add key2id api
This commit is contained in:
parent
6f6bb5b4e0
commit
d8690bfeb9
3 changed files with 77 additions and 0 deletions
|
|
@ -147,6 +147,18 @@ typedef struct {
|
||||||
bit_clrall_fn_t clrall;
|
bit_clrall_fn_t clrall;
|
||||||
} intf_bitmap_t;
|
} intf_bitmap_t;
|
||||||
|
|
||||||
|
/* key to id table */
|
||||||
|
|
||||||
|
typedef int (*key_add_fn_t)(meta_obj_t*, uint64_t*, void*);
|
||||||
|
typedef int (*key_del_fn_t)(meta_obj_t*, void*);
|
||||||
|
typedef uint64_t (*key_find_fn_t)(meta_obj_t*, uint64_t*, void*);
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
key_add_fn_t add_key;
|
||||||
|
key_del_fn_t del_key;
|
||||||
|
key_find_fn_t find_key;
|
||||||
|
} intf_key2id_t;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
intf_lock_t* lock;
|
intf_lock_t* lock;
|
||||||
intf_tostring_t* toString;
|
intf_tostring_t* toString;
|
||||||
|
|
@ -155,6 +167,7 @@ typedef struct {
|
||||||
intf_hash_t* hash;
|
intf_hash_t* hash;
|
||||||
intf_length_t* length;
|
intf_length_t* length;
|
||||||
intf_bitmap_t* bitmap;
|
intf_bitmap_t* bitmap;
|
||||||
|
intf_key2id_t* key2id;
|
||||||
} interface_table_t;
|
} interface_table_t;
|
||||||
|
|
||||||
struct typeinfo_ {
|
struct typeinfo_ {
|
||||||
|
|
@ -201,4 +214,8 @@ extern int bit_set(var, unsigned long);
|
||||||
extern int bit_clr(var, unsigned long);
|
extern int bit_clr(var, unsigned long);
|
||||||
extern int bit_clrall(var);
|
extern int bit_clrall(var);
|
||||||
|
|
||||||
|
extern int key_add(var, uint64_t*, void*);
|
||||||
|
extern int key_del(var, void*);
|
||||||
|
extern int key_find(var, uint64_t*, void*);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
||||||
59
src/key2id.c
Normal file
59
src/key2id.c
Normal file
|
|
@ -0,0 +1,59 @@
|
||||||
|
#include <errno.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
#include "rtti.h"
|
||||||
|
|
||||||
|
int key_add(var v, uint64_t* id, void* key)
|
||||||
|
{
|
||||||
|
meta_obj_t* obj = NULL;
|
||||||
|
key_add_fn_t method = NULL;
|
||||||
|
|
||||||
|
obj = RTTI_DATA_TO_OBJ(v);
|
||||||
|
if (RTTI_OBJ_INVALID(obj)) {
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
RTTI_GET_METHOD(method, obj, key2id, add_key);
|
||||||
|
if (method == NULL) {
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
return method(obj, id, key);
|
||||||
|
}
|
||||||
|
|
||||||
|
int key_del(var v, void* key)
|
||||||
|
{
|
||||||
|
meta_obj_t* obj = NULL;
|
||||||
|
key_del_fn_t method = NULL;
|
||||||
|
|
||||||
|
obj = RTTI_DATA_TO_OBJ(v);
|
||||||
|
if (RTTI_OBJ_INVALID(obj)) {
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
RTTI_GET_METHOD(method, obj, key2id, del_key);
|
||||||
|
if (method == NULL) {
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
return method(obj, key);
|
||||||
|
}
|
||||||
|
|
||||||
|
int key_find(var v, uint64_t* id, void* key)
|
||||||
|
{
|
||||||
|
meta_obj_t* obj = NULL;
|
||||||
|
key_find_fn_t method = NULL;
|
||||||
|
|
||||||
|
obj = RTTI_DATA_TO_OBJ(v);
|
||||||
|
if (RTTI_OBJ_INVALID(obj)) {
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
RTTI_GET_METHOD(method, obj, key2id, find_key);
|
||||||
|
if (method == NULL) {
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
return method(obj, id, key);
|
||||||
|
}
|
||||||
|
|
@ -10,6 +10,7 @@ librtti_c_srcs=[
|
||||||
'hash.c',
|
'hash.c',
|
||||||
'length.c',
|
'length.c',
|
||||||
'bitmap.c',
|
'bitmap.c',
|
||||||
|
'key2id.c',
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue