aboutsummaryrefslogtreecommitdiffhomepage
path: root/backends/wininput.h
diff options
context:
space:
mode:
authorcbdev <cb@cbcdn.com>2021-06-30 03:03:48 +0200
committercbdev <cb@cbcdn.com>2021-06-30 03:03:48 +0200
commitbc3d80e9e6c038c87a64432586670c663a23e53d (patch)
tree5a28b0004a7f3492455316f34bb2c783e670f944 /backends/wininput.h
parent8a0a413f1dd5593189dd6b651babcff9b2495451 (diff)
parentf16f7db86662fcdbf45b6373257c90c824b0b4b0 (diff)
downloadmidimonster-bc3d80e9e6c038c87a64432586670c663a23e53d.tar.gz
midimonster-bc3d80e9e6c038c87a64432586670c663a23e53d.tar.bz2
midimonster-bc3d80e9e6c038c87a64432586670c663a23e53d.zip
Merge branch 'master' into debian/master
Diffstat (limited to 'backends/wininput.h')
-rw-r--r--backends/wininput.h54
1 files changed, 54 insertions, 0 deletions
diff --git a/backends/wininput.h b/backends/wininput.h
new file mode 100644
index 0000000..0939cc3
--- /dev/null
+++ b/backends/wininput.h
@@ -0,0 +1,54 @@
+#include "midimonster.h"
+
+MM_PLUGIN_API int init();
+static int wininput_configure(char* option, char* value);
+static int wininput_configure_instance(instance* inst, char* option, char* value);
+static int wininput_instance(instance* inst);
+static channel* wininput_channel(instance* inst, char* spec, uint8_t flags);
+static uint32_t wininput_interval();
+static int wininput_set(instance* inst, size_t num, channel** c, channel_value* v);
+static int wininput_handle(size_t num, managed_fd* fds);
+static int wininput_start(size_t n, instance** inst);
+static int wininput_shutdown(size_t n, instance** inst);
+
+enum /*wininput_channel_type*/ {
+ none = 0,
+ mouse,
+ keyboard,
+ joystick
+};
+
+enum /*wininput_control_channel*/ {
+ keypress = 0,
+ button,
+ position,
+ wheel,
+
+ key_unicode
+};
+
+typedef struct /*_wininput_key_info*/ {
+ uint8_t keycode;
+ char* name;
+ uint8_t channel;
+} key_info;
+
+typedef union {
+ struct {
+ uint8_t pad[4];
+ uint8_t type;
+ uint8_t channel;
+ uint16_t control;
+ } fields;
+ uint64_t label;
+} wininput_channel_ident;
+
+typedef struct /*_input_request*/ {
+ wininput_channel_ident ident;
+ size_t channels;
+ channel** channel;
+ uint32_t state;
+
+ //used for jostick axes
+ uint32_t min, max;
+} wininput_request;