lib/tdb_compat: header for tdb1 vs tdb2.
authorRusty Russell <rusty@rustcorp.com.au>
Wed, 8 Jun 2011 07:52:41 +0000 (17:22 +0930)
committerRusty Russell <rusty@rustcorp.com.au>
Wed, 8 Jun 2011 07:52:41 +0000 (17:22 +0930)
commit63aeed4a3dac0466bda3cdcaaef294658e358271
tree5ebb22c03bcf3533e14db01404a3955846f7aee7
parentb74920c3c16182e8806393466cc0239666b6c902
lib/tdb_compat: header for tdb1 vs tdb2.

TDB2's API is slightly different from TDB1.  In particular, all functions
return 0 (TDB_SUCCESS) or a negative error number, rather than -1 or tdb_null
and storing the error in tdb_error() (though TDB2 does that as well).

The simplest fix is to replace all the different functions with a wrapper,
and that is done here.

Compatibility functions:

tdb_null: not used as an error return, so not defined by tdb2.
tdb_fetch_compat: TDB1-style data-returning tdb_fetch.
tdb_firstkey_compat: TDB1-style data-returning tdb_firstkey
tdb_nextkey_compat: TDB1-style data-returning tdb_nextkey, with
TDB2-style free of old key.
tdb_errorstr_compat: TDB1-style tdb_errorstr() which takes TDB instead of ecode.
TDB_CONTEXT: TDB1-style typedef for struct tdb_context.
tdb_open_compat: Simplified open routine which takes log function, sets
TDB_ALLOW_NESTING as Samba expects, and adds TDB_CLEAR_IF_FIRST support.

Things defined away in TDB2 wrappers:

tdb_traverse_read: TDB2's tdb_traverse only uses read-locks anyway.
tdb_reopen/tdb_reopen_all: TDB2 detects this error itself.
TDB_INCOMPATIBLE_HASH: TDB2 uses the Jenkins hash already.
TDB_VOLATILE: TDB2 shouldn't have freelist scaling issues.

Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
lib/tdb_compat/tdb_compat.c [new file with mode: 0644]
lib/tdb_compat/tdb_compat.h [new file with mode: 0644]
lib/tdb_compat/wscript [new file with mode: 0644]
wscript_build