2011-07-01 18:56:09 +08:00
|
|
|
/* idl.h - ldap bdb back-end ID list header file */
|
|
|
|
/* $OpenLDAP$ */
|
|
|
|
/* This work is part of OpenLDAP Software <http://www.openldap.org/>.
|
|
|
|
*
|
|
|
|
* Copyright 2000-2011 The OpenLDAP Foundation.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted only as authorized by the OpenLDAP
|
|
|
|
* Public License.
|
|
|
|
*
|
|
|
|
* A copy of this license is available in the file LICENSE in the
|
|
|
|
* top-level directory of the distribution or, alternatively, at
|
|
|
|
* <http://www.OpenLDAP.org/license.html>.
|
|
|
|
*/
|
|
|
|
|
2011-08-12 08:33:28 +08:00
|
|
|
#ifndef _MDB_MIDL_H_
|
|
|
|
#define _MDB_MIDL_H_
|
2011-07-01 18:56:09 +08:00
|
|
|
|
|
|
|
#define ID unsigned long
|
2011-08-20 03:56:10 +08:00
|
|
|
#define NOID (~(ID)0)
|
2011-07-01 18:56:09 +08:00
|
|
|
|
|
|
|
/* IDL sizes - likely should be even bigger
|
|
|
|
* limiting factors: sizeof(ID), thread stack size
|
|
|
|
*/
|
|
|
|
#define MDB_IDL_LOGN 16 /* DB_SIZE is 2^16, UM_SIZE is 2^17 */
|
|
|
|
#define MDB_IDL_DB_SIZE (1<<MDB_IDL_LOGN)
|
|
|
|
#define MDB_IDL_UM_SIZE (1<<(MDB_IDL_LOGN+1))
|
|
|
|
#define MDB_IDL_UM_SIZEOF (MDB_IDL_UM_SIZE * sizeof(ID))
|
|
|
|
|
|
|
|
#define MDB_IDL_DB_MAX (MDB_IDL_DB_SIZE-1)
|
|
|
|
|
|
|
|
#define MDB_IDL_UM_MAX (MDB_IDL_UM_SIZE-1)
|
|
|
|
|
|
|
|
#define MDB_IDL_IS_RANGE(ids) ((ids)[0] == NOID)
|
|
|
|
#define MDB_IDL_RANGE_SIZE (3)
|
|
|
|
#define MDB_IDL_RANGE_SIZEOF (MDB_IDL_RANGE_SIZE * sizeof(ID))
|
|
|
|
#define MDB_IDL_SIZEOF(ids) ((MDB_IDL_IS_RANGE(ids) \
|
|
|
|
? MDB_IDL_RANGE_SIZE : ((ids)[0]+1)) * sizeof(ID))
|
|
|
|
|
|
|
|
#define MDB_IDL_RANGE_FIRST(ids) ((ids)[1])
|
|
|
|
#define MDB_IDL_RANGE_LAST(ids) ((ids)[2])
|
|
|
|
|
|
|
|
#define MDB_IDL_RANGE( ids, f, l ) \
|
|
|
|
do { \
|
|
|
|
(ids)[0] = NOID; \
|
|
|
|
(ids)[1] = (f); \
|
|
|
|
(ids)[2] = (l); \
|
|
|
|
} while(0)
|
|
|
|
|
|
|
|
#define MDB_IDL_ZERO(ids) \
|
|
|
|
do { \
|
|
|
|
(ids)[0] = 0; \
|
|
|
|
(ids)[1] = 0; \
|
|
|
|
(ids)[2] = 0; \
|
|
|
|
} while(0)
|
|
|
|
|
|
|
|
#define MDB_IDL_IS_ZERO(ids) ( (ids)[0] == 0 )
|
|
|
|
#define MDB_IDL_IS_ALL( range, ids ) ( (ids)[0] == NOID \
|
|
|
|
&& (ids)[1] <= (range)[1] && (range)[2] <= (ids)[2] )
|
|
|
|
|
2011-08-15 11:12:20 +08:00
|
|
|
#define MDB_IDL_CPY( dst, src ) (memcpy( dst, src, MDB_IDL_SIZEOF( src ) ))
|
2011-07-01 18:56:09 +08:00
|
|
|
|
|
|
|
#define MDB_IDL_ID( bdb, ids, id ) MDB_IDL_RANGE( ids, id, ((bdb)->bi_lastid) )
|
|
|
|
#define MDB_IDL_ALL( bdb, ids ) MDB_IDL_RANGE( ids, 1, ((bdb)->bi_lastid) )
|
|
|
|
|
2011-08-20 03:56:10 +08:00
|
|
|
#define MDB_IDL_FIRST( ids ) ( (ids)[1] )
|
2011-07-01 18:56:09 +08:00
|
|
|
#define MDB_IDL_LAST( ids ) ( MDB_IDL_IS_RANGE(ids) \
|
2011-08-20 03:56:10 +08:00
|
|
|
? (ids)[2] : (ids)[(ids)[0]] )
|
2011-07-01 18:56:09 +08:00
|
|
|
|
|
|
|
#define MDB_IDL_N( ids ) ( MDB_IDL_IS_RANGE(ids) \
|
2011-08-20 03:56:10 +08:00
|
|
|
? ((ids)[2]-(ids)[1])+1 : (ids)[0] )
|
2011-07-01 18:56:09 +08:00
|
|
|
|
2011-08-12 08:33:28 +08:00
|
|
|
int mdb_midl_insert( ID *ids, ID id );
|
2011-07-01 18:56:09 +08:00
|
|
|
|
2011-08-15 11:01:26 +08:00
|
|
|
typedef struct MIDL2 {
|
|
|
|
ID mid;
|
|
|
|
void *mptr;
|
|
|
|
} MIDL2;
|
|
|
|
|
|
|
|
unsigned mdb_midl2_search( MIDL2 *ids, MIDL2 *id );
|
|
|
|
int mdb_midl2_insert( MIDL2 *ids, MIDL2 *id );
|
|
|
|
|
2011-08-12 08:33:28 +08:00
|
|
|
#endif /* _MDB_MIDL_H_ */
|