add varray api
This commit is contained in:
parent
c1e4069706
commit
30f7f4475f
3 changed files with 85 additions and 1 deletions
|
|
@ -147,7 +147,7 @@ typedef struct {
|
|||
bit_clrall_fn_t clrall;
|
||||
} intf_bitmap_t;
|
||||
|
||||
/* key to id table */
|
||||
/* key to val table */
|
||||
|
||||
typedef int (*key_add_fn_t)(meta_obj_t*, void*, void*);
|
||||
typedef int (*key_del_fn_t)(meta_obj_t*, void*);
|
||||
|
|
@ -159,6 +159,18 @@ typedef struct {
|
|||
key_find_fn_t find_key;
|
||||
} intf_kv_t;
|
||||
|
||||
/* array API */
|
||||
|
||||
typedef int (*vstore_fn_t)(meta_obj_t*, void*);
|
||||
typedef int (*vget_fn_t)(meta_obj_t*, int, void**);
|
||||
typedef int (*vput_fn_t)(meta_obj_t*, int, void*);
|
||||
|
||||
typedef struct {
|
||||
vstore_fn_t vstore;
|
||||
vget_fn_t vget;
|
||||
vput_fn_t vput;
|
||||
} intf_varray_t;
|
||||
|
||||
typedef struct {
|
||||
intf_lock_t* lock;
|
||||
intf_tostring_t* toString;
|
||||
|
|
@ -168,6 +180,7 @@ typedef struct {
|
|||
intf_length_t* length;
|
||||
intf_bitmap_t* bitmap;
|
||||
intf_kv_t* kv;
|
||||
intf_varray_t* varray;
|
||||
} interface_table_t;
|
||||
|
||||
struct typeinfo_ {
|
||||
|
|
@ -219,4 +232,8 @@ extern int key_add(var, void*, void*);
|
|||
extern int key_del(var, void*);
|
||||
extern int key_find(var, void*, void**);
|
||||
|
||||
extern int vstore(var, void*);
|
||||
extern int vget(var, int, void**);
|
||||
extern int vput(var, int, void*);
|
||||
|
||||
#endif
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue