diff options
Diffstat (limited to 'lib/efl/native/ecore_input.rb')
-rw-r--r-- | lib/efl/native/ecore_input.rb | 84 |
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, █ 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 |