diff options
author | Jérémy Zurcher <jeremy@asynk.ch> | 2011-05-19 09:47:05 +0200 |
---|---|---|
committer | Jérémy Zurcher <jeremy@asynk.ch> | 2011-05-19 09:47:05 +0200 |
commit | 422d2cf48320daed5caf35be2d94838268775a1b (patch) | |
tree | 4ced7dc7a3f24f35ee2f8bb6ec1efc6c1b360490 /lib/efl/native/elementary.rb | |
parent | a3fbc22500199376091e37280c0dc336cab2da51 (diff) | |
download | ffi-efl-422d2cf48320daed5caf35be2d94838268775a1b.zip ffi-efl-422d2cf48320daed5caf35be2d94838268775a1b.tar.gz |
extract find_function from Module specific method_missing
Diffstat (limited to 'lib/efl/native/elementary.rb')
-rw-r--r-- | lib/efl/native/elementary.rb | 28 |
1 files changed, 4 insertions, 24 deletions
diff --git a/lib/efl/native/elementary.rb b/lib/efl/native/elementary.rb index 7e2dc4d..76bc3d0 100644 --- a/lib/efl/native/elementary.rb +++ b/lib/efl/native/elementary.rb @@ -8,31 +8,11 @@ module Efl # module Elm # + FCT_PREFIX = 'elm_' + # def self.method_missing m, *args, &block - m_s = m.to_s - if m_s =~/^(.*)=$/ - m_s = $1+'_set' - args_s = '*args[0]' - elsif m_s =~/^(.*)\?$/ - m_s = $1+'_get' - args_s = '*args' - else - args_s = '*args' - end - sym = ( - if Efl::Native.respond_to? 'elm_'+m_s - 'elm_'+m_s - elsif Efl::Native.respond_to? m_s - m_s - elsif Efl::Native.respond_to? 'elm_'+m_s+'_get' - 'elm_'+m_s+'_get' - elsif Efl::Native.respond_to? m_s+'_get' - m_s+'_get' - else - raise NameError.new "#{self.name}.#{m_s} (#{m})" - end - ) - self.module_eval "def self.#{m} *args, █ r=Efl::Native.#{sym}(*args); yield r if block_given?; r; end" + sym, args_s = ModuleHelper.find_function m, FCT_PREFIX + self.module_eval "def self.#{m} *args, █ r=Efl::Native.#{sym}(#{args_s}); yield r if block_given?; r; end" self.send m, *args, &block end # |