summaryrefslogtreecommitdiffstats
path: root/lib/efl/native/eina_hash.rb
diff options
context:
space:
mode:
authorJérémy Zurcher <jeremy@asynk.ch>2012-02-27 15:48:45 +0100
committerJérémy Zurcher <jeremy@asynk.ch>2012-02-27 15:48:45 +0100
commitef44077310b4ebf8d3cb31ccb57d15b96a94c9d3 (patch)
treec2bb690ccc1be37c03f6dcdcf892fbf3e17f5067 /lib/efl/native/eina_hash.rb
parentdbb2c5713e11489dfaeb318a82785017f1794dde (diff)
parentb030c490265bb13ee98a650da419a033495042ed (diff)
downloadffi-efl-ef44077310b4ebf8d3cb31ccb57d15b96a94c9d3.zip
ffi-efl-ef44077310b4ebf8d3cb31ccb57d15b96a94c9d3.tar.gz
Merge branch 'wip'
Conflicts: tools/genruby.rb
Diffstat (limited to 'lib/efl/native/eina_hash.rb')
-rw-r--r--lib/efl/native/eina_hash.rb86
1 files changed, 40 insertions, 46 deletions
diff --git a/lib/efl/native/eina_hash.rb b/lib/efl/native/eina_hash.rb
index 383c182..37beff3 100644
--- a/lib/efl/native/eina_hash.rb
+++ b/lib/efl/native/eina_hash.rb
@@ -1,18 +1,17 @@
#! /usr/bin/env ruby
# -*- coding: UTF-8 -*-
#
-require 'efl/ffi'
+require 'efl/native'
#
module Efl
#
module EinaHash
#
- FCT_PREFIX = 'eina_hash_'
+ FCT_PREFIX = 'eina_hash_' unless const_defined? :FCT_PREFIX
#
- def self.method_missing m, *args, &block
- sym, args_s = ModuleHelper.find_function m, FCT_PREFIX
- self.module_eval "def self.#{m} *args, &block; r=Efl::Native.#{sym}(#{args_s}); yield r if block_given?; r; end"
- self.send m, *args, &block
+ def self.method_missing meth, *args, &block
+ sym = Efl::MethodResolver.resolve self, meth, FCT_PREFIX
+ self.send sym, *args, &block
end
#
end
@@ -21,91 +20,86 @@ module Efl
#
ffi_lib 'eina'
#
- # ENUMS
- #
# TYPEDEFS
# typedef struct _Eina_Hash Eina_Hash;
typedef :pointer, :eina_hash
- typedef :pointer, :eina_hash_p
# typedef struct _Eina_Hash_Tuple Eina_Hash_Tuple;
typedef :pointer, :eina_hash_tuple
#
# CALLBACKS
# typedef unsigned int (*Eina_Key_Length) (const void *key);
- callback :eina_key_length, [ :void_p ], :uint
+ callback :eina_key_length_cb, [ :pointer ], :uint
# typedef int (*Eina_Key_Cmp) (const void *key1, int key1_length, const void *key2, int key2_length);
- callback :eina_key_cmp, [ :void_p, :int, :void_p, :int ], :int
+ callback :eina_key_cmp_cb, [ :pointer, :int, :pointer, :int ], :int
# typedef int (*Eina_Key_Hash) (const void *key, int key_length);
- callback :eina_key_hash, [ :void_p, :int ], :int
+ callback :eina_key_hash_cb, [ :pointer, :int ], :int
# typedef Eina_Bool (*Eina_Hash_Foreach) (const Eina_Hash *hash, const void *key, void *data, void *fdata);
- callback :eina_hash_foreach, [ :eina_hash_p, :void_p, :void_p, :void_p ], :eina_bool
- #
- # VARIABLES
+ callback :eina_hash_foreach_cb, [ :eina_hash, :pointer, :pointer, :pointer ], :bool
#
# FUNCTIONS
fcts = [
# EAPI Eina_Hash *eina_hash_new(Eina_Key_Length key_length_cb, Eina_Key_Cmp key_cmp_cb, Eina_Key_Hash key_hash_cb, Eina_Free_Cb data_free_cb, int buckets_power_size);
- [ :eina_hash_new, [ :eina_key_length, :eina_key_cmp, :eina_key_hash, :eina_free_cb, :int ], :eina_hash_p ],
+ [ :eina_hash_new, [ :eina_key_length_cb, :eina_key_cmp_cb, :eina_key_hash_cb, :eina_free_cb, :int ], :eina_hash ],
# EAPI void eina_hash_free_cb_set(Eina_Hash *hash, Eina_Free_Cb data_free_cb);
- [ :eina_hash_free_cb_set, [ :eina_hash_p, :eina_free_cb ], :void ],
+ [ :eina_hash_free_cb_set, [ :eina_hash, :eina_free_cb ], :void ],
# EAPI Eina_Hash *eina_hash_string_djb2_new(Eina_Free_Cb data_free_cb);
- [ :eina_hash_string_djb2_new, [ :eina_free_cb ], :eina_hash_p ],
+ [ :eina_hash_string_djb2_new, [ :eina_free_cb ], :eina_hash ],
# EAPI Eina_Hash *eina_hash_string_superfast_new(Eina_Free_Cb data_free_cb);
- [ :eina_hash_string_superfast_new, [ :eina_free_cb ], :eina_hash_p ],
+ [ :eina_hash_string_superfast_new, [ :eina_free_cb ], :eina_hash ],
# EAPI Eina_Hash *eina_hash_string_small_new(Eina_Free_Cb data_free_cb);
- [ :eina_hash_string_small_new, [ :eina_free_cb ], :eina_hash_p ],
+ [ :eina_hash_string_small_new, [ :eina_free_cb ], :eina_hash ],
# EAPI Eina_Hash *eina_hash_int32_new(Eina_Free_Cb data_free_cb);
- [ :eina_hash_int32_new, [ :eina_free_cb ], :eina_hash_p ],
+ [ :eina_hash_int32_new, [ :eina_free_cb ], :eina_hash ],
# EAPI Eina_Hash *eina_hash_int64_new(Eina_Free_Cb data_free_cb);
- [ :eina_hash_int64_new, [ :eina_free_cb ], :eina_hash_p ],
+ [ :eina_hash_int64_new, [ :eina_free_cb ], :eina_hash ],
# EAPI Eina_Hash *eina_hash_pointer_new(Eina_Free_Cb data_free_cb);
- [ :eina_hash_pointer_new, [ :eina_free_cb ], :eina_hash_p ],
+ [ :eina_hash_pointer_new, [ :eina_free_cb ], :eina_hash ],
# EAPI Eina_Hash *eina_hash_stringshared_new(Eina_Free_Cb data_free_cb);
- [ :eina_hash_stringshared_new, [ :eina_free_cb ], :eina_hash_p ],
+ [ :eina_hash_stringshared_new, [ :eina_free_cb ], :eina_hash ],
# EAPI Eina_Bool eina_hash_add(Eina_Hash *hash, const void *key, const void *data);
- [ :eina_hash_add, [ :eina_hash_p, :void_p, :void_p ], :eina_bool ],
+ [ :eina_hash_add, [ :eina_hash, :pointer, :pointer ], :bool ],
# EAPI Eina_Bool eina_hash_direct_add(Eina_Hash *hash, const void *key, const void *data);
- [ :eina_hash_direct_add, [ :eina_hash_p, :void_p, :void_p ], :eina_bool ],
+ [ :eina_hash_direct_add, [ :eina_hash, :pointer, :pointer ], :bool ],
# EAPI Eina_Bool eina_hash_del(Eina_Hash *hash, const void *key, const void *data);
- [ :eina_hash_del, [ :eina_hash_p, :void_p, :void_p ], :eina_bool ],
+ [ :eina_hash_del, [ :eina_hash, :pointer, :pointer ], :bool ],
# EAPI void *eina_hash_find(const Eina_Hash *hash, const void *key);
- [ :eina_hash_find, [ :eina_hash_p, :void_p ], :void_p ],
+ [ :eina_hash_find, [ :eina_hash, :pointer ], :pointer ],
# EAPI void *eina_hash_modify(Eina_Hash *hash, const void *key, const void *data);
- [ :eina_hash_modify, [ :eina_hash_p, :void_p, :void_p ], :void_p ],
+ [ :eina_hash_modify, [ :eina_hash, :pointer, :pointer ], :pointer ],
# EAPI void *eina_hash_set(Eina_Hash *hash, const void *key, const void *data);
- [ :eina_hash_set, [ :eina_hash_p, :void_p, :void_p ], :void_p ],
+ [ :eina_hash_set, [ :eina_hash, :pointer, :pointer ], :pointer ],
# EAPI Eina_Bool eina_hash_move(Eina_Hash *hash, const void *old_key, const void *new_key);
- [ :eina_hash_move, [ :eina_hash_p, :void_p, :void_p ], :eina_bool ],
+ [ :eina_hash_move, [ :eina_hash, :pointer, :pointer ], :bool ],
# EAPI void eina_hash_free(Eina_Hash *hash);
- [ :eina_hash_free, [ :eina_hash_p ], :void ],
+ [ :eina_hash_free, [ :eina_hash ], :void ],
# EAPI void eina_hash_free_buckets(Eina_Hash *hash);
- [ :eina_hash_free_buckets, [ :eina_hash_p ], :void ],
+ [ :eina_hash_free_buckets, [ :eina_hash ], :void ],
# EAPI int eina_hash_population(const Eina_Hash *hash);
- [ :eina_hash_population, [ :eina_hash_p ], :int ],
+ [ :eina_hash_population, [ :eina_hash ], :int ],
# EAPI Eina_Bool eina_hash_add_by_hash(Eina_Hash *hash, const void *key, int key_length, int key_hash, const void *data);
- [ :eina_hash_add_by_hash, [ :eina_hash_p, :void_p, :int, :int, :void_p ], :eina_bool ],
+ [ :eina_hash_add_by_hash, [ :eina_hash, :pointer, :int, :int, :pointer ], :bool ],
# EAPI Eina_Bool eina_hash_direct_add_by_hash(Eina_Hash *hash, const void *key, int key_length, int key_hash, const void *data);
- [ :eina_hash_direct_add_by_hash, [ :eina_hash_p, :void_p, :int, :int, :void_p ], :eina_bool ],
+ [ :eina_hash_direct_add_by_hash, [ :eina_hash, :pointer, :int, :int, :pointer ], :bool ],
# EAPI Eina_Bool eina_hash_del_by_key_hash(Eina_Hash *hash, const void *key, int key_length, int key_hash);
- [ :eina_hash_del_by_key_hash, [ :eina_hash_p, :void_p, :int, :int ], :eina_bool ],
+ [ :eina_hash_del_by_key_hash, [ :eina_hash, :pointer, :int, :int ], :bool ],
# EAPI Eina_Bool eina_hash_del_by_key(Eina_Hash *hash, const void *key);
- [ :eina_hash_del_by_key, [ :eina_hash_p, :void_p ], :eina_bool ],
+ [ :eina_hash_del_by_key, [ :eina_hash, :pointer ], :bool ],
# EAPI Eina_Bool eina_hash_del_by_data(Eina_Hash *hash, const void *data);
- [ :eina_hash_del_by_data, [ :eina_hash_p, :void_p ], :eina_bool ],
+ [ :eina_hash_del_by_data, [ :eina_hash, :pointer ], :bool ],
# EAPI Eina_Bool eina_hash_del_by_hash(Eina_Hash *hash, const void *key, int key_length, int key_hash, const void *data);
- [ :eina_hash_del_by_hash, [ :eina_hash_p, :void_p, :int, :int, :void_p ], :eina_bool ],
+ [ :eina_hash_del_by_hash, [ :eina_hash, :pointer, :int, :int, :pointer ], :bool ],
# EAPI void *eina_hash_find_by_hash(const Eina_Hash *hash, const void *key, int key_length, int key_hash);
- [ :eina_hash_find_by_hash, [ :eina_hash_p, :void_p, :int, :int ], :void_p ],
+ [ :eina_hash_find_by_hash, [ :eina_hash, :pointer, :int, :int ], :pointer ],
# EAPI void *eina_hash_modify_by_hash(Eina_Hash *hash, const void *key, int key_length, int key_hash, const void *data);
- [ :eina_hash_modify_by_hash, [ :eina_hash_p, :void_p, :int, :int, :void_p ], :void_p ],
+ [ :eina_hash_modify_by_hash, [ :eina_hash, :pointer, :int, :int, :pointer ], :pointer ],
# EAPI Eina_Iterator *eina_hash_iterator_key_new(const Eina_Hash *hash);
- [ :eina_hash_iterator_key_new, [ :eina_hash_p ], :eina_iterator_p ],
+ [ :eina_hash_iterator_key_new, [ :eina_hash ], :pointer ],
# EAPI Eina_Iterator *eina_hash_iterator_data_new(const Eina_Hash *hash);
- [ :eina_hash_iterator_data_new, [ :eina_hash_p ], :eina_iterator_p ],
+ [ :eina_hash_iterator_data_new, [ :eina_hash ], :pointer ],
# EAPI Eina_Iterator *eina_hash_iterator_tuple_new(const Eina_Hash *hash);
- [ :eina_hash_iterator_tuple_new, [ :eina_hash_p ], :eina_iterator_p ],
+ [ :eina_hash_iterator_tuple_new, [ :eina_hash ], :pointer ],
# EAPI void eina_hash_foreach(const Eina_Hash *hash, Eina_Hash_Foreach func, const void *fdata);
- [ :eina_hash_foreach, [ :eina_hash_p, :eina_hash_foreach, :void_p ], :void ],
+ [ :eina_hash_foreach, [ :eina_hash, :eina_hash_foreach_cb, :pointer ], :void ],
# EAPI int eina_hash_superfast(const char *key, int len);
[ :eina_hash_superfast, [ :string, :int ], :int ],
]