59 #define MDB_IDL_LOGN 16
60 #define MDB_IDL_DB_SIZE (1<<MDB_IDL_LOGN)
61 #define MDB_IDL_UM_SIZE (1<<(MDB_IDL_LOGN+1))
63 #define MDB_IDL_DB_MAX (MDB_IDL_DB_SIZE-1)
64 #define MDB_IDL_UM_MAX (MDB_IDL_UM_SIZE-1)
66 #define MDB_IDL_SIZEOF(ids) (((ids)[0]+1) * sizeof(MDB_ID))
67 #define MDB_IDL_IS_ZERO(ids) ( (ids)[0] == 0 )
68 #define MDB_IDL_CPY( dst, src ) (memcpy( dst, src, MDB_IDL_SIZEOF( src ) ))
69 #define MDB_IDL_FIRST( ids ) ( (ids)[1] )
70 #define MDB_IDL_LAST( ids ) ( (ids)[(ids)[0]] )
73 #define MDB_IDL_ALLOCLEN( ids ) ( (ids)[-1] )
76 #define mdb_midl_xappend(idl, id) do { \
77 MDB_ID *xidl = (idl), xlen = ++(xidl[0]); \
182 typedef struct MDB_ID3 {
189 typedef MDB_ID3 *MDB_ID3L;
191 unsigned mdb_mid3l_search( MDB_ID3L ids,
MDB_ID id );
192 int mdb_mid3l_insert( MDB_ID3L ids, MDB_ID3 *
id );
void mdb_midl_free(MDB_IDL ids)
int mdb_midl_append_list(MDB_IDL *idp, MDB_IDL app)
int mdb_midl_need(MDB_IDL *idp, unsigned num)
void mdb_midl_xmerge(MDB_IDL idl, MDB_IDL merge)
unsigned mdb_mid2l_search(MDB_ID2L ids, MDB_ID id)
int mdb_mid2l_append(MDB_ID2L ids, MDB_ID2 *id)
int mdb_mid2l_insert(MDB_ID2L ids, MDB_ID2 *id)
void mdb_midl_shrink(MDB_IDL *idp)
unsigned mdb_midl_search(MDB_IDL ids, MDB_ID id)
MDB_IDL mdb_midl_alloc(int num)
void mdb_midl_sort(MDB_IDL ids)
int mdb_midl_append_range(MDB_IDL *idp, MDB_ID id, unsigned n)
int mdb_midl_append(MDB_IDL *idp, MDB_ID id)