summaryrefslogtreecommitdiffstats
path: root/lib/efl/native/ecore_input.rb
diff options
context:
space:
mode:
authorJérémy Zurcher <jeremy@asynk.ch>2011-05-04 23:42:07 +0200
committerJérémy Zurcher <jeremy@asynk.ch>2011-05-04 23:42:07 +0200
commite4baccaefd209a25daa3ff8d5277fe86aca1d379 (patch)
treeeb2744b7a8624a7538cb0224d40879074c819653 /lib/efl/native/ecore_input.rb
parent3974ea1fb3734cbf4150c759eebdf8a93d77dc8b (diff)
downloadffi-efl-e4baccaefd209a25daa3ff8d5277fe86aca1d379.zip
ffi-efl-e4baccaefd209a25daa3ff8d5277fe86aca1d379.tar.gz
FFI are in separate namespaces (Efl::Evas::Native), ruby classes are in upper level (Efl::Evas)seperate-natives
Diffstat (limited to 'lib/efl/native/ecore_input.rb')
-rw-r--r--lib/efl/native/ecore_input.rb84
1 files changed, 84 insertions, 0 deletions
diff --git a/lib/efl/native/ecore_input.rb b/lib/efl/native/ecore_input.rb
new file mode 100644
index 0000000..d14409e
--- /dev/null
+++ b/lib/efl/native/ecore_input.rb
@@ -0,0 +1,84 @@
+#! /usr/bin/env ruby
+# -*- coding: UTF-8 -*-
+#
+require 'efl/ffi'
+#
+module Efl
+ #
+ module EcoreInput
+ #
+ def self.method_missing m, *args, &block
+ sym = 'ecore_event_'+m.to_s
+ raise NameError.new "#{self.name}.#{sym} (#{m})" if not Efl::EcoreInput::Native.respond_to? sym
+ self.module_eval "def self.#{m} *args, &block; r=Efl::EcoreInput::Native.#{sym}(*args); yield r if block_given?; r; end"
+ self.send m, *args, &block
+ end
+ #
+ module Native
+ #
+ extend Efl::FFIHelper
+ #
+ ffi_lib 'ecore_input'
+ #
+ # ENUMS
+ # typedef enum _Ecore_Event_Modifier {...} Ecore_Event_Modifier;
+ enum :ecore_event_modifier, [ :ecore_none, :ecore_shift, :ecore_ctrl, :ecore_alt, :ecore_win, :ecore_scroll, :ecore_caps, :ecore_last ]
+ # typedef enum _Ecore_Event_Press {...} Ecore_Event_Press;
+ enum :ecore_event_press, [ :ecore_down, :ecore_up ]
+ # typedef enum _Ecore_Event_IO {...} Ecore_Event_IO;
+ enum :ecore_event_io, [ :ecore_in, :ecore_out ]
+ #
+ # TYPEDEFS
+ # typedef uintptr_t Ecore_Window;
+ typedef :uintptr_t, :ecore_window
+ # typedef struct _Ecore_Event_Key Ecore_Event_Key;
+ typedef :pointer, :ecore_event_key
+ # typedef struct _Ecore_Event_Mouse_Button Ecore_Event_Mouse_Button;
+ typedef :pointer, :ecore_event_mouse_button
+ # typedef struct _Ecore_Event_Mouse_Wheel Ecore_Event_Mouse_Wheel;
+ typedef :pointer, :ecore_event_mouse_wheel
+ # typedef struct _Ecore_Event_Mouse_Move Ecore_Event_Mouse_Move;
+ typedef :pointer, :ecore_event_mouse_move
+ # typedef struct _Ecore_Event_Mouse_IO Ecore_Event_Mouse_IO;
+ typedef :pointer, :ecore_event_mouse_io
+ # typedef struct _Ecore_Event_Modifiers Ecore_Event_Modifiers;
+ typedef :pointer, :ecore_event_modifiers
+ typedef :pointer, :ecore_event_modifiers_p
+ #
+ # CALLBACKS
+ #
+ # FUNCTIONS
+ fcts = [
+ # EAPI extern int ECORE_EVENT_KEY_DOWN;
+ # FIXME
+ # EAPI extern int ECORE_EVENT_KEY_UP;
+ # FIXME
+ # EAPI extern int ECORE_EVENT_MOUSE_BUTTON_DOWN;
+ # FIXME
+ # EAPI extern int ECORE_EVENT_MOUSE_BUTTON_UP;
+ # FIXME
+ # EAPI extern int ECORE_EVENT_MOUSE_MOVE;
+ # FIXME
+ # EAPI extern int ECORE_EVENT_MOUSE_WHEEL;
+ # FIXME
+ # EAPI extern int ECORE_EVENT_MOUSE_IN;
+ # FIXME
+ # EAPI extern int ECORE_EVENT_MOUSE_OUT;
+ # FIXME
+ # EAPI int ecore_event_init(void);
+ [ :ecore_event_init, [ ], :int ],
+ # EAPI int ecore_event_shutdown(void);
+ [ :ecore_event_shutdown, [ ], :int ],
+ # EAPI unsigned int ecore_event_modifier_mask(Ecore_Event_Modifier modifier);
+ [ :ecore_event_modifier_mask, [ :ecore_event_modifier ], :uint ],
+ # EAPI Ecore_Event_Modifier ecore_event_update_modifier(const char *key, Ecore_Event_Modifiers *modifiers, int inc);
+ [ :ecore_event_update_modifier, [ :string, :ecore_event_modifiers_p, :int ], :ecore_event_modifier ],
+ ]
+ #
+ attach_fcts fcts
+ #
+ end
+ end
+end
+#
+# EOF