summaryrefslogtreecommitdiffstats
path: root/lib/efl/evas.rb
diff options
context:
space:
mode:
Diffstat (limited to 'lib/efl/evas.rb')
-rw-r--r--lib/efl/evas.rb22
1 files changed, 4 insertions, 18 deletions
diff --git a/lib/efl/evas.rb b/lib/efl/evas.rb
index b3df675..24ea514 100644
--- a/lib/efl/evas.rb
+++ b/lib/efl/evas.rb
@@ -7,7 +7,8 @@ module Efl
module Evas
#
class Evas
- attr_reader :ptr
+ include Efl::Helper
+ @func_prefixes = [ 'evas_' ].freeze
def initialize o=nil
@ptr = (
case o
@@ -32,12 +33,6 @@ module Efl
def === o
@ptr === o.ptr
end
- def method_missing m, *args, &block
- sym = 'evas_'+m.to_s
- Efl::API.send sym if not Efl::API.respond_to? sym
- self.class.class_eval "def #{m} *args, █ r =Efl::API.#{sym}(@ptr,*args); yield r if block_given?; r; end"
- self.send m, *args, &block
- end
def output_size_get
x = FFI::MemoryPointer.new :int
y = FFI::MemoryPointer.new :int
@@ -67,7 +62,8 @@ module Efl
end
#
class EvasObject
- attr_reader :ptr
+ include Efl::Helper
+ @func_prefixes = [ 'evas_object_', 'evas_' ].freeze
def initialize o=nil
@ptr = (
case o
@@ -89,16 +85,6 @@ module Efl
Efl::API.evas_object_del @ptr
@ptr=nil
end
- def method_missing m, *args, &block
- if Efl::API.respond_to? m
- self.class.class_eval "def #{m} *args, █ r=Efl::API.#{m}(@ptr,*args); yield r if block_given?; r; end"
- return self.send m, *args, &block
- end
- sym = 'evas_object_'+m.to_s
- Efl::API.send sym if not Efl::API.respond_to? sym
- self.class.class_eval "def #{m} *args, █ r=Efl::API.#{sym}(@ptr,*args); yield r if block_given?; r; end"
- self.send m, *args, &block
- end
def geometry_get
x = FFI::MemoryPointer.new :int
y = FFI::MemoryPointer.new :int