mirror of
https://github.com/MariaDB/server.git
synced 2025-08-26 01:44:06 +03:00
storage/bdb/LICENSE: Import db-4.3.28 storage/bdb/btree/bt_compare.c: Import db-4.3.28 storage/bdb/btree/bt_conv.c: Import db-4.3.28 storage/bdb/btree/bt_curadj.c: Import db-4.3.28 storage/bdb/btree/bt_cursor.c: Import db-4.3.28 storage/bdb/btree/bt_delete.c: Import db-4.3.28 storage/bdb/btree/bt_method.c: Import db-4.3.28 storage/bdb/btree/bt_open.c: Import db-4.3.28 storage/bdb/btree/bt_put.c: Import db-4.3.28 storage/bdb/btree/bt_rec.c: Import db-4.3.28 storage/bdb/btree/bt_reclaim.c: Import db-4.3.28 storage/bdb/btree/bt_recno.c: Import db-4.3.28 storage/bdb/btree/bt_rsearch.c: Import db-4.3.28 storage/bdb/btree/bt_search.c: Import db-4.3.28 storage/bdb/btree/bt_split.c: Import db-4.3.28 storage/bdb/btree/bt_stat.c: Import db-4.3.28 storage/bdb/btree/bt_upgrade.c: Import db-4.3.28 storage/bdb/btree/bt_verify.c: Import db-4.3.28 storage/bdb/btree/btree.src: Import db-4.3.28 storage/bdb/build_win32/Berkeley_DB.dsw: Import db-4.3.28 storage/bdb/build_win32/app_dsp.src: Import db-4.3.28 storage/bdb/build_win32/db_test.src: Import db-4.3.28 storage/bdb/build_win32/dbkill.cpp: Import db-4.3.28 storage/bdb/build_win32/dynamic_dsp.src: Import db-4.3.28 storage/bdb/build_win32/java_dsp.src: Import db-4.3.28 storage/bdb/build_win32/libdb_tcl.def: Import db-4.3.28 storage/bdb/build_win32/libdbrc.src: Import db-4.3.28 storage/bdb/build_win32/static_dsp.src: Import db-4.3.28 storage/bdb/build_win32/tcl_dsp.src: Import db-4.3.28 storage/bdb/clib/getcwd.c: Import db-4.3.28 storage/bdb/clib/getopt.c: Import db-4.3.28 storage/bdb/clib/memcmp.c: Import db-4.3.28 storage/bdb/clib/memmove.c: Import db-4.3.28 storage/bdb/clib/raise.c: Import db-4.3.28 storage/bdb/clib/snprintf.c: Import db-4.3.28 storage/bdb/clib/strcasecmp.c: Import db-4.3.28 storage/bdb/clib/strdup.c: Import db-4.3.28 storage/bdb/clib/strerror.c: Import db-4.3.28 storage/bdb/common/db_byteorder.c: Import db-4.3.28 storage/bdb/common/db_err.c: Import db-4.3.28 storage/bdb/common/db_getlong.c: Import db-4.3.28 storage/bdb/common/db_idspace.c: Import db-4.3.28 storage/bdb/common/db_log2.c: Import db-4.3.28 storage/bdb/common/util_arg.c: Import db-4.3.28 storage/bdb/common/util_cache.c: Import db-4.3.28 storage/bdb/common/util_log.c: Import db-4.3.28 storage/bdb/common/util_sig.c: Import db-4.3.28 storage/bdb/cxx/cxx_db.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_dbc.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_dbt.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_env.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_except.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_lock.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_logc.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_mpool.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_txn.cpp: Import db-4.3.28 storage/bdb/db/crdel.src: Import db-4.3.28 storage/bdb/db/crdel_rec.c: Import db-4.3.28 storage/bdb/db/db.c: Import db-4.3.28 storage/bdb/db/db.src: Import db-4.3.28 storage/bdb/db/db_am.c: Import db-4.3.28 storage/bdb/db/db_cam.c: Import db-4.3.28 storage/bdb/db/db_conv.c: Import db-4.3.28 storage/bdb/db/db_dispatch.c: Import db-4.3.28 storage/bdb/db/db_dup.c: Import db-4.3.28 storage/bdb/db/db_iface.c: Import db-4.3.28 storage/bdb/db/db_join.c: Import db-4.3.28 storage/bdb/db/db_meta.c: Import db-4.3.28 storage/bdb/db/db_method.c: Import db-4.3.28 storage/bdb/db/db_open.c: Import db-4.3.28 storage/bdb/db/db_overflow.c: Import db-4.3.28 storage/bdb/db/db_pr.c: Import db-4.3.28 storage/bdb/db/db_rec.c: Import db-4.3.28 storage/bdb/db/db_reclaim.c: Import db-4.3.28 storage/bdb/db/db_remove.c: Import db-4.3.28 storage/bdb/db/db_rename.c: Import db-4.3.28 storage/bdb/db/db_ret.c: Import db-4.3.28 storage/bdb/db/db_truncate.c: Import db-4.3.28 storage/bdb/db/db_upg.c: Import db-4.3.28 storage/bdb/db/db_upg_opd.c: Import db-4.3.28 storage/bdb/db/db_vrfy.c: Import db-4.3.28 storage/bdb/db/db_vrfyutil.c: Import db-4.3.28 storage/bdb/db185/db185.c: Import db-4.3.28 storage/bdb/db185/db185_int.in: Import db-4.3.28 storage/bdb/db_archive/db_archive.c: Import db-4.3.28 storage/bdb/db_checkpoint/db_checkpoint.c: Import db-4.3.28 storage/bdb/db_deadlock/db_deadlock.c: Import db-4.3.28 storage/bdb/db_dump/db_dump.c: Import db-4.3.28 storage/bdb/db_dump185/db_dump185.c: Import db-4.3.28 storage/bdb/db_load/db_load.c: Import db-4.3.28 storage/bdb/db_printlog/README: Import db-4.3.28 storage/bdb/db_printlog/db_printlog.c: Import db-4.3.28 storage/bdb/db_printlog/dbname.awk: Import db-4.3.28 storage/bdb/db_printlog/rectype.awk: Import db-4.3.28 storage/bdb/db_printlog/status.awk: Import db-4.3.28 storage/bdb/db_recover/db_recover.c: Import db-4.3.28 storage/bdb/db_stat/db_stat.c: Import db-4.3.28 storage/bdb/db_upgrade/db_upgrade.c: Import db-4.3.28 storage/bdb/db_verify/db_verify.c: Import db-4.3.28 storage/bdb/dbinc/btree.h: Import db-4.3.28 storage/bdb/dbinc/crypto.h: Import db-4.3.28 storage/bdb/dbinc/cxx_int.h: Import db-4.3.28 storage/bdb/dbinc/db.in: Import db-4.3.28 storage/bdb/dbinc/db_185.in: Import db-4.3.28 storage/bdb/dbinc/db_am.h: Import db-4.3.28 storage/bdb/dbinc/db_cxx.in: Import db-4.3.28 storage/bdb/dbinc/db_dispatch.h: Import db-4.3.28 storage/bdb/dbinc/db_int.in: Import db-4.3.28 storage/bdb/dbinc/db_join.h: Import db-4.3.28 storage/bdb/dbinc/db_page.h: Import db-4.3.28 storage/bdb/dbinc/db_server_int.h: Import db-4.3.28 storage/bdb/dbinc/db_shash.h: Import db-4.3.28 storage/bdb/dbinc/db_swap.h: Import db-4.3.28 storage/bdb/dbinc/db_upgrade.h: Import db-4.3.28 storage/bdb/dbinc/db_verify.h: Import db-4.3.28 storage/bdb/dbinc/debug.h: Import db-4.3.28 storage/bdb/dbinc/fop.h: Import db-4.3.28 storage/bdb/dbinc/globals.h: Import db-4.3.28 storage/bdb/dbinc/hash.h: Import db-4.3.28 storage/bdb/dbinc/hmac.h: Import db-4.3.28 storage/bdb/dbinc/lock.h: Import db-4.3.28 storage/bdb/dbinc/log.h: Import db-4.3.28 storage/bdb/dbinc/mp.h: Import db-4.3.28 storage/bdb/dbinc/mutex.h: Import db-4.3.28 storage/bdb/dbinc/os.h: Import db-4.3.28 storage/bdb/dbinc/qam.h: Import db-4.3.28 storage/bdb/dbinc/queue.h: Import db-4.3.28 storage/bdb/dbinc/region.h: Import db-4.3.28 storage/bdb/dbinc/rep.h: Import db-4.3.28 storage/bdb/dbinc/shqueue.h: Import db-4.3.28 storage/bdb/dbinc/tcl_db.h: Import db-4.3.28 storage/bdb/dbinc/txn.h: Import db-4.3.28 storage/bdb/dbinc/xa.h: Import db-4.3.28 storage/bdb/dbm/dbm.c: Import db-4.3.28 storage/bdb/dbreg/dbreg.c: Import db-4.3.28 storage/bdb/dbreg/dbreg.src: Import db-4.3.28 storage/bdb/dbreg/dbreg_rec.c: Import db-4.3.28 storage/bdb/dbreg/dbreg_util.c: Import db-4.3.28 storage/bdb/dist/Makefile.in: Import db-4.3.28 storage/bdb/dist/RELEASE: Import db-4.3.28 storage/bdb/dist/aclocal/config.ac: Import db-4.3.28 storage/bdb/dist/aclocal/libtool.ac: Import db-4.3.28 storage/bdb/dist/aclocal/mutex.ac: Import db-4.3.28 storage/bdb/dist/aclocal/options.ac: Import db-4.3.28 storage/bdb/dist/aclocal/programs.ac: Import db-4.3.28 storage/bdb/dist/aclocal/sosuffix.ac: Import db-4.3.28 storage/bdb/dist/aclocal/tcl.ac: Import db-4.3.28 storage/bdb/dist/aclocal/types.ac: Import db-4.3.28 storage/bdb/dist/aclocal_java/ac_jni_include_dirs.ac: Import db-4.3.28 storage/bdb/dist/aclocal_java/ac_prog_java.ac: Import db-4.3.28 storage/bdb/dist/buildrel: Import db-4.3.28 storage/bdb/dist/configure.ac: Import db-4.3.28 storage/bdb/dist/gen_inc.awk: Import db-4.3.28 storage/bdb/dist/gen_rec.awk: Import db-4.3.28 storage/bdb/dist/gen_rpc.awk: Import db-4.3.28 storage/bdb/dist/ltmain.sh: Import db-4.3.28 storage/bdb/dist/pubdef.in: Import db-4.3.28 storage/bdb/dist/srcfiles.in: Import db-4.3.28 storage/bdb/dist/vx_2.0/BerkeleyDB.wpj: Import db-4.3.28 storage/bdb/dist/vx_2.0/wpj.in: Import db-4.3.28 storage/bdb/dist/vx_config.in: Import db-4.3.28 storage/bdb/dist/vx_setup/CONFIG.in: Import db-4.3.28 storage/bdb/dist/vx_setup/LICENSE.TXT: Import db-4.3.28 storage/bdb/dist/vx_setup/vx_allfile.in: Import db-4.3.28 storage/bdb/dist/vx_setup/vx_demofile.in: Import db-4.3.28 storage/bdb/dist/win_config.in: Import db-4.3.28 storage/bdb/dist/win_exports.in: Import db-4.3.28 storage/bdb/env/db_salloc.c: Import db-4.3.28 storage/bdb/env/db_shash.c: Import db-4.3.28 storage/bdb/env/env_file.c: Import db-4.3.28 storage/bdb/env/env_method.c: Import db-4.3.28 storage/bdb/env/env_open.c: Import db-4.3.28 storage/bdb/env/env_recover.c: Import db-4.3.28 storage/bdb/env/env_region.c: Import db-4.3.28 storage/bdb/fileops/fileops.src: Import db-4.3.28 storage/bdb/fileops/fop_basic.c: Import db-4.3.28 storage/bdb/fileops/fop_rec.c: Import db-4.3.28 storage/bdb/fileops/fop_util.c: Import db-4.3.28 storage/bdb/hash/hash.c: Import db-4.3.28 storage/bdb/hash/hash.src: Import db-4.3.28 storage/bdb/hash/hash_conv.c: Import db-4.3.28 storage/bdb/hash/hash_dup.c: Import db-4.3.28 storage/bdb/hash/hash_func.c: Import db-4.3.28 storage/bdb/hash/hash_meta.c: Import db-4.3.28 storage/bdb/hash/hash_method.c: Import db-4.3.28 storage/bdb/hash/hash_open.c: Import db-4.3.28 storage/bdb/hash/hash_page.c: Import db-4.3.28 storage/bdb/hash/hash_rec.c: Import db-4.3.28 storage/bdb/hash/hash_reclaim.c: Import db-4.3.28 storage/bdb/hash/hash_stat.c: Import db-4.3.28 storage/bdb/hash/hash_upgrade.c: Import db-4.3.28 storage/bdb/hash/hash_verify.c: Import db-4.3.28 storage/bdb/hmac/hmac.c: Import db-4.3.28 storage/bdb/hmac/sha1.c: Import db-4.3.28 storage/bdb/hsearch/hsearch.c: Import db-4.3.28 storage/bdb/lock/lock.c: Import db-4.3.28 storage/bdb/lock/lock_deadlock.c: Import db-4.3.28 storage/bdb/lock/lock_method.c: Import db-4.3.28 storage/bdb/lock/lock_region.c: Import db-4.3.28 storage/bdb/lock/lock_stat.c: Import db-4.3.28 storage/bdb/lock/lock_util.c: Import db-4.3.28 storage/bdb/log/log.c: Import db-4.3.28 storage/bdb/log/log_archive.c: Import db-4.3.28 storage/bdb/log/log_compare.c: Import db-4.3.28 storage/bdb/log/log_get.c: Import db-4.3.28 storage/bdb/log/log_method.c: Import db-4.3.28 storage/bdb/log/log_put.c: Import db-4.3.28 storage/bdb/mp/mp_alloc.c: Import db-4.3.28 storage/bdb/mp/mp_bh.c: Import db-4.3.28 storage/bdb/mp/mp_fget.c: Import db-4.3.28 storage/bdb/mp/mp_fopen.c: Import db-4.3.28 storage/bdb/mp/mp_fput.c: Import db-4.3.28 storage/bdb/mp/mp_fset.c: Import db-4.3.28 storage/bdb/mp/mp_method.c: Import db-4.3.28 storage/bdb/mp/mp_region.c: Import db-4.3.28 storage/bdb/mp/mp_register.c: Import db-4.3.28 storage/bdb/mp/mp_stat.c: Import db-4.3.28 storage/bdb/mp/mp_sync.c: Import db-4.3.28 storage/bdb/mp/mp_trickle.c: Import db-4.3.28 storage/bdb/mutex/mut_fcntl.c: Import db-4.3.28 storage/bdb/mutex/mut_pthread.c: Import db-4.3.28 storage/bdb/mutex/mut_tas.c: Import db-4.3.28 storage/bdb/mutex/mut_win32.c: Import db-4.3.28 storage/bdb/mutex/mutex.c: Import db-4.3.28 storage/bdb/mutex/tm.c: Import db-4.3.28 storage/bdb/mutex/uts4_cc.s: Import db-4.3.28 storage/bdb/os/os_abs.c: Import db-4.3.28 storage/bdb/os/os_alloc.c: Import db-4.3.28 storage/bdb/os/os_clock.c: Import db-4.3.28 storage/bdb/os/os_config.c: Import db-4.3.28 storage/bdb/os/os_dir.c: Import db-4.3.28 storage/bdb/os/os_errno.c: Import db-4.3.28 storage/bdb/os/os_fid.c: Import db-4.3.28 storage/bdb/os/os_fsync.c: Import db-4.3.28 storage/bdb/os/os_handle.c: Import db-4.3.28 storage/bdb/os/os_id.c: Import db-4.3.28 storage/bdb/os/os_map.c: Import db-4.3.28 storage/bdb/os/os_method.c: Import db-4.3.28 storage/bdb/os/os_oflags.c: Import db-4.3.28 storage/bdb/os/os_open.c: Import db-4.3.28 storage/bdb/os/os_region.c: Import db-4.3.28 storage/bdb/os/os_rename.c: Import db-4.3.28 storage/bdb/os/os_root.c: Import db-4.3.28 storage/bdb/os/os_rpath.c: Import db-4.3.28 storage/bdb/os/os_rw.c: Import db-4.3.28 storage/bdb/os/os_seek.c: Import db-4.3.28 storage/bdb/os/os_sleep.c: Import db-4.3.28 storage/bdb/os/os_spin.c: Import db-4.3.28 storage/bdb/os/os_stat.c: Import db-4.3.28 storage/bdb/os/os_tmpdir.c: Import db-4.3.28 storage/bdb/os/os_unlink.c: Import db-4.3.28 storage/bdb/os_vxworks/os_vx_abs.c: Import db-4.3.28 storage/bdb/os_vxworks/os_vx_config.c: Import db-4.3.28 storage/bdb/os_vxworks/os_vx_map.c: Import db-4.3.28 storage/bdb/os_win32/os_abs.c: Import db-4.3.28 storage/bdb/os_win32/os_clock.c: Import db-4.3.28 storage/bdb/os_win32/os_config.c: Import db-4.3.28 storage/bdb/os_win32/os_dir.c: Import db-4.3.28 storage/bdb/os_win32/os_errno.c: Import db-4.3.28 storage/bdb/os_win32/os_fid.c: Import db-4.3.28 storage/bdb/os_win32/os_fsync.c: Import db-4.3.28 storage/bdb/os_win32/os_handle.c: Import db-4.3.28 storage/bdb/os_win32/os_map.c: Import db-4.3.28 storage/bdb/os_win32/os_open.c: Import db-4.3.28 storage/bdb/os_win32/os_rename.c: Import db-4.3.28 storage/bdb/os_win32/os_rw.c: Import db-4.3.28 storage/bdb/os_win32/os_seek.c: Import db-4.3.28 storage/bdb/os_win32/os_sleep.c: Import db-4.3.28 storage/bdb/os_win32/os_spin.c: Import db-4.3.28 storage/bdb/os_win32/os_stat.c: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/BerkeleyDB.pm: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/BerkeleyDB.pod.P: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/BerkeleyDB.pod: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/BerkeleyDB.xs: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/Changes: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/MANIFEST: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/Makefile.PL: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/README: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/config.in: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/constants.h: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/mkconsts: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/patches/5.004: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/ppport.h: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/scan: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/btree.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/destroy.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/env.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/filter.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/hash.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/join.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/mldbm.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/queue.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/recno.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/strict.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/subdb.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/txn.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/util.pm: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/typemap: Import db-4.3.28 storage/bdb/perl/DB_File/Changes: Import db-4.3.28 storage/bdb/perl/DB_File/DB_File.pm: Import db-4.3.28 storage/bdb/perl/DB_File/DB_File.xs: Import db-4.3.28 storage/bdb/perl/DB_File/MANIFEST: Import db-4.3.28 storage/bdb/perl/DB_File/Makefile.PL: Import db-4.3.28 storage/bdb/perl/DB_File/README: Import db-4.3.28 storage/bdb/perl/DB_File/dbinfo: Import db-4.3.28 storage/bdb/perl/DB_File/patches/5.004: Import db-4.3.28 storage/bdb/perl/DB_File/ppport.h: Import db-4.3.28 storage/bdb/perl/DB_File/t/db-btree.t: Import db-4.3.28 storage/bdb/perl/DB_File/t/db-hash.t: Import db-4.3.28 storage/bdb/perl/DB_File/t/db-recno.t: Import db-4.3.28 storage/bdb/perl/DB_File/typemap: Import db-4.3.28 storage/bdb/qam/qam.c: Import db-4.3.28 storage/bdb/qam/qam.src: Import db-4.3.28 storage/bdb/qam/qam_conv.c: Import db-4.3.28 storage/bdb/qam/qam_files.c: Import db-4.3.28 storage/bdb/qam/qam_method.c: Import db-4.3.28 storage/bdb/qam/qam_open.c: Import db-4.3.28 storage/bdb/qam/qam_rec.c: Import db-4.3.28 storage/bdb/qam/qam_stat.c: Import db-4.3.28 storage/bdb/qam/qam_upgrade.c: Import db-4.3.28 storage/bdb/qam/qam_verify.c: Import db-4.3.28 storage/bdb/rep/rep_method.c: Import db-4.3.28 storage/bdb/rep/rep_record.c: Import db-4.3.28 storage/bdb/rep/rep_region.c: Import db-4.3.28 storage/bdb/rep/rep_util.c: Import db-4.3.28 storage/bdb/rpc_client/client.c: Import db-4.3.28 storage/bdb/rpc_client/gen_client_ret.c: Import db-4.3.28 storage/bdb/rpc_server/c/db_server_util.c: Import db-4.3.28 storage/bdb/rpc_server/cxx/db_server_cxxproc.cpp: Import db-4.3.28 storage/bdb/rpc_server/cxx/db_server_cxxutil.cpp: Import db-4.3.28 storage/bdb/rpc_server/java/FreeList.java: Import db-4.3.28 storage/bdb/rpc_server/java/LocalIterator.java: Import db-4.3.28 storage/bdb/rpc_server/java/README: Import db-4.3.28 storage/bdb/rpc_server/java/RpcDb.java: Import db-4.3.28 storage/bdb/rpc_server/java/RpcDbEnv.java: Import db-4.3.28 storage/bdb/rpc_server/java/RpcDbTxn.java: Import db-4.3.28 storage/bdb/rpc_server/java/RpcDbc.java: Import db-4.3.28 storage/bdb/rpc_server/java/Timer.java: Import db-4.3.28 storage/bdb/rpc_server/java/gen/__db_open_reply.java: Import db-4.3.28 storage/bdb/rpc_server/java/gen/__db_stat_msg.java: Import db-4.3.28 storage/bdb/rpc_server/java/gen/db_server.java: Import db-4.3.28 storage/bdb/rpc_server/java/s_jrpcgen: Import db-4.3.28 storage/bdb/rpc_server/rpc.src: Import db-4.3.28 storage/bdb/tcl/docs/db.html: Import db-4.3.28 storage/bdb/tcl/docs/env.html: Import db-4.3.28 storage/bdb/tcl/docs/historic.html: Import db-4.3.28 storage/bdb/tcl/docs/index.html: Import db-4.3.28 storage/bdb/tcl/docs/library.html: Import db-4.3.28 storage/bdb/tcl/docs/lock.html: Import db-4.3.28 storage/bdb/tcl/docs/log.html: Import db-4.3.28 storage/bdb/tcl/docs/mpool.html: Import db-4.3.28 storage/bdb/tcl/docs/rep.html: Import db-4.3.28 storage/bdb/tcl/docs/test.html: Import db-4.3.28 storage/bdb/tcl/docs/txn.html: Import db-4.3.28 storage/bdb/tcl/tcl_compat.c: Import db-4.3.28 storage/bdb/tcl/tcl_db.c: Import db-4.3.28 storage/bdb/tcl/tcl_db_pkg.c: Import db-4.3.28 storage/bdb/tcl/tcl_dbcursor.c: Import db-4.3.28 storage/bdb/tcl/tcl_env.c: Import db-4.3.28 storage/bdb/tcl/tcl_internal.c: Import db-4.3.28 storage/bdb/tcl/tcl_lock.c: Import db-4.3.28 storage/bdb/tcl/tcl_log.c: Import db-4.3.28 storage/bdb/tcl/tcl_mp.c: Import db-4.3.28 storage/bdb/tcl/tcl_rep.c: Import db-4.3.28 storage/bdb/tcl/tcl_txn.c: Import db-4.3.28 storage/bdb/tcl/tcl_util.c: Import db-4.3.28 storage/bdb/test/archive.tcl: Import db-4.3.28 storage/bdb/test/bigfile001.tcl: Import db-4.3.28 storage/bdb/test/bigfile002.tcl: Import db-4.3.28 storage/bdb/test/byteorder.tcl: Import db-4.3.28 storage/bdb/test/conscript.tcl: Import db-4.3.28 storage/bdb/test/dbm.tcl: Import db-4.3.28 storage/bdb/test/dbscript.tcl: Import db-4.3.28 storage/bdb/test/ddoyscript.tcl: Import db-4.3.28 storage/bdb/test/ddscript.tcl: Import db-4.3.28 storage/bdb/test/dead001.tcl: Import db-4.3.28 storage/bdb/test/dead002.tcl: Import db-4.3.28 storage/bdb/test/dead003.tcl: Import db-4.3.28 storage/bdb/test/dead004.tcl: Import db-4.3.28 storage/bdb/test/dead005.tcl: Import db-4.3.28 storage/bdb/test/dead006.tcl: Import db-4.3.28 storage/bdb/test/dead007.tcl: Import db-4.3.28 storage/bdb/test/env001.tcl: Import db-4.3.28 storage/bdb/test/env002.tcl: Import db-4.3.28 storage/bdb/test/env003.tcl: Import db-4.3.28 storage/bdb/test/env004.tcl: Import db-4.3.28 storage/bdb/test/env005.tcl: Import db-4.3.28 storage/bdb/test/env006.tcl: Import db-4.3.28 storage/bdb/test/env007.tcl: Import db-4.3.28 storage/bdb/test/env008.tcl: Import db-4.3.28 storage/bdb/test/env009.tcl: Import db-4.3.28 storage/bdb/test/env010.tcl: Import db-4.3.28 storage/bdb/test/env011.tcl: Import db-4.3.28 storage/bdb/test/hsearch.tcl: Import db-4.3.28 storage/bdb/test/join.tcl: Import db-4.3.28 storage/bdb/test/lock001.tcl: Import db-4.3.28 storage/bdb/test/lock002.tcl: Import db-4.3.28 storage/bdb/test/lock003.tcl: Import db-4.3.28 storage/bdb/test/lock004.tcl: Import db-4.3.28 storage/bdb/test/lock005.tcl: Import db-4.3.28 storage/bdb/test/lockscript.tcl: Import db-4.3.28 storage/bdb/test/log001.tcl: Import db-4.3.28 storage/bdb/test/log002.tcl: Import db-4.3.28 storage/bdb/test/log003.tcl: Import db-4.3.28 storage/bdb/test/log004.tcl: Import db-4.3.28 storage/bdb/test/log005.tcl: Import db-4.3.28 storage/bdb/test/logtrack.tcl: Import db-4.3.28 storage/bdb/test/mdbscript.tcl: Import db-4.3.28 storage/bdb/test/memp001.tcl: Import db-4.3.28 storage/bdb/test/memp002.tcl: Import db-4.3.28 storage/bdb/test/memp003.tcl: Import db-4.3.28 storage/bdb/test/mpoolscript.tcl: Import db-4.3.28 storage/bdb/test/mutex001.tcl: Import db-4.3.28 storage/bdb/test/mutex002.tcl: Import db-4.3.28 storage/bdb/test/mutex003.tcl: Import db-4.3.28 storage/bdb/test/mutexscript.tcl: Import db-4.3.28 storage/bdb/test/ndbm.tcl: Import db-4.3.28 storage/bdb/test/parallel.tcl: Import db-4.3.28 storage/bdb/test/recd001.tcl: Import db-4.3.28 storage/bdb/test/recd002.tcl: Import db-4.3.28 storage/bdb/test/recd003.tcl: Import db-4.3.28 storage/bdb/test/recd004.tcl: Import db-4.3.28 storage/bdb/test/recd005.tcl: Import db-4.3.28 storage/bdb/test/recd006.tcl: Import db-4.3.28 storage/bdb/test/recd007.tcl: Import db-4.3.28 storage/bdb/test/recd008.tcl: Import db-4.3.28 storage/bdb/test/recd009.tcl: Import db-4.3.28 storage/bdb/test/recd010.tcl: Import db-4.3.28 storage/bdb/test/recd011.tcl: Import db-4.3.28 storage/bdb/test/recd012.tcl: Import db-4.3.28 storage/bdb/test/recd013.tcl: Import db-4.3.28 storage/bdb/test/recd014.tcl: Import db-4.3.28 storage/bdb/test/recd015.tcl: Import db-4.3.28 storage/bdb/test/recd016.tcl: Import db-4.3.28 storage/bdb/test/recd017.tcl: Import db-4.3.28 storage/bdb/test/recd018.tcl: Import db-4.3.28 storage/bdb/test/recd019.tcl: Import db-4.3.28 storage/bdb/test/recd020.tcl: Import db-4.3.28 storage/bdb/test/recd15scr.tcl: Import db-4.3.28 storage/bdb/test/recdscript.tcl: Import db-4.3.28 storage/bdb/test/rep001.tcl: Import db-4.3.28 storage/bdb/test/rep002.tcl: Import db-4.3.28 storage/bdb/test/rep003.tcl: Import db-4.3.28 storage/bdb/test/rep005.tcl: Import db-4.3.28 storage/bdb/test/reputils.tcl: Import db-4.3.28 storage/bdb/test/rpc001.tcl: Import db-4.3.28 storage/bdb/test/rpc002.tcl: Import db-4.3.28 storage/bdb/test/rpc003.tcl: Import db-4.3.28 storage/bdb/test/rpc004.tcl: Import db-4.3.28 storage/bdb/test/rpc005.tcl: Import db-4.3.28 storage/bdb/test/rsrc001.tcl: Import db-4.3.28 storage/bdb/test/rsrc002.tcl: Import db-4.3.28 storage/bdb/test/rsrc003.tcl: Import db-4.3.28 storage/bdb/test/rsrc004.tcl: Import db-4.3.28 storage/bdb/test/scr001/chk.code: Import db-4.3.28 storage/bdb/test/scr003/chk.define: Import db-4.3.28 storage/bdb/test/scr004/chk.javafiles: Import db-4.3.28 storage/bdb/test/scr005/chk.nl: Import db-4.3.28 storage/bdb/test/scr006/chk.offt: Import db-4.3.28 storage/bdb/test/scr007/chk.proto: Import db-4.3.28 storage/bdb/test/scr008/chk.pubdef: Import db-4.3.28 storage/bdb/test/scr009/chk.srcfiles: Import db-4.3.28 storage/bdb/test/scr010/chk.str: Import db-4.3.28 storage/bdb/test/scr010/spell.ok: Import db-4.3.28 storage/bdb/test/scr011/chk.tags: Import db-4.3.28 storage/bdb/test/scr012/chk.vx_code: Import db-4.3.28 storage/bdb/test/scr013/chk.stats: Import db-4.3.28 storage/bdb/test/scr015/TestConstruct01.cpp: Import db-4.3.28 storage/bdb/test/scr015/TestConstruct01.testerr: Import db-4.3.28 storage/bdb/test/scr015/TestGetSetMethods.cpp: Import db-4.3.28 storage/bdb/test/scr015/TestKeyRange.cpp: Import db-4.3.28 storage/bdb/test/scr015/TestLogc.cpp: Import db-4.3.28 storage/bdb/test/scr015/TestSimpleAccess.cpp: Import db-4.3.28 storage/bdb/test/scr015/TestTruncate.cpp: Import db-4.3.28 storage/bdb/test/scr015/chk.cxxtests: Import db-4.3.28 storage/bdb/test/scr016/CallbackTest.java: Import db-4.3.28 storage/bdb/test/scr016/CallbackTest.testout: Import db-4.3.28 storage/bdb/test/scr016/TestAppendRecno.java: Import db-4.3.28 storage/bdb/test/scr016/TestAssociate.java: Import db-4.3.28 storage/bdb/test/scr016/TestClosedDb.java: Import db-4.3.28 storage/bdb/test/scr016/TestClosedDb.testout: Import db-4.3.28 storage/bdb/test/scr016/TestConstruct01.java: Import db-4.3.28 storage/bdb/test/scr016/TestConstruct01.testout: Import db-4.3.28 storage/bdb/test/scr016/TestConstruct02.java: Import db-4.3.28 storage/bdb/test/scr016/TestDbtFlags.java: Import db-4.3.28 storage/bdb/test/scr016/TestGetSetMethods.java: Import db-4.3.28 storage/bdb/test/scr016/TestKeyRange.java: Import db-4.3.28 storage/bdb/test/scr016/TestLockVec.java: Import db-4.3.28 storage/bdb/test/scr016/TestLogc.java: Import db-4.3.28 storage/bdb/test/scr016/TestOpenEmpty.java: Import db-4.3.28 storage/bdb/test/scr016/TestOpenEmpty.testerr: Import db-4.3.28 storage/bdb/test/scr016/TestReplication.java: Import db-4.3.28 storage/bdb/test/scr016/TestRpcServer.java: Import db-4.3.28 storage/bdb/test/scr016/TestSameDbt.java: Import db-4.3.28 storage/bdb/test/scr016/TestSimpleAccess.java: Import db-4.3.28 storage/bdb/test/scr016/TestStat.java: Import db-4.3.28 storage/bdb/test/scr016/TestStat.testout: Import db-4.3.28 storage/bdb/test/scr016/TestTruncate.java: Import db-4.3.28 storage/bdb/test/scr016/TestTruncate.testout: Import db-4.3.28 storage/bdb/test/scr016/TestUtil.java: Import db-4.3.28 storage/bdb/test/scr016/TestXAServlet.java: Import db-4.3.28 storage/bdb/test/scr016/chk.javatests: Import db-4.3.28 storage/bdb/test/scr016/ignore: Import db-4.3.28 storage/bdb/test/scr016/testone: Import db-4.3.28 storage/bdb/test/scr017/chk.db185: Import db-4.3.28 storage/bdb/test/scr019/chk.include: Import db-4.3.28 storage/bdb/test/scr020/chk.inc: Import db-4.3.28 storage/bdb/test/scr021/chk.flags: Import db-4.3.28 storage/bdb/test/scr022/chk.rr: Import db-4.3.28 storage/bdb/test/sdb001.tcl: Import db-4.3.28 storage/bdb/test/sdb002.tcl: Import db-4.3.28 storage/bdb/test/sdb003.tcl: Import db-4.3.28 storage/bdb/test/sdb004.tcl: Import db-4.3.28 storage/bdb/test/sdb005.tcl: Import db-4.3.28 storage/bdb/test/sdb006.tcl: Import db-4.3.28 storage/bdb/test/sdb007.tcl: Import db-4.3.28 storage/bdb/test/sdb008.tcl: Import db-4.3.28 storage/bdb/test/sdb009.tcl: Import db-4.3.28 storage/bdb/test/sdb010.tcl: Import db-4.3.28 storage/bdb/test/sdb011.tcl: Import db-4.3.28 storage/bdb/test/sdb012.tcl: Import db-4.3.28 storage/bdb/test/sdbscript.tcl: Import db-4.3.28 storage/bdb/test/sdbtest001.tcl: Import db-4.3.28 storage/bdb/test/sdbtest002.tcl: Import db-4.3.28 storage/bdb/test/sdbutils.tcl: Import db-4.3.28 storage/bdb/test/sec001.tcl: Import db-4.3.28 storage/bdb/test/sec002.tcl: Import db-4.3.28 storage/bdb/test/shelltest.tcl: Import db-4.3.28 storage/bdb/test/si001.tcl: Import db-4.3.28 storage/bdb/test/si002.tcl: Import db-4.3.28 storage/bdb/test/si003.tcl: Import db-4.3.28 storage/bdb/test/si004.tcl: Import db-4.3.28 storage/bdb/test/si005.tcl: Import db-4.3.28 storage/bdb/test/sysscript.tcl: Import db-4.3.28 storage/bdb/test/test.tcl: Import db-4.3.28 storage/bdb/test/test001.tcl: Import db-4.3.28 storage/bdb/test/test002.tcl: Import db-4.3.28 storage/bdb/test/test003.tcl: Import db-4.3.28 storage/bdb/test/test004.tcl: Import db-4.3.28 storage/bdb/test/test005.tcl: Import db-4.3.28 storage/bdb/test/test006.tcl: Import db-4.3.28 storage/bdb/test/test007.tcl: Import db-4.3.28 storage/bdb/test/test008.tcl: Import db-4.3.28 storage/bdb/test/test009.tcl: Import db-4.3.28 storage/bdb/test/test010.tcl: Import db-4.3.28 storage/bdb/test/test011.tcl: Import db-4.3.28 storage/bdb/test/test012.tcl: Import db-4.3.28 storage/bdb/test/test013.tcl: Import db-4.3.28 storage/bdb/test/test014.tcl: Import db-4.3.28 storage/bdb/test/test015.tcl: Import db-4.3.28 storage/bdb/test/test016.tcl: Import db-4.3.28 storage/bdb/test/test017.tcl: Import db-4.3.28 storage/bdb/test/test018.tcl: Import db-4.3.28 storage/bdb/test/test019.tcl: Import db-4.3.28 storage/bdb/test/test020.tcl: Import db-4.3.28 storage/bdb/test/test021.tcl: Import db-4.3.28 storage/bdb/test/test022.tcl: Import db-4.3.28 storage/bdb/test/test023.tcl: Import db-4.3.28 storage/bdb/test/test024.tcl: Import db-4.3.28 storage/bdb/test/test025.tcl: Import db-4.3.28 storage/bdb/test/test026.tcl: Import db-4.3.28 storage/bdb/test/test027.tcl: Import db-4.3.28 storage/bdb/test/test028.tcl: Import db-4.3.28 storage/bdb/test/test029.tcl: Import db-4.3.28 storage/bdb/test/test030.tcl: Import db-4.3.28 storage/bdb/test/test031.tcl: Import db-4.3.28 storage/bdb/test/test032.tcl: Import db-4.3.28 storage/bdb/test/test033.tcl: Import db-4.3.28 storage/bdb/test/test034.tcl: Import db-4.3.28 storage/bdb/test/test035.tcl: Import db-4.3.28 storage/bdb/test/test036.tcl: Import db-4.3.28 storage/bdb/test/test037.tcl: Import db-4.3.28 storage/bdb/test/test038.tcl: Import db-4.3.28 storage/bdb/test/test039.tcl: Import db-4.3.28 storage/bdb/test/test040.tcl: Import db-4.3.28 storage/bdb/test/test041.tcl: Import db-4.3.28 storage/bdb/test/test042.tcl: Import db-4.3.28 storage/bdb/test/test043.tcl: Import db-4.3.28 storage/bdb/test/test044.tcl: Import db-4.3.28 storage/bdb/test/test045.tcl: Import db-4.3.28 storage/bdb/test/test046.tcl: Import db-4.3.28 storage/bdb/test/test047.tcl: Import db-4.3.28 storage/bdb/test/test048.tcl: Import db-4.3.28 storage/bdb/test/test049.tcl: Import db-4.3.28 storage/bdb/test/test050.tcl: Import db-4.3.28 storage/bdb/test/test051.tcl: Import db-4.3.28 storage/bdb/test/test052.tcl: Import db-4.3.28 storage/bdb/test/test053.tcl: Import db-4.3.28 storage/bdb/test/test054.tcl: Import db-4.3.28 storage/bdb/test/test055.tcl: Import db-4.3.28 storage/bdb/test/test056.tcl: Import db-4.3.28 storage/bdb/test/test057.tcl: Import db-4.3.28 storage/bdb/test/test058.tcl: Import db-4.3.28 storage/bdb/test/test059.tcl: Import db-4.3.28 storage/bdb/test/test060.tcl: Import db-4.3.28 storage/bdb/test/test061.tcl: Import db-4.3.28 storage/bdb/test/test062.tcl: Import db-4.3.28 storage/bdb/test/test063.tcl: Import db-4.3.28 storage/bdb/test/test064.tcl: Import db-4.3.28 storage/bdb/test/test065.tcl: Import db-4.3.28 storage/bdb/test/test066.tcl: Import db-4.3.28 storage/bdb/test/test067.tcl: Import db-4.3.28 storage/bdb/test/test068.tcl: Import db-4.3.28 storage/bdb/test/test069.tcl: Import db-4.3.28 storage/bdb/test/test070.tcl: Import db-4.3.28 storage/bdb/test/test071.tcl: Import db-4.3.28 storage/bdb/test/test072.tcl: Import db-4.3.28 storage/bdb/test/test073.tcl: Import db-4.3.28 storage/bdb/test/test074.tcl: Import db-4.3.28 storage/bdb/test/test076.tcl: Import db-4.3.28 storage/bdb/test/test077.tcl: Import db-4.3.28 storage/bdb/test/test078.tcl: Import db-4.3.28 storage/bdb/test/test079.tcl: Import db-4.3.28 storage/bdb/test/test081.tcl: Import db-4.3.28 storage/bdb/test/test082.tcl: Import db-4.3.28 storage/bdb/test/test083.tcl: Import db-4.3.28 storage/bdb/test/test084.tcl: Import db-4.3.28 storage/bdb/test/test085.tcl: Import db-4.3.28 storage/bdb/test/test086.tcl: Import db-4.3.28 storage/bdb/test/test087.tcl: Import db-4.3.28 storage/bdb/test/test088.tcl: Import db-4.3.28 storage/bdb/test/test089.tcl: Import db-4.3.28 storage/bdb/test/test090.tcl: Import db-4.3.28 storage/bdb/test/test091.tcl: Import db-4.3.28 storage/bdb/test/test092.tcl: Import db-4.3.28 storage/bdb/test/test093.tcl: Import db-4.3.28 storage/bdb/test/test094.tcl: Import db-4.3.28 storage/bdb/test/test095.tcl: Import db-4.3.28 storage/bdb/test/test096.tcl: Import db-4.3.28 storage/bdb/test/test097.tcl: Import db-4.3.28 storage/bdb/test/test098.tcl: Import db-4.3.28 storage/bdb/test/test099.tcl: Import db-4.3.28 storage/bdb/test/test100.tcl: Import db-4.3.28 storage/bdb/test/test101.tcl: Import db-4.3.28 storage/bdb/test/testparams.tcl: Import db-4.3.28 storage/bdb/test/testutils.tcl: Import db-4.3.28 storage/bdb/test/txn001.tcl: Import db-4.3.28 storage/bdb/test/txn002.tcl: Import db-4.3.28 storage/bdb/test/txn003.tcl: Import db-4.3.28 storage/bdb/test/txn004.tcl: Import db-4.3.28 storage/bdb/test/txn005.tcl: Import db-4.3.28 storage/bdb/test/txn006.tcl: Import db-4.3.28 storage/bdb/test/txn007.tcl: Import db-4.3.28 storage/bdb/test/txn008.tcl: Import db-4.3.28 storage/bdb/test/txn009.tcl: Import db-4.3.28 storage/bdb/test/txnscript.tcl: Import db-4.3.28 storage/bdb/test/update.tcl: Import db-4.3.28 storage/bdb/test/upgrade.tcl: Import db-4.3.28 storage/bdb/test/wrap.tcl: Import db-4.3.28 storage/bdb/txn/txn.c: Import db-4.3.28 storage/bdb/txn/txn.src: Import db-4.3.28 storage/bdb/txn/txn_method.c: Import db-4.3.28 storage/bdb/txn/txn_rec.c: Import db-4.3.28 storage/bdb/txn/txn_recover.c: Import db-4.3.28 storage/bdb/txn/txn_region.c: Import db-4.3.28 storage/bdb/txn/txn_stat.c: Import db-4.3.28 storage/bdb/txn/txn_util.c: Import db-4.3.28 storage/bdb/xa/xa.c: Import db-4.3.28 storage/bdb/xa/xa_db.c: Import db-4.3.28 storage/bdb/xa/xa_map.c: Import db-4.3.28 storage/bdb/clib/strtol.c: Import db-4.3.28 storage/bdb/clib/strtoul.c: Import db-4.3.28 storage/bdb/common/crypto_stub.c: Import db-4.3.28 storage/bdb/crypto/aes_method.c: Import db-4.3.28 storage/bdb/crypto/crypto.c: Import db-4.3.28 storage/bdb/crypto/crypto.html: Import db-4.3.28 storage/bdb/crypto/mersenne/mt19937db.c: Import db-4.3.28 storage/bdb/crypto/rijndael/rijndael-alg-fst.c: Import db-4.3.28 storage/bdb/crypto/rijndael/rijndael-alg-fst.h: Import db-4.3.28 storage/bdb/crypto/rijndael/rijndael-api-fst.c: Import db-4.3.28 storage/bdb/crypto/rijndael/rijndael-api-fst.h: Import db-4.3.28 storage/bdb/cxx/cxx_multi.cpp: Import db-4.3.28 storage/bdb/cxx/cxx_seq.cpp: Import db-4.3.28 storage/bdb/db/db_ovfl_vrfy.c: Import db-4.3.28 storage/bdb/db/db_setid.c: Import db-4.3.28 storage/bdb/db/db_setlsn.c: Import db-4.3.28 storage/bdb/db/db_stati.c: Import db-4.3.28 storage/bdb/db/db_vrfy_stub.c: Import db-4.3.28 storage/bdb/db_stat/dd.sh: Import db-4.3.28 storage/bdb/dbreg/dbreg_stat.c: Import db-4.3.28 storage/bdb/dist/aclocal/rpc.ac: Import db-4.3.28 storage/bdb/dist/aclocal/sequence.ac: Import db-4.3.28 storage/bdb/dist/config.hin: Import db-4.3.28 storage/bdb/dist/s_java_const: Import db-4.3.28 storage/bdb/dist/s_java_stat: Import db-4.3.28 storage/bdb/dist/s_java_swig: Import db-4.3.28 storage/bdb/dist/s_je2db: Import db-4.3.28 storage/bdb/dist/s_winmsi: Import db-4.3.28 storage/bdb/dist/template/db_server_proc: Import db-4.3.28 storage/bdb/dist/template/gen_client_ret: Import db-4.3.28 storage/bdb/dist/template/rec_btree: Import db-4.3.28 storage/bdb/dist/template/rec_crdel: Import db-4.3.28 storage/bdb/dist/template/rec_dbreg: Import db-4.3.28 storage/bdb/dist/template/rec_db: Import db-4.3.28 storage/bdb/dist/template/rec_fileops: Import db-4.3.28 storage/bdb/dist/template/rec_hash: Import db-4.3.28 storage/bdb/dist/template/rec_qam: Import db-4.3.28 storage/bdb/dist/template/rec_rep: Import db-4.3.28 storage/bdb/dist/template/rec_txn: Import db-4.3.28 storage/bdb/dist/vx_2.0/BerkeleyDBsmall.wpj: Import db-4.3.28 storage/bdb/dist/vx_2.2/BerkeleyDB.wpj: Import db-4.3.28 storage/bdb/dist/vx_2.2/BerkeleyDBsmall.wpj: Import db-4.3.28 storage/bdb/dist/vx_2.2/wpj.in: Import db-4.3.28 storage/bdb/dist/win_db.in: Import db-4.3.28 storage/bdb/dist/winmsi/dbcorewix.in: Import db-4.3.28 storage/bdb/dist/winmsi/dbvarsbat.in: Import db-4.3.28 storage/bdb/dist/winmsi/dbwix.m4: Import db-4.3.28 storage/bdb/dist/winmsi/environment.in: Import db-4.3.28 storage/bdb/dist/winmsi/features.in: Import db-4.3.28 storage/bdb/dist/winmsi/files.in: Import db-4.3.28 storage/bdb/dist/winmsi/images/caticon.ibd: Import db-4.3.28 storage/bdb/dist/winmsi/images/foldernew.ibd: Import db-4.3.28 storage/bdb/dist/winmsi/images/folderup.ibd: Import db-4.3.28 storage/bdb/dist/winmsi/images/sleepycat.jpg: Import db-4.3.28 storage/bdb/dist/winmsi/images/topstripe.ibd: Import db-4.3.28 storage/bdb/dist/winmsi/images/webicon.ico: Import db-4.3.28 storage/bdb/dist/winmsi/links.in: Import db-4.3.28 storage/bdb/dist/winmsi/s_winmsi.fcn: Import db-4.3.28 storage/bdb/dist/winmsi/winbuild.bat: Import db-4.3.28 storage/bdb/env/env_stat.c: Import db-4.3.28 storage/bdb/hash/hash_stub.c: Import db-4.3.28 storage/bdb/lock/lock_id.c: Import db-4.3.28 storage/bdb/lock/lock_list.c: Import db-4.3.28 storage/bdb/lock/lock_timer.c: Import db-4.3.28 storage/bdb/log/log_stat.c: Import db-4.3.28 storage/bdb/mp/mp_fmethod.c: Import db-4.3.28 storage/bdb/os/os_truncate.c: Import db-4.3.28 storage/bdb/os_win32/os_truncate.c: Import db-4.3.28 storage/bdb/os_win32/os_unlink.c: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/META.yml: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/cds.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/encrypt.t: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/t/pod.t: Import db-4.3.28 storage/bdb/perl/DB_File/META.yml: Import db-4.3.28 storage/bdb/qam/qam_stub.c: Import db-4.3.28 storage/bdb/rep/rep.src: Import db-4.3.28 storage/bdb/rep/rep_backup.c: Import db-4.3.28 storage/bdb/rep/rep_stat.c: Import db-4.3.28 storage/bdb/rep/rep_stub.c: Import db-4.3.28 storage/bdb/rpc_client/gen_client.c: Import db-4.3.28 storage/bdb/rpc_server/c/db_server_proc.c: Import db-4.3.28 storage/bdb/rpc_server/c/gen_db_server.c: Import db-4.3.28 storage/bdb/rpc_server/db_server.x: Import db-4.3.28 storage/bdb/sequence/seq_stat.c: Import db-4.3.28 storage/bdb/sequence/sequence.c: Import db-4.3.28 storage/bdb/tcl/tcl_seq.c: Import db-4.3.28 storage/bdb/dist/config.guess: Import db-4.3.28 storage/bdb/dist/config.sub: Import db-4.3.28 storage/bdb/dist/s_all: Import db-4.3.28 storage/bdb/dist/s_config: Import db-4.3.28 storage/bdb/dist/s_crypto: Import db-4.3.28 storage/bdb/dist/s_include: Import db-4.3.28 storage/bdb/dist/s_java: Import db-4.3.28 storage/bdb/dist/s_perm: Import db-4.3.28 storage/bdb/dist/s_readme: Import db-4.3.28 storage/bdb/dist/s_recover: Import db-4.3.28 storage/bdb/dist/s_rpc: Import db-4.3.28 storage/bdb/dist/s_symlink: Import db-4.3.28 storage/bdb/dist/s_tags: Import db-4.3.28 storage/bdb/dist/s_test: Import db-4.3.28 storage/bdb/dist/s_vxworks: Import db-4.3.28 storage/bdb/dist/s_win32_dsp: Import db-4.3.28 storage/bdb/dist/s_win32: Import db-4.3.28 storage/bdb/perl/BerkeleyDB/dbinfo: Import db-4.3.28
931 lines
26 KiB
C
931 lines
26 KiB
C
/*
|
|
* See the file LICENSE for redistribution information.
|
|
*
|
|
* Copyright (c) 1998-2004
|
|
* Sleepycat Software. All rights reserved.
|
|
*
|
|
* $Id: db_join.c,v 11.75 2004/09/22 03:30:23 bostic Exp $
|
|
*/
|
|
|
|
#include "db_config.h"
|
|
|
|
#ifndef NO_SYSTEM_INCLUDES
|
|
#include <sys/types.h>
|
|
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#endif
|
|
|
|
#include "db_int.h"
|
|
#include "dbinc/db_page.h"
|
|
#include "dbinc/db_join.h"
|
|
#include "dbinc/btree.h"
|
|
|
|
static int __db_join_close_pp __P((DBC *));
|
|
static int __db_join_cmp __P((const void *, const void *));
|
|
static int __db_join_del __P((DBC *, u_int32_t));
|
|
static int __db_join_get __P((DBC *, DBT *, DBT *, u_int32_t));
|
|
static int __db_join_get_pp __P((DBC *, DBT *, DBT *, u_int32_t));
|
|
static int __db_join_getnext __P((DBC *, DBT *, DBT *, u_int32_t, u_int32_t));
|
|
static int __db_join_primget __P((DB *,
|
|
DB_TXN *, u_int32_t, DBT *, DBT *, u_int32_t));
|
|
static int __db_join_put __P((DBC *, DBT *, DBT *, u_int32_t));
|
|
|
|
/*
|
|
* Check to see if the Nth secondary cursor of join cursor jc is pointing
|
|
* to a sorted duplicate set.
|
|
*/
|
|
#define SORTED_SET(jc, n) ((jc)->j_curslist[(n)]->dbp->dup_compare != NULL)
|
|
|
|
/*
|
|
* This is the duplicate-assisted join functionality. Right now we're
|
|
* going to write it such that we return one item at a time, although
|
|
* I think we may need to optimize it to return them all at once.
|
|
* It should be easier to get it working this way, and I believe that
|
|
* changing it should be fairly straightforward.
|
|
*
|
|
* We optimize the join by sorting cursors from smallest to largest
|
|
* cardinality. In most cases, this is indeed optimal. However, if
|
|
* a cursor with large cardinality has very few data in common with the
|
|
* first cursor, it is possible that the join will be made faster by
|
|
* putting it earlier in the cursor list. Since we have no way to detect
|
|
* cases like this, we simply provide a flag, DB_JOIN_NOSORT, which retains
|
|
* the sort order specified by the caller, who may know more about the
|
|
* structure of the data.
|
|
*
|
|
* The first cursor moves sequentially through the duplicate set while
|
|
* the others search explicitly for the duplicate in question.
|
|
*
|
|
*/
|
|
|
|
/*
|
|
* __db_join --
|
|
* This is the interface to the duplicate-assisted join functionality.
|
|
* In the same way that cursors mark a position in a database, a cursor
|
|
* can mark a position in a join. While most cursors are created by the
|
|
* cursor method of a DB, join cursors are created through an explicit
|
|
* call to DB->join.
|
|
*
|
|
* The curslist is an array of existing, initialized cursors and primary
|
|
* is the DB of the primary file. The data item that joins all the
|
|
* cursors in the curslist is used as the key into the primary and that
|
|
* key and data are returned. When no more items are left in the join
|
|
* set, the c_next operation off the join cursor will return DB_NOTFOUND.
|
|
*
|
|
* PUBLIC: int __db_join __P((DB *, DBC **, DBC **, u_int32_t));
|
|
*/
|
|
int
|
|
__db_join(primary, curslist, dbcp, flags)
|
|
DB *primary;
|
|
DBC **curslist, **dbcp;
|
|
u_int32_t flags;
|
|
{
|
|
DB_ENV *dbenv;
|
|
DBC *dbc;
|
|
JOIN_CURSOR *jc;
|
|
size_t ncurs, nslots;
|
|
u_int32_t i;
|
|
int ret;
|
|
|
|
dbenv = primary->dbenv;
|
|
dbc = NULL;
|
|
jc = NULL;
|
|
|
|
if ((ret = __os_calloc(dbenv, 1, sizeof(DBC), &dbc)) != 0)
|
|
goto err;
|
|
|
|
if ((ret = __os_calloc(dbenv, 1, sizeof(JOIN_CURSOR), &jc)) != 0)
|
|
goto err;
|
|
|
|
if ((ret = __os_malloc(dbenv, 256, &jc->j_key.data)) != 0)
|
|
goto err;
|
|
jc->j_key.ulen = 256;
|
|
F_SET(&jc->j_key, DB_DBT_USERMEM);
|
|
|
|
F_SET(&jc->j_rdata, DB_DBT_REALLOC);
|
|
|
|
for (jc->j_curslist = curslist;
|
|
*jc->j_curslist != NULL; jc->j_curslist++)
|
|
;
|
|
|
|
/*
|
|
* The number of cursor slots we allocate is one greater than
|
|
* the number of cursors involved in the join, because the
|
|
* list is NULL-terminated.
|
|
*/
|
|
ncurs = (size_t)(jc->j_curslist - curslist);
|
|
nslots = ncurs + 1;
|
|
|
|
/*
|
|
* !!! -- A note on the various lists hanging off jc.
|
|
*
|
|
* j_curslist is the initial NULL-terminated list of cursors passed
|
|
* into __db_join. The original cursors are not modified; pristine
|
|
* copies are required because, in databases with unsorted dups, we
|
|
* must reset all of the secondary cursors after the first each
|
|
* time the first one is incremented, or else we will lose data
|
|
* which happen to be sorted differently in two different cursors.
|
|
*
|
|
* j_workcurs is where we put those copies that we're planning to
|
|
* work with. They're lazily c_dup'ed from j_curslist as we need
|
|
* them, and closed when the join cursor is closed or when we need
|
|
* to reset them to their original values (in which case we just
|
|
* c_dup afresh).
|
|
*
|
|
* j_fdupcurs is an array of cursors which point to the first
|
|
* duplicate in the duplicate set that contains the data value
|
|
* we're currently interested in. We need this to make
|
|
* __db_join_get correctly return duplicate duplicates; i.e., if a
|
|
* given data value occurs twice in the set belonging to cursor #2,
|
|
* and thrice in the set belonging to cursor #3, and once in all
|
|
* the other cursors, successive calls to __db_join_get need to
|
|
* return that data item six times. To make this happen, each time
|
|
* cursor N is allowed to advance to a new datum, all cursors M
|
|
* such that M > N have to be reset to the first duplicate with
|
|
* that datum, so __db_join_get will return all the dup-dups again.
|
|
* We could just reset them to the original cursor from j_curslist,
|
|
* but that would be a bit slower in the unsorted case and a LOT
|
|
* slower in the sorted one.
|
|
*
|
|
* j_exhausted is a list of boolean values which represent
|
|
* whether or not their corresponding cursors are "exhausted",
|
|
* i.e. whether the datum under the corresponding cursor has
|
|
* been found not to exist in any unreturned combinations of
|
|
* later secondary cursors, in which case they are ready to be
|
|
* incremented.
|
|
*/
|
|
|
|
/* We don't want to free regions whose callocs have failed. */
|
|
jc->j_curslist = NULL;
|
|
jc->j_workcurs = NULL;
|
|
jc->j_fdupcurs = NULL;
|
|
jc->j_exhausted = NULL;
|
|
|
|
if ((ret = __os_calloc(dbenv, nslots, sizeof(DBC *),
|
|
&jc->j_curslist)) != 0)
|
|
goto err;
|
|
if ((ret = __os_calloc(dbenv, nslots, sizeof(DBC *),
|
|
&jc->j_workcurs)) != 0)
|
|
goto err;
|
|
if ((ret = __os_calloc(dbenv, nslots, sizeof(DBC *),
|
|
&jc->j_fdupcurs)) != 0)
|
|
goto err;
|
|
if ((ret = __os_calloc(dbenv, nslots, sizeof(u_int8_t),
|
|
&jc->j_exhausted)) != 0)
|
|
goto err;
|
|
for (i = 0; curslist[i] != NULL; i++) {
|
|
jc->j_curslist[i] = curslist[i];
|
|
jc->j_workcurs[i] = NULL;
|
|
jc->j_fdupcurs[i] = NULL;
|
|
jc->j_exhausted[i] = 0;
|
|
}
|
|
jc->j_ncurs = (u_int32_t)ncurs;
|
|
|
|
/*
|
|
* If DB_JOIN_NOSORT is not set, optimize secondary cursors by
|
|
* sorting in order of increasing cardinality.
|
|
*/
|
|
if (!LF_ISSET(DB_JOIN_NOSORT))
|
|
qsort(jc->j_curslist, ncurs, sizeof(DBC *), __db_join_cmp);
|
|
|
|
/*
|
|
* We never need to reset the 0th cursor, so there's no
|
|
* solid reason to use workcurs[0] rather than curslist[0] in
|
|
* join_get. Nonetheless, it feels cleaner to do it for symmetry,
|
|
* and this is the most logical place to copy it.
|
|
*
|
|
* !!!
|
|
* There's no need to close the new cursor if we goto err only
|
|
* because this is the last thing that can fail. Modifier of this
|
|
* function beware!
|
|
*/
|
|
if ((ret =
|
|
__db_c_dup(jc->j_curslist[0], jc->j_workcurs, DB_POSITION)) != 0)
|
|
goto err;
|
|
|
|
dbc->c_close = __db_join_close_pp;
|
|
dbc->c_del = __db_join_del;
|
|
dbc->c_get = __db_join_get_pp;
|
|
dbc->c_put = __db_join_put;
|
|
dbc->internal = (DBC_INTERNAL *)jc;
|
|
dbc->dbp = primary;
|
|
jc->j_primary = primary;
|
|
|
|
/* Stash the first cursor's transaction here for easy access. */
|
|
dbc->txn = curslist[0]->txn;
|
|
|
|
*dbcp = dbc;
|
|
|
|
MUTEX_THREAD_LOCK(dbenv, primary->mutexp);
|
|
TAILQ_INSERT_TAIL(&primary->join_queue, dbc, links);
|
|
MUTEX_THREAD_UNLOCK(dbenv, primary->mutexp);
|
|
|
|
return (0);
|
|
|
|
err: if (jc != NULL) {
|
|
if (jc->j_curslist != NULL)
|
|
__os_free(dbenv, jc->j_curslist);
|
|
if (jc->j_workcurs != NULL) {
|
|
if (jc->j_workcurs[0] != NULL)
|
|
(void)__db_c_close(jc->j_workcurs[0]);
|
|
__os_free(dbenv, jc->j_workcurs);
|
|
}
|
|
if (jc->j_fdupcurs != NULL)
|
|
__os_free(dbenv, jc->j_fdupcurs);
|
|
if (jc->j_exhausted != NULL)
|
|
__os_free(dbenv, jc->j_exhausted);
|
|
__os_free(dbenv, jc);
|
|
}
|
|
if (dbc != NULL)
|
|
__os_free(dbenv, dbc);
|
|
return (ret);
|
|
}
|
|
|
|
/*
|
|
* __db_join_close_pp --
|
|
* DBC->c_close pre/post processing for join cursors.
|
|
*/
|
|
static int
|
|
__db_join_close_pp(dbc)
|
|
DBC *dbc;
|
|
{
|
|
DB_ENV *dbenv;
|
|
DB *dbp;
|
|
int handle_check, ret;
|
|
|
|
dbp = dbc->dbp;
|
|
dbenv = dbp->dbenv;
|
|
|
|
PANIC_CHECK(dbenv);
|
|
|
|
handle_check = IS_REPLICATED(dbenv, dbp);
|
|
if (handle_check &&
|
|
(ret = __db_rep_enter(dbp, 0, 0, dbc->txn != NULL)) != 0)
|
|
return (ret);
|
|
|
|
ret = __db_join_close(dbc);
|
|
|
|
if (handle_check)
|
|
__env_db_rep_exit(dbenv);
|
|
|
|
return (ret);
|
|
}
|
|
|
|
static int
|
|
__db_join_put(dbc, key, data, flags)
|
|
DBC *dbc;
|
|
DBT *key;
|
|
DBT *data;
|
|
u_int32_t flags;
|
|
{
|
|
PANIC_CHECK(dbc->dbp->dbenv);
|
|
|
|
COMPQUIET(key, NULL);
|
|
COMPQUIET(data, NULL);
|
|
COMPQUIET(flags, 0);
|
|
return (EINVAL);
|
|
}
|
|
|
|
static int
|
|
__db_join_del(dbc, flags)
|
|
DBC *dbc;
|
|
u_int32_t flags;
|
|
{
|
|
PANIC_CHECK(dbc->dbp->dbenv);
|
|
|
|
COMPQUIET(flags, 0);
|
|
return (EINVAL);
|
|
}
|
|
|
|
/*
|
|
* __db_join_get_pp --
|
|
* DBjoin->get pre/post processing.
|
|
*/
|
|
static int
|
|
__db_join_get_pp(dbc, key, data, flags)
|
|
DBC *dbc;
|
|
DBT *key, *data;
|
|
u_int32_t flags;
|
|
{
|
|
DB *dbp;
|
|
DB_ENV *dbenv;
|
|
u_int32_t handle_check, save_flags;
|
|
int ret;
|
|
|
|
dbp = dbc->dbp;
|
|
dbenv = dbp->dbenv;
|
|
|
|
/* Save the original flags value. */
|
|
save_flags = flags;
|
|
|
|
PANIC_CHECK(dbenv);
|
|
|
|
if (LF_ISSET(DB_DIRTY_READ | DB_DEGREE_2 | DB_RMW)) {
|
|
if (!LOCKING_ON(dbp->dbenv))
|
|
return (__db_fnl(dbp->dbenv, "DBcursor->c_get"));
|
|
|
|
LF_CLR(DB_DIRTY_READ | DB_DEGREE_2 | DB_RMW);
|
|
}
|
|
|
|
switch (flags) {
|
|
case 0:
|
|
case DB_JOIN_ITEM:
|
|
break;
|
|
default:
|
|
return (__db_ferr(dbp->dbenv, "DBcursor->c_get", 0));
|
|
}
|
|
|
|
/*
|
|
* A partial get of the key of a join cursor don't make much sense;
|
|
* the entire key is necessary to query the primary database
|
|
* and find the datum, and so regardless of the size of the key
|
|
* it would not be a performance improvement. Since it would require
|
|
* special handling, we simply disallow it.
|
|
*
|
|
* A partial get of the data, however, potentially makes sense (if
|
|
* all possible data are a predictable large structure, for instance)
|
|
* and causes us no headaches, so we permit it.
|
|
*/
|
|
if (F_ISSET(key, DB_DBT_PARTIAL)) {
|
|
__db_err(dbp->dbenv,
|
|
"DB_DBT_PARTIAL may not be set on key during join_get");
|
|
return (EINVAL);
|
|
}
|
|
|
|
handle_check = IS_REPLICATED(dbp->dbenv, dbp);
|
|
if (handle_check &&
|
|
(ret = __db_rep_enter(dbp, 1, 0, dbc->txn != NULL)) != 0)
|
|
return (ret);
|
|
|
|
/* Restore the original flags value. */
|
|
flags = save_flags;
|
|
|
|
ret = __db_join_get(dbc, key, data, flags);
|
|
|
|
if (handle_check)
|
|
__env_db_rep_exit(dbenv);
|
|
|
|
return (ret);
|
|
}
|
|
|
|
static int
|
|
__db_join_get(dbc, key_arg, data_arg, flags)
|
|
DBC *dbc;
|
|
DBT *key_arg, *data_arg;
|
|
u_int32_t flags;
|
|
{
|
|
DBT *key_n, key_n_mem;
|
|
DB *dbp;
|
|
DBC *cp;
|
|
JOIN_CURSOR *jc;
|
|
int db_manage_data, ret;
|
|
u_int32_t i, j, operation, opmods;
|
|
|
|
dbp = dbc->dbp;
|
|
jc = (JOIN_CURSOR *)dbc->internal;
|
|
|
|
operation = LF_ISSET(DB_OPFLAGS_MASK);
|
|
|
|
/* !!!
|
|
* If the set of flags here changes, check that __db_join_primget
|
|
* is updated to handle them properly.
|
|
*/
|
|
opmods = LF_ISSET(DB_RMW | DB_DEGREE_2 | DB_DIRTY_READ);
|
|
|
|
/*
|
|
* Since we are fetching the key as a datum in the secondary indices,
|
|
* we must be careful of caller-specified DB_DBT_* memory
|
|
* management flags. If necessary, use a stack-allocated DBT;
|
|
* we'll appropriately copy and/or allocate the data later.
|
|
*/
|
|
if (F_ISSET(key_arg, DB_DBT_USERMEM) ||
|
|
F_ISSET(key_arg, DB_DBT_MALLOC)) {
|
|
/* We just use the default buffer; no need to go malloc. */
|
|
key_n = &key_n_mem;
|
|
memset(key_n, 0, sizeof(DBT));
|
|
} else {
|
|
/*
|
|
* Either DB_DBT_REALLOC or the default buffer will work
|
|
* fine if we have to reuse it, as we do.
|
|
*/
|
|
key_n = key_arg;
|
|
}
|
|
|
|
/*
|
|
* If our last attempt to do a get on the primary key failed,
|
|
* short-circuit the join and try again with the same key.
|
|
*/
|
|
if (F_ISSET(jc, JOIN_RETRY))
|
|
goto samekey;
|
|
F_CLR(jc, JOIN_RETRY);
|
|
|
|
retry: ret = __db_c_get(jc->j_workcurs[0], &jc->j_key, key_n,
|
|
opmods | (jc->j_exhausted[0] ? DB_NEXT_DUP : DB_CURRENT));
|
|
|
|
if (ret == DB_BUFFER_SMALL) {
|
|
jc->j_key.ulen <<= 1;
|
|
if ((ret = __os_realloc(dbp->dbenv,
|
|
jc->j_key.ulen, &jc->j_key.data)) != 0)
|
|
goto mem_err;
|
|
goto retry;
|
|
}
|
|
|
|
/*
|
|
* If ret == DB_NOTFOUND, we're out of elements of the first
|
|
* secondary cursor. This is how we finally finish the join
|
|
* if all goes well.
|
|
*/
|
|
if (ret != 0)
|
|
goto err;
|
|
|
|
/*
|
|
* If jc->j_exhausted[0] == 1, we've just advanced the first cursor,
|
|
* and we're going to want to advance all the cursors that point to
|
|
* the first member of a duplicate duplicate set (j_fdupcurs[1..N]).
|
|
* Close all the cursors in j_fdupcurs; we'll reopen them the
|
|
* first time through the upcoming loop.
|
|
*/
|
|
for (i = 1; i < jc->j_ncurs; i++) {
|
|
if (jc->j_fdupcurs[i] != NULL &&
|
|
(ret = __db_c_close(jc->j_fdupcurs[i])) != 0)
|
|
goto err;
|
|
jc->j_fdupcurs[i] = NULL;
|
|
}
|
|
|
|
/*
|
|
* If jc->j_curslist[1] == NULL, we have only one cursor in the join.
|
|
* Thus, we can safely increment that one cursor on each call
|
|
* to __db_join_get, and we signal this by setting jc->j_exhausted[0]
|
|
* right away.
|
|
*
|
|
* Otherwise, reset jc->j_exhausted[0] to 0, so that we don't
|
|
* increment it until we know we're ready to.
|
|
*/
|
|
if (jc->j_curslist[1] == NULL)
|
|
jc->j_exhausted[0] = 1;
|
|
else
|
|
jc->j_exhausted[0] = 0;
|
|
|
|
/* We have the first element; now look for it in the other cursors. */
|
|
for (i = 1; i < jc->j_ncurs; i++) {
|
|
DB_ASSERT(jc->j_curslist[i] != NULL);
|
|
if (jc->j_workcurs[i] == NULL)
|
|
/* If this is NULL, we need to dup curslist into it. */
|
|
if ((ret = __db_c_dup(jc->j_curslist[i],
|
|
&jc->j_workcurs[i], DB_POSITION)) != 0)
|
|
goto err;
|
|
|
|
retry2: cp = jc->j_workcurs[i];
|
|
|
|
if ((ret = __db_join_getnext(cp, &jc->j_key, key_n,
|
|
jc->j_exhausted[i], opmods)) == DB_NOTFOUND) {
|
|
/*
|
|
* jc->j_workcurs[i] has no more of the datum we're
|
|
* interested in. Go back one cursor and get
|
|
* a new dup. We can't just move to a new
|
|
* element of the outer relation, because that way
|
|
* we might miss duplicate duplicates in cursor i-1.
|
|
*
|
|
* If this takes us back to the first cursor,
|
|
* -then- we can move to a new element of the outer
|
|
* relation.
|
|
*/
|
|
--i;
|
|
jc->j_exhausted[i] = 1;
|
|
|
|
if (i == 0) {
|
|
for (j = 1; jc->j_workcurs[j] != NULL; j++) {
|
|
/*
|
|
* We're moving to a new element of
|
|
* the first secondary cursor. If
|
|
* that cursor is sorted, then any
|
|
* other sorted cursors can be safely
|
|
* reset to the first duplicate
|
|
* duplicate in the current set if we
|
|
* have a pointer to it (we can't just
|
|
* leave them be, or we'll miss
|
|
* duplicate duplicates in the outer
|
|
* relation).
|
|
*
|
|
* If the first cursor is unsorted, or
|
|
* if cursor j is unsorted, we can
|
|
* make no assumptions about what
|
|
* we're looking for next or where it
|
|
* will be, so we reset to the very
|
|
* beginning (setting workcurs NULL
|
|
* will achieve this next go-round).
|
|
*
|
|
* XXX: This is likely to break
|
|
* horribly if any two cursors are
|
|
* both sorted, but have different
|
|
* specified sort functions. For,
|
|
* now, we dismiss this as pathology
|
|
* and let strange things happen--we
|
|
* can't make rope childproof.
|
|
*/
|
|
if ((ret = __db_c_close(
|
|
jc->j_workcurs[j])) != 0)
|
|
goto err;
|
|
if (!SORTED_SET(jc, 0) ||
|
|
!SORTED_SET(jc, j) ||
|
|
jc->j_fdupcurs[j] == NULL)
|
|
/*
|
|
* Unsafe conditions;
|
|
* reset fully.
|
|
*/
|
|
jc->j_workcurs[j] = NULL;
|
|
else
|
|
/* Partial reset suffices. */
|
|
if ((__db_c_dup(
|
|
jc->j_fdupcurs[j],
|
|
&jc->j_workcurs[j],
|
|
DB_POSITION)) != 0)
|
|
goto err;
|
|
jc->j_exhausted[j] = 0;
|
|
}
|
|
goto retry;
|
|
/* NOTREACHED */
|
|
}
|
|
|
|
/*
|
|
* We're about to advance the cursor and need to
|
|
* reset all of the workcurs[j] where j>i, so that
|
|
* we don't miss any duplicate duplicates.
|
|
*/
|
|
for (j = i + 1;
|
|
jc->j_workcurs[j] != NULL;
|
|
j++) {
|
|
if ((ret =
|
|
__db_c_close(jc->j_workcurs[j])) != 0)
|
|
goto err;
|
|
jc->j_exhausted[j] = 0;
|
|
if (jc->j_fdupcurs[j] == NULL)
|
|
jc->j_workcurs[j] = NULL;
|
|
else if ((ret = __db_c_dup(jc->j_fdupcurs[j],
|
|
&jc->j_workcurs[j], DB_POSITION)) != 0)
|
|
goto err;
|
|
}
|
|
goto retry2;
|
|
/* NOTREACHED */
|
|
}
|
|
|
|
if (ret == DB_BUFFER_SMALL) {
|
|
jc->j_key.ulen <<= 1;
|
|
if ((ret = __os_realloc(dbp->dbenv, jc->j_key.ulen,
|
|
&jc->j_key.data)) != 0) {
|
|
mem_err: __db_err(dbp->dbenv,
|
|
"Allocation failed for join key, len = %lu",
|
|
(u_long)jc->j_key.ulen);
|
|
goto err;
|
|
}
|
|
goto retry2;
|
|
}
|
|
|
|
if (ret != 0)
|
|
goto err;
|
|
|
|
/*
|
|
* If we made it this far, we've found a matching
|
|
* datum in cursor i. Mark the current cursor
|
|
* unexhausted, so we don't miss any duplicate
|
|
* duplicates the next go-round--unless this is the
|
|
* very last cursor, in which case there are none to
|
|
* miss, and we'll need that exhausted flag to finally
|
|
* get a DB_NOTFOUND and move on to the next datum in
|
|
* the outermost cursor.
|
|
*/
|
|
if (i + 1 != jc->j_ncurs)
|
|
jc->j_exhausted[i] = 0;
|
|
else
|
|
jc->j_exhausted[i] = 1;
|
|
|
|
/*
|
|
* If jc->j_fdupcurs[i] is NULL and the ith cursor's dups are
|
|
* sorted, then we're here for the first time since advancing
|
|
* cursor 0, and we have a new datum of interest.
|
|
* jc->j_workcurs[i] points to the beginning of a set of
|
|
* duplicate duplicates; store this into jc->j_fdupcurs[i].
|
|
*/
|
|
if (SORTED_SET(jc, i) && jc->j_fdupcurs[i] == NULL && (ret =
|
|
__db_c_dup(cp, &jc->j_fdupcurs[i], DB_POSITION)) != 0)
|
|
goto err;
|
|
}
|
|
|
|
err: if (ret != 0)
|
|
return (ret);
|
|
|
|
if (0) {
|
|
samekey: /*
|
|
* Get the key we tried and failed to return last time;
|
|
* it should be the current datum of all the secondary cursors.
|
|
*/
|
|
if ((ret = __db_c_get(jc->j_workcurs[0],
|
|
&jc->j_key, key_n, DB_CURRENT | opmods)) != 0)
|
|
return (ret);
|
|
F_CLR(jc, JOIN_RETRY);
|
|
}
|
|
|
|
/*
|
|
* ret == 0; we have a key to return.
|
|
*
|
|
* If DB_DBT_USERMEM or DB_DBT_MALLOC is set, we need to copy the key
|
|
* back into the dbt we were given for the key; call __db_retcopy.
|
|
* Otherwise, assert that we do not need to copy anything and proceed.
|
|
*/
|
|
DB_ASSERT(F_ISSET(
|
|
key_arg, DB_DBT_USERMEM | DB_DBT_MALLOC) || key_n == key_arg);
|
|
|
|
if (F_ISSET(key_arg, DB_DBT_USERMEM | DB_DBT_MALLOC) &&
|
|
(ret = __db_retcopy(dbp->dbenv,
|
|
key_arg, key_n->data, key_n->size, NULL, NULL)) != 0) {
|
|
/*
|
|
* The retcopy failed, most commonly because we have a user
|
|
* buffer for the key which is too small. Set things up to
|
|
* retry next time, and return.
|
|
*/
|
|
F_SET(jc, JOIN_RETRY);
|
|
return (ret);
|
|
}
|
|
|
|
/*
|
|
* If DB_JOIN_ITEM is set, we return it; otherwise we do the lookup
|
|
* in the primary and then return.
|
|
*
|
|
* Note that we use key_arg here; it is safe (and appropriate)
|
|
* to do so.
|
|
*/
|
|
if (operation == DB_JOIN_ITEM)
|
|
return (0);
|
|
|
|
/*
|
|
* If data_arg->flags == 0--that is, if DB is managing the
|
|
* data DBT's memory--it's not safe to just pass the DBT
|
|
* through to the primary get call, since we don't want that
|
|
* memory to belong to the primary DB handle (and if the primary
|
|
* is free-threaded, it can't anyway).
|
|
*
|
|
* Instead, use memory that is managed by the join cursor, in
|
|
* jc->j_rdata.
|
|
*/
|
|
if (!F_ISSET(data_arg, DB_DBT_MALLOC | DB_DBT_REALLOC | DB_DBT_USERMEM))
|
|
db_manage_data = 1;
|
|
else
|
|
db_manage_data = 0;
|
|
if ((ret = __db_join_primget(jc->j_primary,
|
|
jc->j_curslist[0]->txn, jc->j_curslist[0]->locker, key_arg,
|
|
db_manage_data ? &jc->j_rdata : data_arg, opmods)) != 0) {
|
|
if (ret == DB_NOTFOUND)
|
|
/*
|
|
* If ret == DB_NOTFOUND, the primary and secondary
|
|
* are out of sync; every item in each secondary
|
|
* should correspond to something in the primary,
|
|
* or we shouldn't have done the join this way.
|
|
* Wail.
|
|
*/
|
|
ret = __db_secondary_corrupt(jc->j_primary);
|
|
else
|
|
/*
|
|
* The get on the primary failed for some other
|
|
* reason, most commonly because we're using a user
|
|
* buffer that's not big enough. Flag our failure
|
|
* so we can return the same key next time.
|
|
*/
|
|
F_SET(jc, JOIN_RETRY);
|
|
}
|
|
if (db_manage_data && ret == 0) {
|
|
data_arg->data = jc->j_rdata.data;
|
|
data_arg->size = jc->j_rdata.size;
|
|
}
|
|
|
|
return (ret);
|
|
}
|
|
|
|
/*
|
|
* __db_join_close --
|
|
* DBC->c_close for join cursors.
|
|
*
|
|
* PUBLIC: int __db_join_close __P((DBC *));
|
|
*/
|
|
int
|
|
__db_join_close(dbc)
|
|
DBC *dbc;
|
|
{
|
|
DB *dbp;
|
|
DB_ENV *dbenv;
|
|
JOIN_CURSOR *jc;
|
|
int ret, t_ret;
|
|
u_int32_t i;
|
|
|
|
jc = (JOIN_CURSOR *)dbc->internal;
|
|
dbp = dbc->dbp;
|
|
dbenv = dbp->dbenv;
|
|
ret = t_ret = 0;
|
|
|
|
/*
|
|
* Remove from active list of join cursors. Note that this
|
|
* must happen before any action that can fail and return, or else
|
|
* __db_close may loop indefinitely.
|
|
*/
|
|
MUTEX_THREAD_LOCK(dbenv, dbp->mutexp);
|
|
TAILQ_REMOVE(&dbp->join_queue, dbc, links);
|
|
MUTEX_THREAD_UNLOCK(dbenv, dbp->mutexp);
|
|
|
|
PANIC_CHECK(dbenv);
|
|
|
|
/*
|
|
* Close any open scratch cursors. In each case, there may
|
|
* not be as many outstanding as there are cursors in
|
|
* curslist, but we want to close whatever's there.
|
|
*
|
|
* If any close fails, there's no reason not to close everything else;
|
|
* we'll just return the error code of the last one to fail. There's
|
|
* not much the caller can do anyway, since these cursors only exist
|
|
* hanging off a db-internal data structure that they shouldn't be
|
|
* mucking with.
|
|
*/
|
|
for (i = 0; i < jc->j_ncurs; i++) {
|
|
if (jc->j_workcurs[i] != NULL &&
|
|
(t_ret = __db_c_close(jc->j_workcurs[i])) != 0)
|
|
ret = t_ret;
|
|
if (jc->j_fdupcurs[i] != NULL &&
|
|
(t_ret = __db_c_close(jc->j_fdupcurs[i])) != 0)
|
|
ret = t_ret;
|
|
}
|
|
|
|
__os_free(dbenv, jc->j_exhausted);
|
|
__os_free(dbenv, jc->j_curslist);
|
|
__os_free(dbenv, jc->j_workcurs);
|
|
__os_free(dbenv, jc->j_fdupcurs);
|
|
__os_free(dbenv, jc->j_key.data);
|
|
if (jc->j_rdata.data != NULL)
|
|
__os_ufree(dbenv, jc->j_rdata.data);
|
|
__os_free(dbenv, jc);
|
|
__os_free(dbenv, dbc);
|
|
|
|
return (ret);
|
|
}
|
|
|
|
/*
|
|
* __db_join_getnext --
|
|
* This function replaces the DBC_CONTINUE and DBC_KEYSET
|
|
* functionality inside the various cursor get routines.
|
|
*
|
|
* If exhausted == 0, we're not done with the current datum;
|
|
* return it if it matches "matching", otherwise search
|
|
* using DB_GET_BOTHC (which is faster than iteratively doing
|
|
* DB_NEXT_DUP) forward until we find one that does.
|
|
*
|
|
* If exhausted == 1, we are done with the current datum, so just
|
|
* leap forward to searching NEXT_DUPs.
|
|
*
|
|
* If no matching datum exists, returns DB_NOTFOUND, else 0.
|
|
*/
|
|
static int
|
|
__db_join_getnext(dbc, key, data, exhausted, opmods)
|
|
DBC *dbc;
|
|
DBT *key, *data;
|
|
u_int32_t exhausted, opmods;
|
|
{
|
|
int ret, cmp;
|
|
DB *dbp;
|
|
DBT ldata;
|
|
int (*func) __P((DB *, const DBT *, const DBT *));
|
|
|
|
dbp = dbc->dbp;
|
|
func = (dbp->dup_compare == NULL) ? __bam_defcmp : dbp->dup_compare;
|
|
|
|
switch (exhausted) {
|
|
case 0:
|
|
/*
|
|
* We don't want to step on data->data; use a new
|
|
* DBT and malloc so we don't step on dbc's rdata memory.
|
|
*/
|
|
memset(&ldata, 0, sizeof(DBT));
|
|
F_SET(&ldata, DB_DBT_MALLOC);
|
|
if ((ret = __db_c_get(dbc,
|
|
key, &ldata, opmods | DB_CURRENT)) != 0)
|
|
break;
|
|
cmp = func(dbp, data, &ldata);
|
|
if (cmp == 0) {
|
|
/*
|
|
* We have to return the real data value. Copy
|
|
* it into data, then free the buffer we malloc'ed
|
|
* above.
|
|
*/
|
|
if ((ret = __db_retcopy(dbp->dbenv, data, ldata.data,
|
|
ldata.size, &data->data, &data->size)) != 0)
|
|
return (ret);
|
|
__os_ufree(dbp->dbenv, ldata.data);
|
|
return (0);
|
|
}
|
|
|
|
/*
|
|
* Didn't match--we want to fall through and search future
|
|
* dups. We just forget about ldata and free
|
|
* its buffer--data contains the value we're searching for.
|
|
*/
|
|
__os_ufree(dbp->dbenv, ldata.data);
|
|
/* FALLTHROUGH */
|
|
case 1:
|
|
ret = __db_c_get(dbc, key, data, opmods | DB_GET_BOTHC);
|
|
break;
|
|
default:
|
|
ret = EINVAL;
|
|
break;
|
|
}
|
|
|
|
return (ret);
|
|
}
|
|
|
|
/*
|
|
* __db_join_cmp --
|
|
* Comparison function for sorting DBCs in cardinality order.
|
|
*/
|
|
static int
|
|
__db_join_cmp(a, b)
|
|
const void *a, *b;
|
|
{
|
|
DBC *dbca, *dbcb;
|
|
db_recno_t counta, countb;
|
|
|
|
dbca = *((DBC * const *)a);
|
|
dbcb = *((DBC * const *)b);
|
|
|
|
if (__db_c_count(dbca, &counta) != 0 ||
|
|
__db_c_count(dbcb, &countb) != 0)
|
|
return (0);
|
|
|
|
return ((long)counta - (long)countb);
|
|
}
|
|
|
|
/*
|
|
* __db_join_primget --
|
|
* Perform a DB->get in the primary, being careful not to use a new
|
|
* locker ID if we're doing CDB locking.
|
|
*/
|
|
static int
|
|
__db_join_primget(dbp, txn, lockerid, key, data, flags)
|
|
DB *dbp;
|
|
DB_TXN *txn;
|
|
u_int32_t lockerid;
|
|
DBT *key, *data;
|
|
u_int32_t flags;
|
|
{
|
|
DBC *dbc;
|
|
int ret, rmw, t_ret;
|
|
|
|
if ((ret = __db_cursor_int(dbp,
|
|
txn, dbp->type, PGNO_INVALID, 0, lockerid, &dbc)) != 0)
|
|
return (ret);
|
|
|
|
/*
|
|
* The only allowable flags here are the two flags copied into
|
|
* "opmods" in __db_join_get, DB_RMW and DB_DIRTY_READ. The former
|
|
* is an op on the c_get call, the latter on the cursor call.
|
|
* It's a DB bug if we allow any other flags down in here.
|
|
*/
|
|
rmw = LF_ISSET(DB_RMW);
|
|
if (LF_ISSET(DB_DIRTY_READ) ||
|
|
(txn != NULL && F_ISSET(txn, TXN_DIRTY_READ)))
|
|
F_SET(dbc, DBC_DIRTY_READ);
|
|
|
|
if (LF_ISSET(DB_DEGREE_2) ||
|
|
(txn != NULL && F_ISSET(txn, TXN_DEGREE_2)))
|
|
F_SET(dbc, DBC_DEGREE_2);
|
|
|
|
LF_CLR(DB_RMW | DB_DIRTY_READ | DB_DEGREE_2);
|
|
DB_ASSERT(flags == 0);
|
|
|
|
F_SET(dbc, DBC_TRANSIENT);
|
|
|
|
/*
|
|
* This shouldn't be necessary, thanks to the fact that join cursors
|
|
* swap in their own DB_DBT_REALLOC'ed buffers, but just for form's
|
|
* sake, we mirror what __db_get does.
|
|
*/
|
|
SET_RET_MEM(dbc, dbp);
|
|
|
|
ret = __db_c_get(dbc, key, data, DB_SET | rmw);
|
|
|
|
if ((t_ret = __db_c_close(dbc)) != 0 && ret == 0)
|
|
ret = t_ret;
|
|
|
|
return (ret);
|
|
}
|
|
|
|
/*
|
|
* __db_secondary_corrupt --
|
|
* Report that a secondary index appears corrupt, as it has a record
|
|
* that does not correspond to a record in the primary or vice versa.
|
|
*
|
|
* PUBLIC: int __db_secondary_corrupt __P((DB *));
|
|
*/
|
|
int
|
|
__db_secondary_corrupt(dbp)
|
|
DB *dbp;
|
|
{
|
|
__db_err(dbp->dbenv,
|
|
"Secondary index corrupt: not consistent with primary");
|
|
return (DB_SECONDARY_BAD);
|
|
}
|