add bitmap interface and fix toString()

This commit is contained in:
Rongsong Shen 2026-02-12 14:48:56 +08:00
parent 00080a95f3
commit ecb1162069
4 changed files with 94 additions and 2 deletions

View file

@ -134,6 +134,19 @@ typedef struct {
length_fn_t length;
} intf_length_t;
/* set */
typedef int (*bit_test_fn_t)(meta_obj_t*, unsigned long);
typedef int (*bit_set_fn_t)(meta_obj_t*, unsigned long);
typedef int (*bit_clr_fn_t)(meta_obj_t*, unsigned long);
typedef int (*bit_clrall_fn_t)(meta_obj_t*);
typedef struct {
bit_test_fn_t test;
bit_set_fn_t set;
bit_clr_fn_t clr;
bit_clrall_fn_t clrall;
} intf_bitmap_t;
typedef struct {
intf_lock_t* lock;
intf_tostring_t* toString;
@ -141,6 +154,7 @@ typedef struct {
intf_reference_t* reference;
intf_hash_t* hash;
intf_length_t* length;
intf_bitmap_t* bitmap;
} interface_table_t;
struct typeinfo_ {

77
src/bitmap.c Normal file
View file

@ -0,0 +1,77 @@
#include <errno.h>
#include <stdio.h>
#include <string.h>
#include "rtti.h"
int bit_test(var v, unsigned long idx)
{
meta_obj_t* obj = NULL;
bit_test_fn_t method = NULL;
obj = RTTI_DATA_TO_OBJ(v);
if (RTTI_OBJ_INVALID(obj)) {
return -EINVAL;
}
RTTI_GET_METHOD(method, obj, bitmap, test);
if (method == NULL) {
return -EINVAL;
}
return method(obj, idx);
}
int bit_set(var v, unsigned long idx)
{
meta_obj_t* obj = NULL;
bit_test_fn_t method = NULL;
obj = RTTI_DATA_TO_OBJ(v);
if (RTTI_OBJ_INVALID(obj)) {
return -EINVAL;
}
RTTI_GET_METHOD(method, obj, bitmap, set);
if (method == NULL) {
return -EINVAL;
}
return method(obj, idx);
}
int bit_clr(var v, unsigned long idx)
{
meta_obj_t* obj = NULL;
bit_test_fn_t method = NULL;
obj = RTTI_DATA_TO_OBJ(v);
if (RTTI_OBJ_INVALID(obj)) {
return -EINVAL;
}
RTTI_GET_METHOD(method, obj, bitmap, clr);
if (method == NULL) {
return -EINVAL;
}
return method(obj, idx);
}
int bit_clrall(var v)
{
meta_obj_t* obj = NULL;
bit_test_fn_t method = NULL;
obj = RTTI_DATA_TO_OBJ(v);
if (RTTI_OBJ_INVALID(obj)) {
return -EINVAL;
}
RTTI_GET_METHOD(method, obj, bitmap, clrall);
if (method == NULL) {
return -EINVAL;
}
return method(obj);
}

View file

@ -8,6 +8,7 @@ librtti_c_srcs=[
'str.c',
'hash.c',
'length.c',
'bitmap.c',
]

View file

@ -23,7 +23,7 @@ char* toString(var v, ...)
}
va_start(ap, v);
s = method(v, ap);
s = method(obj, ap);
va_end(ap);
return s;