mirror of
https://github.com/MariaDB/server.git
synced 2025-05-05 16:59:35 +03:00
BitKeeper/deleted/.del-ex_access.wpj~3df6ae8c99bf7c5f: Delete: bdb/build_vxworks/ex_access/ex_access.wpj BitKeeper/deleted/.del-ex_btrec.wpj~a7622f1c6f432dc6: Delete: bdb/build_vxworks/ex_btrec/ex_btrec.wpj BitKeeper/deleted/.del-ex_dbclient.wpj~7345440f3b204cdd: Delete: bdb/build_vxworks/ex_dbclient/ex_dbclient.wpj BitKeeper/deleted/.del-ex_env.wpj~fbe1ab10b04e8b74: Delete: bdb/build_vxworks/ex_env/ex_env.wpj BitKeeper/deleted/.del-ex_mpool.wpj~4479cfd5c45f327d: Delete: bdb/build_vxworks/ex_mpool/ex_mpool.wpj BitKeeper/deleted/.del-ex_tpcb.wpj~f78093006e14bf41: Delete: bdb/build_vxworks/ex_tpcb/ex_tpcb.wpj BitKeeper/deleted/.del-db_buildall.dsp~bd749ff6da11682: Delete: bdb/build_win32/db_buildall.dsp BitKeeper/deleted/.del-cxx_app.cpp~ad8df8e0791011ed: Delete: bdb/cxx/cxx_app.cpp BitKeeper/deleted/.del-cxx_log.cpp~a50ff3118fe06952: Delete: bdb/cxx/cxx_log.cpp BitKeeper/deleted/.del-cxx_table.cpp~ecd751e79b055556: Delete: bdb/cxx/cxx_table.cpp BitKeeper/deleted/.del-namemap.txt~796a3acd3885d8fd: Delete: bdb/cxx/namemap.txt BitKeeper/deleted/.del-Design.fileop~3ca4da68f1727373: Delete: bdb/db/Design.fileop BitKeeper/deleted/.del-db185_int.h~61bee3736e7959ef: Delete: bdb/db185/db185_int.h BitKeeper/deleted/.del-acconfig.h~411e8854d67ad8b5: Delete: bdb/dist/acconfig.h BitKeeper/deleted/.del-mutex.m4~a13383cde18a64e1: Delete: bdb/dist/aclocal/mutex.m4 BitKeeper/deleted/.del-options.m4~b9d0ca637213750a: Delete: bdb/dist/aclocal/options.m4 BitKeeper/deleted/.del-programs.m4~3ce7890b47732b30: Delete: bdb/dist/aclocal/programs.m4 BitKeeper/deleted/.del-tcl.m4~f944e2db93c3b6db: Delete: bdb/dist/aclocal/tcl.m4 BitKeeper/deleted/.del-types.m4~59cae158c9a32cff: Delete: bdb/dist/aclocal/types.m4 BitKeeper/deleted/.del-script~d38f6d3a4f159cb4: Delete: bdb/dist/build/script BitKeeper/deleted/.del-configure.in~ac795a92c8fe049c: Delete: bdb/dist/configure.in BitKeeper/deleted/.del-ltconfig~66bbd007d8024af: Delete: bdb/dist/ltconfig BitKeeper/deleted/.del-rec_ctemp~a28554362534f00a: Delete: bdb/dist/rec_ctemp BitKeeper/deleted/.del-s_tcl~2ffe4326459fcd9f: Delete: bdb/dist/s_tcl BitKeeper/deleted/.del-.IGNORE_ME~d8148b08fa7d5d15: Delete: bdb/dist/template/.IGNORE_ME BitKeeper/deleted/.del-btree.h~179f2aefec1753d: Delete: bdb/include/btree.h BitKeeper/deleted/.del-cxx_int.h~6b649c04766508f8: Delete: bdb/include/cxx_int.h BitKeeper/deleted/.del-db.src~6b433ae615b16a8d: Delete: bdb/include/db.src BitKeeper/deleted/.del-db_185.h~ad8b373d9391d35c: Delete: bdb/include/db_185.h BitKeeper/deleted/.del-db_am.h~a714912b6b75932f: Delete: bdb/include/db_am.h BitKeeper/deleted/.del-db_cxx.h~fcafadf45f5d19e9: Delete: bdb/include/db_cxx.h BitKeeper/deleted/.del-db_dispatch.h~6844f20f7eb46904: Delete: bdb/include/db_dispatch.h BitKeeper/deleted/.del-db_int.src~419a3f48b6a01da7: Delete: bdb/include/db_int.src BitKeeper/deleted/.del-db_join.h~76f9747a42c3399a: Delete: bdb/include/db_join.h BitKeeper/deleted/.del-db_page.h~e302ca3a4db3abdc: Delete: bdb/include/db_page.h BitKeeper/deleted/.del-db_server_int.h~e1d20b6ba3bca1ab: Delete: bdb/include/db_server_int.h BitKeeper/deleted/.del-db_shash.h~5fbf2d696fac90f3: Delete: bdb/include/db_shash.h BitKeeper/deleted/.del-db_swap.h~1e60887550864a59: Delete: bdb/include/db_swap.h BitKeeper/deleted/.del-db_upgrade.h~c644eee73701fc8d: Delete: bdb/include/db_upgrade.h BitKeeper/deleted/.del-db_verify.h~b8d6c297c61f342e: Delete: bdb/include/db_verify.h BitKeeper/deleted/.del-debug.h~dc2b4f2cf27ccebc: Delete: bdb/include/debug.h BitKeeper/deleted/.del-hash.h~2aaa548b28882dfb: Delete: bdb/include/hash.h BitKeeper/deleted/.del-lock.h~a761c1b7de57b77f: Delete: bdb/include/lock.h BitKeeper/deleted/.del-log.h~ff20184238e35e4d: Delete: bdb/include/log.h BitKeeper/deleted/.del-mp.h~7e317597622f3411: Delete: bdb/include/mp.h BitKeeper/deleted/.del-mutex.h~d3ae7a2977a68137: Delete: bdb/include/mutex.h BitKeeper/deleted/.del-os.h~91867cc8757cd0e3: Delete: bdb/include/os.h BitKeeper/deleted/.del-os_jump.h~e1b939fa5151d4be: Delete: bdb/include/os_jump.h BitKeeper/deleted/.del-qam.h~6fad0c1b5723d597: Delete: bdb/include/qam.h BitKeeper/deleted/.del-queue.h~4c72c0826c123d5: Delete: bdb/include/queue.h BitKeeper/deleted/.del-region.h~513fe04d977ca0fc: Delete: bdb/include/region.h BitKeeper/deleted/.del-shqueue.h~525fc3e6c2025c36: Delete: bdb/include/shqueue.h BitKeeper/deleted/.del-tcl_db.h~c536fd61a844f23f: Delete: bdb/include/tcl_db.h BitKeeper/deleted/.del-txn.h~c8d94b221ec147e4: Delete: bdb/include/txn.h BitKeeper/deleted/.del-xa.h~ecc466493aae9d9a: Delete: bdb/include/xa.h BitKeeper/deleted/.del-DbRecoveryInit.java~756b52601a0b9023: Delete: bdb/java/src/com/sleepycat/db/DbRecoveryInit.java BitKeeper/deleted/.del-DbTxnRecover.java~74607cba7ab89d6d: Delete: bdb/java/src/com/sleepycat/db/DbTxnRecover.java BitKeeper/deleted/.del-lock_conflict.c~fc5e0f14cf597a2b: Delete: bdb/lock/lock_conflict.c BitKeeper/deleted/.del-log.src~53ac9e7b5cb023f2: Delete: bdb/log/log.src BitKeeper/deleted/.del-log_findckp.c~24287f008916e81f: Delete: bdb/log/log_findckp.c BitKeeper/deleted/.del-log_rec.c~d51711f2cac09297: Delete: bdb/log/log_rec.c BitKeeper/deleted/.del-log_register.c~b40bb4efac75ca15: Delete: bdb/log/log_register.c BitKeeper/deleted/.del-Design~b3d0f179f2767b: Delete: bdb/mp/Design BitKeeper/deleted/.del-os_finit.c~95dbefc6fe79b26c: Delete: bdb/os/os_finit.c BitKeeper/deleted/.del-os_abs.c~df95d1e7db81924: Delete: bdb/os_vxworks/os_abs.c BitKeeper/deleted/.del-os_finit.c~803b484bdb9d0122: Delete: bdb/os_vxworks/os_finit.c BitKeeper/deleted/.del-os_map.c~3a6d7926398b76d3: Delete: bdb/os_vxworks/os_map.c BitKeeper/deleted/.del-os_finit.c~19a227c6d3c78ad: Delete: bdb/os_win32/os_finit.c BitKeeper/deleted/.del-log-corruption.patch~1cf2ecc7c6408d5d: Delete: bdb/patches/log-corruption.patch BitKeeper/deleted/.del-Btree.pm~af6d0c5eaed4a98e: Delete: bdb/perl.BerkeleyDB/BerkeleyDB/Btree.pm BitKeeper/deleted/.del-BerkeleyDB.pm~7244036d4482643: Delete: bdb/perl.BerkeleyDB/BerkeleyDB.pm BitKeeper/deleted/.del-BerkeleyDB.pod~e7b18fd6132448e3: Delete: bdb/perl.BerkeleyDB/BerkeleyDB.pod BitKeeper/deleted/.del-Hash.pm~10292a26c06a5c95: Delete: bdb/perl.BerkeleyDB/BerkeleyDB/Hash.pm BitKeeper/deleted/.del-BerkeleyDB.pod.P~79f76a1495eda203: Delete: bdb/perl.BerkeleyDB/BerkeleyDB.pod.P BitKeeper/deleted/.del-BerkeleyDB.xs~80c99afbd98e392c: Delete: bdb/perl.BerkeleyDB/BerkeleyDB.xs BitKeeper/deleted/.del-Changes~729c1891efa60de9: Delete: bdb/perl.BerkeleyDB/Changes BitKeeper/deleted/.del-MANIFEST~63a1e34aecf157a0: Delete: bdb/perl.BerkeleyDB/MANIFEST BitKeeper/deleted/.del-Makefile.PL~c68797707d8df87a: Delete: bdb/perl.BerkeleyDB/Makefile.PL BitKeeper/deleted/.del-README~5f2f579b1a241407: Delete: bdb/perl.BerkeleyDB/README BitKeeper/deleted/.del-Todo~dca3c66c193adda9: Delete: bdb/perl.BerkeleyDB/Todo BitKeeper/deleted/.del-config.in~ae81681e450e0999: Delete: bdb/perl.BerkeleyDB/config.in BitKeeper/deleted/.del-dbinfo~28ad67d83be4f68e: Delete: bdb/perl.BerkeleyDB/dbinfo BitKeeper/deleted/.del-mkconsts~543ab60669c7a04e: Delete: bdb/perl.BerkeleyDB/mkconsts BitKeeper/deleted/.del-mkpod~182c0ca54e439afb: Delete: bdb/perl.BerkeleyDB/mkpod BitKeeper/deleted/.del-5.004~e008cb5a48805543: Delete: bdb/perl.BerkeleyDB/patches/5.004 BitKeeper/deleted/.del-irix_6_5.pl~61662bb08afcdec8: Delete: bdb/perl.BerkeleyDB/hints/irix_6_5.pl BitKeeper/deleted/.del-solaris.pl~6771e7182394e152: Delete: bdb/perl.BerkeleyDB/hints/solaris.pl BitKeeper/deleted/.del-typemap~783b8f5295b05f3d: Delete: bdb/perl.BerkeleyDB/typemap BitKeeper/deleted/.del-5.004_01~6081ce2fff7b0bc: Delete: bdb/perl.BerkeleyDB/patches/5.004_01 BitKeeper/deleted/.del-5.004_02~87214eac35ad9e6: Delete: bdb/perl.BerkeleyDB/patches/5.004_02 BitKeeper/deleted/.del-5.004_03~9a672becec7cb40f: Delete: bdb/perl.BerkeleyDB/patches/5.004_03 BitKeeper/deleted/.del-5.004_04~e326cb51af09d154: Delete: bdb/perl.BerkeleyDB/patches/5.004_04 BitKeeper/deleted/.del-5.004_05~7ab457a1e41a92fe: Delete: bdb/perl.BerkeleyDB/patches/5.004_05 BitKeeper/deleted/.del-5.005~f9e2d59b5964cd4b: Delete: bdb/perl.BerkeleyDB/patches/5.005 BitKeeper/deleted/.del-5.005_01~3eb9fb7b5842ea8e: Delete: bdb/perl.BerkeleyDB/patches/5.005_01 BitKeeper/deleted/.del-5.005_02~67477ce0bef717cb: Delete: bdb/perl.BerkeleyDB/patches/5.005_02 BitKeeper/deleted/.del-5.005_03~c4c29a1fb21e290a: Delete: bdb/perl.BerkeleyDB/patches/5.005_03 BitKeeper/deleted/.del-5.6.0~e1fb9897d124ee22: Delete: bdb/perl.BerkeleyDB/patches/5.6.0 BitKeeper/deleted/.del-btree.t~e4a1a3c675ddc406: Delete: bdb/perl.BerkeleyDB/t/btree.t BitKeeper/deleted/.del-db-3.0.t~d2c60991d84558f2: Delete: bdb/perl.BerkeleyDB/t/db-3.0.t BitKeeper/deleted/.del-db-3.1.t~6ee88cd13f55e018: Delete: bdb/perl.BerkeleyDB/t/db-3.1.t BitKeeper/deleted/.del-db-3.2.t~f73b6461f98fd1cf: Delete: bdb/perl.BerkeleyDB/t/db-3.2.t BitKeeper/deleted/.del-destroy.t~cc6a2ae1980a2ecd: Delete: bdb/perl.BerkeleyDB/t/destroy.t BitKeeper/deleted/.del-env.t~a8604a4499c4bd07: Delete: bdb/perl.BerkeleyDB/t/env.t BitKeeper/deleted/.del-examples.t~2571b77c3cc75574: Delete: bdb/perl.BerkeleyDB/t/examples.t BitKeeper/deleted/.del-examples.t.T~8228bdd75ac78b88: Delete: bdb/perl.BerkeleyDB/t/examples.t.T BitKeeper/deleted/.del-examples3.t.T~66a186897a87026d: Delete: bdb/perl.BerkeleyDB/t/examples3.t.T BitKeeper/deleted/.del-examples3.t~fe3822ba2f2d7f83: Delete: bdb/perl.BerkeleyDB/t/examples3.t BitKeeper/deleted/.del-filter.t~f87b045c1b708637: Delete: bdb/perl.BerkeleyDB/t/filter.t BitKeeper/deleted/.del-hash.t~616bfb4d644de3a3: Delete: bdb/perl.BerkeleyDB/t/hash.t BitKeeper/deleted/.del-join.t~29fc39f74a83ca22: Delete: bdb/perl.BerkeleyDB/t/join.t BitKeeper/deleted/.del-mldbm.t~31f5015341eea040: Delete: bdb/perl.BerkeleyDB/t/mldbm.t BitKeeper/deleted/.del-queue.t~8f338034ce44a641: Delete: bdb/perl.BerkeleyDB/t/queue.t BitKeeper/deleted/.del-recno.t~d4ddbd3743add63e: Delete: bdb/perl.BerkeleyDB/t/recno.t BitKeeper/deleted/.del-strict.t~6885cdd2ea71ca2d: Delete: bdb/perl.BerkeleyDB/t/strict.t BitKeeper/deleted/.del-subdb.t~aab62a5d5864c603: Delete: bdb/perl.BerkeleyDB/t/subdb.t BitKeeper/deleted/.del-txn.t~65033b8558ae1216: Delete: bdb/perl.BerkeleyDB/t/txn.t BitKeeper/deleted/.del-unknown.t~f3710458682665e1: Delete: bdb/perl.BerkeleyDB/t/unknown.t BitKeeper/deleted/.del-Changes~436f74a5c414c65b: Delete: bdb/perl.DB_File/Changes BitKeeper/deleted/.del-DB_File.pm~ae0951c6c7665a82: Delete: bdb/perl.DB_File/DB_File.pm BitKeeper/deleted/.del-DB_File.xs~89e49a0b5556f1d8: Delete: bdb/perl.DB_File/DB_File.xs BitKeeper/deleted/.del-DB_File_BS~290fad5dbbb87069: Delete: bdb/perl.DB_File/DB_File_BS BitKeeper/deleted/.del-MANIFEST~90ee581572bdd4ac: Delete: bdb/perl.DB_File/MANIFEST BitKeeper/deleted/.del-Makefile.PL~ac0567bb5a377e38: Delete: bdb/perl.DB_File/Makefile.PL BitKeeper/deleted/.del-README~77e924a5a9bae6b3: Delete: bdb/perl.DB_File/README BitKeeper/deleted/.del-config.in~ab4c2792b86a810b: Delete: bdb/perl.DB_File/config.in BitKeeper/deleted/.del-dbinfo~461c43b30fab2cb: Delete: bdb/perl.DB_File/dbinfo BitKeeper/deleted/.del-dynixptx.pl~50dcddfae25d17e9: Delete: bdb/perl.DB_File/hints/dynixptx.pl BitKeeper/deleted/.del-typemap~55cffb3288a9e587: Delete: bdb/perl.DB_File/typemap BitKeeper/deleted/.del-version.c~a4df0e646f8b3975: Delete: bdb/perl.DB_File/version.c BitKeeper/deleted/.del-5.004_01~d6830d0082702af7: Delete: bdb/perl.DB_File/patches/5.004_01 BitKeeper/deleted/.del-5.004_02~78b082dc80c91031: Delete: bdb/perl.DB_File/patches/5.004_02 BitKeeper/deleted/.del-5.004~4411ec2e3c9e008b: Delete: bdb/perl.DB_File/patches/5.004 BitKeeper/deleted/.del-sco.pl~1e795fe14fe4dcfe: Delete: bdb/perl.DB_File/hints/sco.pl BitKeeper/deleted/.del-5.004_03~33f274648b160d95: Delete: bdb/perl.DB_File/patches/5.004_03 BitKeeper/deleted/.del-5.004_04~8f3d1b3cf18bb20a: Delete: bdb/perl.DB_File/patches/5.004_04 BitKeeper/deleted/.del-5.004_05~9c0f02e7331e142: Delete: bdb/perl.DB_File/patches/5.004_05 BitKeeper/deleted/.del-5.005~c2108cb2e3c8d951: Delete: bdb/perl.DB_File/patches/5.005 BitKeeper/deleted/.del-5.005_01~3b45e9673afc4cfa: Delete: bdb/perl.DB_File/patches/5.005_01 BitKeeper/deleted/.del-5.005_02~9fe5766bb02a4522: Delete: bdb/perl.DB_File/patches/5.005_02 BitKeeper/deleted/.del-5.005_03~ffa1c38c19ae72ea: Delete: bdb/perl.DB_File/patches/5.005_03 BitKeeper/deleted/.del-5.6.0~373be3a5ce47be85: Delete: bdb/perl.DB_File/patches/5.6.0 BitKeeper/deleted/.del-db-btree.t~3231595a1c241eb3: Delete: bdb/perl.DB_File/t/db-btree.t BitKeeper/deleted/.del-db-hash.t~7c4ad0c795c7fad2: Delete: bdb/perl.DB_File/t/db-hash.t BitKeeper/deleted/.del-db-recno.t~6c2d3d80b9ba4a50: Delete: bdb/perl.DB_File/t/db-recno.t BitKeeper/deleted/.del-db_server.sed~cdb00ebcd48a64e2: Delete: bdb/rpc_server/db_server.sed BitKeeper/deleted/.del-db_server_proc.c~d46c8f409c3747f4: Delete: bdb/rpc_server/db_server_proc.c BitKeeper/deleted/.del-db_server_svc.sed~3f5e59f334fa4607: Delete: bdb/rpc_server/db_server_svc.sed BitKeeper/deleted/.del-db_server_util.c~a809f3a4629acda: Delete: bdb/rpc_server/db_server_util.c BitKeeper/deleted/.del-log.tcl~ff1b41f1355b97d7: Delete: bdb/test/log.tcl BitKeeper/deleted/.del-mpool.tcl~b0df4dc1b04db26c: Delete: bdb/test/mpool.tcl BitKeeper/deleted/.del-mutex.tcl~52fd5c73a150565: Delete: bdb/test/mutex.tcl BitKeeper/deleted/.del-txn.tcl~c4ff071550b5446e: Delete: bdb/test/txn.tcl BitKeeper/deleted/.del-README~e800a12a5392010a: Delete: bdb/test/upgrade/README BitKeeper/deleted/.del-pack-2.6.6.pl~89d5076d758d3e98: Delete: bdb/test/upgrade/generate-2.X/pack-2.6.6.pl BitKeeper/deleted/.del-test-2.6.patch~4a52dc83d447547b: Delete: bdb/test/upgrade/generate-2.X/test-2.6.patch
2201 lines
48 KiB
C++
2201 lines
48 KiB
C++
/*-
|
|
* See the file LICENSE for redistribution information.
|
|
*
|
|
* Copyright (c) 2001-2002
|
|
* Sleepycat Software. All rights reserved.
|
|
*/
|
|
|
|
#include "db_config.h"
|
|
|
|
#ifdef HAVE_RPC
|
|
#ifndef lint
|
|
static const char revid[] = "$Id: db_server_cxxproc.cpp,v 1.12 2002/08/09 01:56:08 bostic Exp $";
|
|
#endif /* not lint */
|
|
|
|
#ifndef NO_SYSTEM_INCLUDES
|
|
#include <sys/types.h>
|
|
|
|
#include <rpc/rpc.h>
|
|
|
|
#include <string.h>
|
|
#endif
|
|
#include "dbinc_auto/db_server.h"
|
|
|
|
#include "db_int.h"
|
|
#include "db_cxx.h"
|
|
|
|
extern "C" {
|
|
#include "dbinc/db_server_int.h"
|
|
#include "dbinc_auto/rpc_server_ext.h"
|
|
}
|
|
|
|
/* BEGIN __env_cachesize_proc */
|
|
extern "C" void
|
|
__env_cachesize_proc(
|
|
long dbenvcl_id,
|
|
u_int32_t gbytes,
|
|
u_int32_t bytes,
|
|
u_int32_t ncache,
|
|
__env_cachesize_reply *replyp)
|
|
/* END __env_cachesize_proc */
|
|
{
|
|
DbEnv *dbenv;
|
|
ct_entry *dbenv_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbenv_ctp, dbenvcl_id, CT_ENV);
|
|
dbenv = (DbEnv *)dbenv_ctp->ct_anyp;
|
|
|
|
ret = dbenv->set_cachesize(gbytes, bytes, ncache);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __env_close_proc */
|
|
extern "C" void
|
|
__env_close_proc(
|
|
long dbenvcl_id,
|
|
u_int32_t flags,
|
|
__env_close_reply *replyp)
|
|
/* END __env_close_proc */
|
|
{
|
|
ct_entry *dbenv_ctp;
|
|
|
|
ACTIVATE_CTP(dbenv_ctp, dbenvcl_id, CT_ENV);
|
|
replyp->status = __dbenv_close_int(dbenvcl_id, flags, 0);
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __env_create_proc */
|
|
extern "C" void
|
|
__env_create_proc(
|
|
u_int32_t timeout,
|
|
__env_create_reply *replyp)
|
|
/* END __env_create_proc */
|
|
{
|
|
DbEnv *dbenv;
|
|
ct_entry *ctp;
|
|
|
|
ctp = new_ct_ent(&replyp->status);
|
|
if (ctp == NULL)
|
|
return;
|
|
|
|
dbenv = new DbEnv(DB_CXX_NO_EXCEPTIONS);
|
|
ctp->ct_envp = dbenv;
|
|
ctp->ct_type = CT_ENV;
|
|
ctp->ct_parent = NULL;
|
|
ctp->ct_envparent = ctp;
|
|
__dbsrv_settimeout(ctp, timeout);
|
|
__dbsrv_active(ctp);
|
|
replyp->envcl_id = ctp->ct_id;
|
|
|
|
replyp->status = 0;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __env_dbremove_proc */
|
|
extern "C" void
|
|
__env_dbremove_proc(
|
|
long dbenvcl_id,
|
|
long txnpcl_id,
|
|
char *name,
|
|
char *subdb,
|
|
u_int32_t flags,
|
|
__env_dbremove_reply *replyp)
|
|
/* END __env_dbremove_proc */
|
|
{
|
|
int ret;
|
|
DbEnv *dbenv;
|
|
DbTxn *txnp;
|
|
ct_entry *dbenv_ctp, *txnp_ctp;
|
|
|
|
ACTIVATE_CTP(dbenv_ctp, dbenvcl_id, CT_ENV);
|
|
dbenv = (DbEnv *)dbenv_ctp->ct_anyp;
|
|
|
|
if (txnpcl_id != 0) {
|
|
ACTIVATE_CTP(txnp_ctp, txnpcl_id, CT_TXN);
|
|
txnp = (DbTxn *)txnp_ctp->ct_anyp;
|
|
} else
|
|
txnp = NULL;
|
|
|
|
ret = dbenv->dbremove(txnp, name, subdb, flags);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __env_dbrename_proc */
|
|
void
|
|
__env_dbrename_proc(
|
|
long dbenvcl_id,
|
|
long txnpcl_id,
|
|
char *name,
|
|
char *subdb,
|
|
char *newname,
|
|
u_int32_t flags,
|
|
__env_dbrename_reply *replyp)
|
|
/* END __env_dbrename_proc */
|
|
{
|
|
int ret;
|
|
DbEnv *dbenv;
|
|
DbTxn *txnp;
|
|
ct_entry *dbenv_ctp, *txnp_ctp;
|
|
|
|
ACTIVATE_CTP(dbenv_ctp, dbenvcl_id, CT_ENV);
|
|
dbenv = (DbEnv *)dbenv_ctp->ct_anyp;
|
|
|
|
if (txnpcl_id != 0) {
|
|
ACTIVATE_CTP(txnp_ctp, txnpcl_id, CT_TXN);
|
|
txnp = (DbTxn *)txnp_ctp->ct_anyp;
|
|
} else
|
|
txnp = NULL;
|
|
|
|
ret = dbenv->dbrename(txnp, name, subdb, newname, flags);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __env_encrypt_proc */
|
|
extern "C" void
|
|
__env_encrypt_proc(
|
|
long dbenvcl_id,
|
|
char *passwd,
|
|
u_int32_t flags,
|
|
__env_encrypt_reply *replyp)
|
|
/* END __env_encrypt_proc */
|
|
{
|
|
DbEnv *dbenv;
|
|
ct_entry *dbenv_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbenv_ctp, dbenvcl_id, CT_ENV);
|
|
dbenv = (DbEnv *)dbenv_ctp->ct_anyp;
|
|
|
|
ret = dbenv->set_encrypt(passwd, flags);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __env_flags_proc */
|
|
extern "C" void
|
|
__env_flags_proc(
|
|
long dbenvcl_id,
|
|
u_int32_t flags,
|
|
u_int32_t onoff,
|
|
__env_flags_reply *replyp)
|
|
/* END __env_flags_proc */
|
|
{
|
|
DbEnv *dbenv;
|
|
ct_entry *dbenv_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbenv_ctp, dbenvcl_id, CT_ENV);
|
|
dbenv = (DbEnv *)dbenv_ctp->ct_anyp;
|
|
|
|
ret = dbenv->set_flags(flags, onoff);
|
|
if (onoff)
|
|
dbenv_ctp->ct_envdp.onflags = flags;
|
|
else
|
|
dbenv_ctp->ct_envdp.offflags = flags;
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
/* BEGIN __env_open_proc */
|
|
extern "C" void
|
|
__env_open_proc(
|
|
long dbenvcl_id,
|
|
char *home,
|
|
u_int32_t flags,
|
|
u_int32_t mode,
|
|
__env_open_reply *replyp)
|
|
/* END __env_open_proc */
|
|
{
|
|
DbEnv *dbenv;
|
|
ct_entry *dbenv_ctp, *new_ctp;
|
|
u_int32_t newflags, shareflags;
|
|
int ret;
|
|
home_entry *fullhome;
|
|
|
|
ACTIVATE_CTP(dbenv_ctp, dbenvcl_id, CT_ENV);
|
|
dbenv = (DbEnv *)dbenv_ctp->ct_anyp;
|
|
fullhome = get_home(home);
|
|
if (fullhome == NULL) {
|
|
ret = DB_NOSERVER_HOME;
|
|
goto out;
|
|
}
|
|
|
|
/*
|
|
* If they are using locking do deadlock detection for them,
|
|
* internally.
|
|
*/
|
|
if ((flags & DB_INIT_LOCK) &&
|
|
(ret = dbenv->set_lk_detect(DB_LOCK_DEFAULT)) != 0)
|
|
goto out;
|
|
|
|
if (__dbsrv_verbose) {
|
|
dbenv->set_errfile(stderr);
|
|
dbenv->set_errpfx(fullhome->home);
|
|
}
|
|
|
|
/*
|
|
* Mask off flags we ignore
|
|
*/
|
|
newflags = (flags & ~DB_SERVER_FLAGMASK);
|
|
shareflags = (newflags & DB_SERVER_ENVFLAGS);
|
|
/*
|
|
* Check now whether we can share a handle for this env.
|
|
*/
|
|
replyp->envcl_id = dbenvcl_id;
|
|
if ((new_ctp = __dbsrv_shareenv(dbenv_ctp, fullhome, shareflags))
|
|
!= NULL) {
|
|
/*
|
|
* We can share, clean up old ID, set new one.
|
|
*/
|
|
if (__dbsrv_verbose)
|
|
printf("Sharing env ID %ld\n", new_ctp->ct_id);
|
|
replyp->envcl_id = new_ctp->ct_id;
|
|
ret = __dbenv_close_int(dbenvcl_id, 0, 0);
|
|
} else {
|
|
ret = dbenv->open(fullhome->home, newflags, mode);
|
|
dbenv_ctp->ct_envdp.home = fullhome;
|
|
dbenv_ctp->ct_envdp.envflags = shareflags;
|
|
}
|
|
out: replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __env_remove_proc */
|
|
extern "C" void
|
|
__env_remove_proc(
|
|
long dbenvcl_id,
|
|
char *home,
|
|
u_int32_t flags,
|
|
__env_remove_reply *replyp)
|
|
/* END __env_remove_proc */
|
|
{
|
|
DbEnv *dbenv;
|
|
ct_entry *dbenv_ctp;
|
|
int ret;
|
|
home_entry *fullhome;
|
|
|
|
ACTIVATE_CTP(dbenv_ctp, dbenvcl_id, CT_ENV);
|
|
dbenv = (DbEnv *)dbenv_ctp->ct_anyp;
|
|
fullhome = get_home(home);
|
|
if (fullhome == NULL) {
|
|
replyp->status = DB_NOSERVER_HOME;
|
|
return;
|
|
}
|
|
|
|
ret = dbenv->remove(fullhome->home, flags);
|
|
__dbdel_ctp(dbenv_ctp);
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __txn_abort_proc */
|
|
extern "C" void
|
|
__txn_abort_proc(
|
|
long txnpcl_id,
|
|
__txn_abort_reply *replyp)
|
|
/* END __txn_abort_proc */
|
|
{
|
|
DbTxn *txnp;
|
|
ct_entry *txnp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(txnp_ctp, txnpcl_id, CT_TXN);
|
|
txnp = (DbTxn *)txnp_ctp->ct_anyp;
|
|
|
|
ret = txnp->abort();
|
|
__dbdel_ctp(txnp_ctp);
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __txn_begin_proc */
|
|
extern "C" void
|
|
__txn_begin_proc(
|
|
long dbenvcl_id,
|
|
long parentcl_id,
|
|
u_int32_t flags,
|
|
__txn_begin_reply *replyp)
|
|
/* END __txn_begin_proc */
|
|
{
|
|
DbEnv *dbenv;
|
|
DbTxn *parent, *txnp;
|
|
ct_entry *ctp, *dbenv_ctp, *parent_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbenv_ctp, dbenvcl_id, CT_ENV);
|
|
dbenv = (DbEnv *)dbenv_ctp->ct_anyp;
|
|
parent_ctp = NULL;
|
|
|
|
ctp = new_ct_ent(&replyp->status);
|
|
if (ctp == NULL)
|
|
return;
|
|
|
|
if (parentcl_id != 0) {
|
|
ACTIVATE_CTP(parent_ctp, parentcl_id, CT_TXN);
|
|
parent = (DbTxn *)parent_ctp->ct_anyp;
|
|
ctp->ct_activep = parent_ctp->ct_activep;
|
|
} else
|
|
parent = NULL;
|
|
|
|
ret = dbenv->txn_begin(parent, &txnp, flags);
|
|
if (ret == 0) {
|
|
ctp->ct_txnp = txnp;
|
|
ctp->ct_type = CT_TXN;
|
|
ctp->ct_parent = parent_ctp;
|
|
ctp->ct_envparent = dbenv_ctp;
|
|
replyp->txnidcl_id = ctp->ct_id;
|
|
__dbsrv_settimeout(ctp, dbenv_ctp->ct_timeout);
|
|
__dbsrv_active(ctp);
|
|
} else
|
|
__dbclear_ctp(ctp);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __txn_commit_proc */
|
|
extern "C" void
|
|
__txn_commit_proc(
|
|
long txnpcl_id,
|
|
u_int32_t flags,
|
|
__txn_commit_reply *replyp)
|
|
/* END __txn_commit_proc */
|
|
{
|
|
DbTxn *txnp;
|
|
ct_entry *txnp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(txnp_ctp, txnpcl_id, CT_TXN);
|
|
txnp = (DbTxn *)txnp_ctp->ct_anyp;
|
|
|
|
ret = txnp->commit(flags);
|
|
__dbdel_ctp(txnp_ctp);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __txn_discard_proc */
|
|
extern "C" void
|
|
__txn_discard_proc(
|
|
long txnpcl_id,
|
|
u_int32_t flags,
|
|
__txn_discard_reply *replyp)
|
|
/* END __txn_discard_proc */
|
|
{
|
|
DbTxn *txnp;
|
|
ct_entry *txnp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(txnp_ctp, txnpcl_id, CT_TXN);
|
|
txnp = (DbTxn *)txnp_ctp->ct_anyp;
|
|
|
|
ret = txnp->discard(flags);
|
|
__dbdel_ctp(txnp_ctp);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __txn_prepare_proc */
|
|
extern "C" void
|
|
__txn_prepare_proc(
|
|
long txnpcl_id,
|
|
u_int8_t *gid,
|
|
__txn_prepare_reply *replyp)
|
|
/* END __txn_prepare_proc */
|
|
{
|
|
DbTxn *txnp;
|
|
ct_entry *txnp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(txnp_ctp, txnpcl_id, CT_TXN);
|
|
txnp = (DbTxn *)txnp_ctp->ct_anyp;
|
|
|
|
ret = txnp->prepare(gid);
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __txn_recover_proc */
|
|
extern "C" void
|
|
__txn_recover_proc(
|
|
long dbenvcl_id,
|
|
u_int32_t count,
|
|
u_int32_t flags,
|
|
__txn_recover_reply *replyp,
|
|
int * freep)
|
|
/* END __txn_recover_proc */
|
|
{
|
|
DbEnv *dbenv;
|
|
DbPreplist *dbprep, *p;
|
|
ct_entry *dbenv_ctp, *ctp;
|
|
long erri, i, retcount;
|
|
u_int32_t *txnidp;
|
|
int ret;
|
|
char *gid;
|
|
|
|
ACTIVATE_CTP(dbenv_ctp, dbenvcl_id, CT_ENV);
|
|
dbenv = (DbEnv *)dbenv_ctp->ct_anyp;
|
|
*freep = 0;
|
|
|
|
if ((ret =
|
|
__os_malloc(dbenv->get_DB_ENV(), count * sizeof(DbPreplist), &dbprep)) != 0)
|
|
goto out;
|
|
if ((ret =
|
|
dbenv->txn_recover(dbprep, count, &retcount, flags)) != 0)
|
|
goto out;
|
|
/*
|
|
* If there is nothing, success, but it's easy.
|
|
*/
|
|
replyp->retcount = retcount; // TODO: fix C++ txn_recover
|
|
if (retcount == 0) {
|
|
replyp->txn.txn_val = NULL;
|
|
replyp->txn.txn_len = 0;
|
|
replyp->gid.gid_val = NULL;
|
|
replyp->gid.gid_len = 0;
|
|
}
|
|
|
|
/*
|
|
* We have our txn list. Now we need to allocate the space for
|
|
* the txn ID array and the GID array and set them up.
|
|
*/
|
|
if ((ret = __os_calloc(dbenv->get_DB_ENV(), retcount, sizeof(u_int32_t),
|
|
&replyp->txn.txn_val)) != 0)
|
|
goto out;
|
|
replyp->txn.txn_len = retcount * sizeof(u_int32_t);
|
|
if ((ret = __os_calloc(dbenv->get_DB_ENV(), retcount, DB_XIDDATASIZE,
|
|
&replyp->gid.gid_val)) != 0) {
|
|
__os_free(dbenv->get_DB_ENV(), replyp->txn.txn_val);
|
|
goto out;
|
|
}
|
|
replyp->gid.gid_len = retcount * DB_XIDDATASIZE;
|
|
|
|
/*
|
|
* Now walk through our results, creating parallel arrays
|
|
* to send back. For each entry we need to create a new
|
|
* txn ctp and then fill in the array info.
|
|
*/
|
|
i = 0;
|
|
p = dbprep;
|
|
gid = replyp->gid.gid_val;
|
|
txnidp = replyp->txn.txn_val;
|
|
while (i++ < retcount) {
|
|
ctp = new_ct_ent(&ret);
|
|
if (ret != 0) {
|
|
i--;
|
|
goto out2;
|
|
}
|
|
ctp->ct_txnp = p->txn;
|
|
ctp->ct_type = CT_TXN;
|
|
ctp->ct_parent = NULL;
|
|
ctp->ct_envparent = dbenv_ctp;
|
|
__dbsrv_settimeout(ctp, dbenv_ctp->ct_timeout);
|
|
__dbsrv_active(ctp);
|
|
|
|
*txnidp = ctp->ct_id;
|
|
memcpy(gid, p->gid, DB_XIDDATASIZE);
|
|
|
|
p++;
|
|
txnidp++;
|
|
gid += DB_XIDDATASIZE;
|
|
}
|
|
/*
|
|
* If we get here, we have success and we have to set freep
|
|
* so it'll get properly freed next time.
|
|
*/
|
|
*freep = 1;
|
|
out:
|
|
if (dbprep != NULL)
|
|
__os_free(dbenv->get_DB_ENV(), dbprep);
|
|
replyp->status = ret;
|
|
return;
|
|
out2:
|
|
/*
|
|
* We had an error in the middle of creating our new txn
|
|
* ct entries. We have to unwind all that we have done. Ugh.
|
|
*/
|
|
for (txnidp = replyp->txn.txn_val, erri = 0;
|
|
erri < i; erri++, txnidp++) {
|
|
ctp = get_tableent(*txnidp);
|
|
__dbclear_ctp(ctp);
|
|
}
|
|
__os_free(dbenv->get_DB_ENV(), replyp->txn.txn_val);
|
|
__os_free(dbenv->get_DB_ENV(), replyp->gid.gid_val);
|
|
__os_free(dbenv->get_DB_ENV(), dbprep);
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_bt_maxkey_proc */
|
|
extern "C" void
|
|
__db_bt_maxkey_proc(
|
|
long dbpcl_id,
|
|
u_int32_t maxkey,
|
|
__db_bt_maxkey_reply *replyp)
|
|
/* END __db_bt_maxkey_proc */
|
|
{
|
|
Db *dbp;
|
|
ct_entry *dbp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
|
|
ret = dbp->set_bt_maxkey(maxkey);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_associate_proc */
|
|
extern "C" void
|
|
__db_associate_proc(
|
|
long dbpcl_id,
|
|
long txnpcl_id,
|
|
long sdbpcl_id,
|
|
u_int32_t flags,
|
|
__db_associate_reply *replyp)
|
|
/* END __db_associate_proc */
|
|
{
|
|
Db *dbp, *sdbp;
|
|
DbTxn *txnp;
|
|
ct_entry *dbp_ctp, *sdbp_ctp, *txnp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
ACTIVATE_CTP(sdbp_ctp, sdbpcl_id, CT_DB);
|
|
sdbp = (Db *)sdbp_ctp->ct_anyp;
|
|
if (txnpcl_id != 0) {
|
|
ACTIVATE_CTP(txnp_ctp, txnpcl_id, CT_TXN);
|
|
txnp = (DbTxn *)txnp_ctp->ct_anyp;
|
|
} else
|
|
txnp = NULL;
|
|
|
|
/*
|
|
* We do not support DB_CREATE for associate. Users
|
|
* can only access secondary indices on a read-only basis,
|
|
* so whatever they are looking for needs to be there already.
|
|
*/
|
|
if (flags != 0)
|
|
ret = EINVAL;
|
|
else
|
|
ret = dbp->associate(txnp, sdbp, NULL, flags);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_bt_minkey_proc */
|
|
extern "C" void
|
|
__db_bt_minkey_proc(
|
|
long dbpcl_id,
|
|
u_int32_t minkey,
|
|
__db_bt_minkey_reply *replyp)
|
|
/* END __db_bt_minkey_proc */
|
|
{
|
|
Db *dbp;
|
|
ct_entry *dbp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
|
|
ret = dbp->set_bt_minkey(minkey);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_close_proc */
|
|
extern "C" void
|
|
__db_close_proc(
|
|
long dbpcl_id,
|
|
u_int32_t flags,
|
|
__db_close_reply *replyp)
|
|
/* END __db_close_proc */
|
|
{
|
|
ct_entry *dbp_ctp;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
replyp->status = __db_close_int(dbpcl_id, flags);
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_create_proc */
|
|
extern "C" void
|
|
__db_create_proc(
|
|
long dbenvcl_id,
|
|
u_int32_t flags,
|
|
__db_create_reply *replyp)
|
|
/* END __db_create_proc */
|
|
{
|
|
Db *dbp;
|
|
DbEnv *dbenv;
|
|
ct_entry *dbenv_ctp, *dbp_ctp;
|
|
|
|
ACTIVATE_CTP(dbenv_ctp, dbenvcl_id, CT_ENV);
|
|
dbenv = (DbEnv *)dbenv_ctp->ct_anyp;
|
|
|
|
dbp_ctp = new_ct_ent(&replyp->status);
|
|
if (dbp_ctp == NULL)
|
|
return ;
|
|
/*
|
|
* We actually require env's for databases. The client should
|
|
* have caught it, but just in case.
|
|
*/
|
|
DB_ASSERT(dbenv != NULL);
|
|
dbp = new Db(dbenv, flags);
|
|
dbp_ctp->ct_dbp = dbp;
|
|
dbp_ctp->ct_type = CT_DB;
|
|
dbp_ctp->ct_parent = dbenv_ctp;
|
|
dbp_ctp->ct_envparent = dbenv_ctp;
|
|
replyp->dbcl_id = dbp_ctp->ct_id;
|
|
replyp->status = 0;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_del_proc */
|
|
extern "C" void
|
|
__db_del_proc(
|
|
long dbpcl_id,
|
|
long txnpcl_id,
|
|
u_int32_t keydlen,
|
|
u_int32_t keydoff,
|
|
u_int32_t keyulen,
|
|
u_int32_t keyflags,
|
|
void *keydata,
|
|
u_int32_t keysize,
|
|
u_int32_t flags,
|
|
__db_del_reply *replyp)
|
|
/* END __db_del_proc */
|
|
{
|
|
Db *dbp;
|
|
DbTxn *txnp;
|
|
ct_entry *dbp_ctp, *txnp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
if (txnpcl_id != 0) {
|
|
ACTIVATE_CTP(txnp_ctp, txnpcl_id, CT_TXN);
|
|
txnp = (DbTxn *)txnp_ctp->ct_anyp;
|
|
} else
|
|
txnp = NULL;
|
|
|
|
/* Set up key */
|
|
Dbt key(keydata, keysize);
|
|
key.set_dlen(keydlen);
|
|
key.set_ulen(keyulen);
|
|
key.set_doff(keydoff);
|
|
key.set_flags(keyflags);
|
|
|
|
ret = dbp->del(txnp, &key, flags);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_encrypt_proc */
|
|
extern "C" void
|
|
__db_encrypt_proc(
|
|
long dbpcl_id,
|
|
char *passwd,
|
|
u_int32_t flags,
|
|
__db_encrypt_reply *replyp)
|
|
/* END __db_encrypt_proc */
|
|
{
|
|
Db *dbp;
|
|
ct_entry *dbp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
|
|
ret = dbp->set_encrypt(passwd, flags);
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_extentsize_proc */
|
|
extern "C" void
|
|
__db_extentsize_proc(
|
|
long dbpcl_id,
|
|
u_int32_t extentsize,
|
|
__db_extentsize_reply *replyp)
|
|
/* END __db_extentsize_proc */
|
|
{
|
|
Db *dbp;
|
|
ct_entry *dbp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
|
|
ret = dbp->set_q_extentsize(extentsize);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_flags_proc */
|
|
extern "C" void
|
|
__db_flags_proc(
|
|
long dbpcl_id,
|
|
u_int32_t flags,
|
|
__db_flags_reply *replyp)
|
|
/* END __db_flags_proc */
|
|
{
|
|
Db *dbp;
|
|
ct_entry *dbp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
|
|
ret = dbp->set_flags(flags);
|
|
dbp_ctp->ct_dbdp.setflags = flags;
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_get_proc */
|
|
extern "C" void
|
|
__db_get_proc(
|
|
long dbpcl_id,
|
|
long txnpcl_id,
|
|
u_int32_t keydlen,
|
|
u_int32_t keydoff,
|
|
u_int32_t keyulen,
|
|
u_int32_t keyflags,
|
|
void *keydata,
|
|
u_int32_t keysize,
|
|
u_int32_t datadlen,
|
|
u_int32_t datadoff,
|
|
u_int32_t dataulen,
|
|
u_int32_t dataflags,
|
|
void *datadata,
|
|
u_int32_t datasize,
|
|
u_int32_t flags,
|
|
__db_get_reply *replyp,
|
|
int * freep)
|
|
/* END __db_get_proc */
|
|
{
|
|
Db *dbp;
|
|
DbTxn *txnp;
|
|
ct_entry *dbp_ctp, *txnp_ctp;
|
|
int key_alloc, bulk_alloc, ret;
|
|
void *tmpdata;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
if (txnpcl_id != 0) {
|
|
ACTIVATE_CTP(txnp_ctp, txnpcl_id, CT_TXN);
|
|
txnp = (DbTxn *)txnp_ctp->ct_anyp;
|
|
} else
|
|
txnp = NULL;
|
|
|
|
*freep = 0;
|
|
bulk_alloc = 0;
|
|
|
|
/* Set up key and data */
|
|
Dbt key(keydata, keysize);
|
|
key.set_dlen(keydlen);
|
|
key.set_ulen(keyulen);
|
|
key.set_doff(keydoff);
|
|
/*
|
|
* Ignore memory related flags on server.
|
|
*/
|
|
key.set_flags(DB_DBT_MALLOC | (keyflags & DB_DBT_PARTIAL));
|
|
|
|
Dbt data(datadata, datasize);
|
|
data.set_dlen(datadlen);
|
|
data.set_ulen(dataulen);
|
|
data.set_doff(datadoff);
|
|
/*
|
|
* Ignore memory related flags on server.
|
|
*/
|
|
dataflags &= DB_DBT_PARTIAL;
|
|
if (flags & DB_MULTIPLE) {
|
|
if (data.get_data() == 0) {
|
|
ret = __os_umalloc(dbp->get_DB()->dbenv,
|
|
dataulen, &tmpdata);
|
|
if (ret != 0)
|
|
goto err;
|
|
data.set_data(tmpdata);
|
|
bulk_alloc = 1;
|
|
}
|
|
dataflags |= DB_DBT_USERMEM;
|
|
} else
|
|
dataflags |= DB_DBT_MALLOC;
|
|
data.set_flags(dataflags);
|
|
|
|
/* Got all our stuff, now do the get */
|
|
ret = dbp->get(txnp, &key, &data, flags);
|
|
/*
|
|
* Otherwise just status.
|
|
*/
|
|
if (ret == 0) {
|
|
/*
|
|
* XXX
|
|
* We need to xdr_free whatever we are returning, next time.
|
|
* However, DB does not allocate a new key if one was given
|
|
* and we'd be free'ing up space allocated in the request.
|
|
* So, allocate a new key/data pointer if it is the same one
|
|
* as in the request.
|
|
*/
|
|
*freep = 1;
|
|
/*
|
|
* Key
|
|
*/
|
|
key_alloc = 0;
|
|
if (key.get_data() == keydata) {
|
|
ret = __os_umalloc(dbp->get_DB()->dbenv,
|
|
key.get_size(), &replyp->keydata.keydata_val);
|
|
if (ret != 0) {
|
|
__os_ufree(dbp->get_DB()->dbenv, key.get_data());
|
|
__os_ufree(dbp->get_DB()->dbenv, data.get_data());
|
|
goto err;
|
|
}
|
|
key_alloc = 1;
|
|
memcpy(replyp->keydata.keydata_val, key.get_data(), key.get_size());
|
|
} else
|
|
replyp->keydata.keydata_val = (char *)key.get_data();
|
|
|
|
replyp->keydata.keydata_len = key.get_size();
|
|
|
|
/*
|
|
* Data
|
|
*/
|
|
if (data.get_data() == datadata) {
|
|
ret = __os_umalloc(dbp->get_DB()->dbenv,
|
|
data.get_size(), &replyp->datadata.datadata_val);
|
|
if (ret != 0) {
|
|
__os_ufree(dbp->get_DB()->dbenv, key.get_data());
|
|
__os_ufree(dbp->get_DB()->dbenv, data.get_data());
|
|
if (key_alloc)
|
|
__os_ufree(dbp->get_DB()->dbenv,
|
|
replyp->keydata.keydata_val);
|
|
goto err;
|
|
}
|
|
memcpy(replyp->datadata.datadata_val, data.get_data(),
|
|
data.get_size());
|
|
} else
|
|
replyp->datadata.datadata_val = (char *)data.get_data();
|
|
replyp->datadata.datadata_len = data.get_size();
|
|
} else {
|
|
err: replyp->keydata.keydata_val = NULL;
|
|
replyp->keydata.keydata_len = 0;
|
|
replyp->datadata.datadata_val = NULL;
|
|
replyp->datadata.datadata_len = 0;
|
|
*freep = 0;
|
|
if (bulk_alloc)
|
|
__os_ufree(dbp->get_DB()->dbenv, data.get_data());
|
|
}
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_h_ffactor_proc */
|
|
extern "C" void
|
|
__db_h_ffactor_proc(
|
|
long dbpcl_id,
|
|
u_int32_t ffactor,
|
|
__db_h_ffactor_reply *replyp)
|
|
/* END __db_h_ffactor_proc */
|
|
{
|
|
Db *dbp;
|
|
ct_entry *dbp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
|
|
ret = dbp->set_h_ffactor(ffactor);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_h_nelem_proc */
|
|
extern "C" void
|
|
__db_h_nelem_proc(
|
|
long dbpcl_id,
|
|
u_int32_t nelem,
|
|
__db_h_nelem_reply *replyp)
|
|
/* END __db_h_nelem_proc */
|
|
{
|
|
Db *dbp;
|
|
ct_entry *dbp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
|
|
ret = dbp->set_h_nelem(nelem);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_key_range_proc */
|
|
extern "C" void
|
|
__db_key_range_proc(
|
|
long dbpcl_id,
|
|
long txnpcl_id,
|
|
u_int32_t keydlen,
|
|
u_int32_t keydoff,
|
|
u_int32_t keyulen,
|
|
u_int32_t keyflags,
|
|
void *keydata,
|
|
u_int32_t keysize,
|
|
u_int32_t flags,
|
|
__db_key_range_reply *replyp)
|
|
/* END __db_key_range_proc */
|
|
{
|
|
Db *dbp;
|
|
DB_KEY_RANGE range;
|
|
DbTxn *txnp;
|
|
ct_entry *dbp_ctp, *txnp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
if (txnpcl_id != 0) {
|
|
ACTIVATE_CTP(txnp_ctp, txnpcl_id, CT_TXN);
|
|
txnp = (DbTxn *)txnp_ctp->ct_anyp;
|
|
} else
|
|
txnp = NULL;
|
|
|
|
/* Set up key */
|
|
Dbt key(keydata, keysize);
|
|
key.set_dlen(keydlen);
|
|
key.set_ulen(keyulen);
|
|
key.set_doff(keydoff);
|
|
key.set_flags(keyflags);
|
|
|
|
ret = dbp->key_range(txnp, &key, &range, flags);
|
|
|
|
replyp->status = ret;
|
|
replyp->less = range.less;
|
|
replyp->equal = range.equal;
|
|
replyp->greater = range.greater;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_lorder_proc */
|
|
extern "C" void
|
|
__db_lorder_proc(
|
|
long dbpcl_id,
|
|
u_int32_t lorder,
|
|
__db_lorder_reply *replyp)
|
|
/* END __db_lorder_proc */
|
|
{
|
|
Db *dbp;
|
|
ct_entry *dbp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
|
|
ret = dbp->set_lorder(lorder);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_open_proc */
|
|
extern "C" void
|
|
__db_open_proc(
|
|
long dbpcl_id,
|
|
long txnpcl_id,
|
|
char *name,
|
|
char *subdb,
|
|
u_int32_t type,
|
|
u_int32_t flags,
|
|
u_int32_t mode,
|
|
__db_open_reply *replyp)
|
|
/* END __db_open_proc */
|
|
{
|
|
Db *dbp;
|
|
DbTxn *txnp;
|
|
DBTYPE dbtype;
|
|
ct_entry *dbp_ctp, *new_ctp, *txnp_ctp;
|
|
int isswapped, ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
if (txnpcl_id != 0) {
|
|
ACTIVATE_CTP(txnp_ctp, txnpcl_id, CT_TXN);
|
|
txnp = (DbTxn *)txnp_ctp->ct_anyp;
|
|
} else
|
|
txnp = NULL;
|
|
|
|
replyp->dbcl_id = dbpcl_id;
|
|
if ((new_ctp = __dbsrv_sharedb(dbp_ctp, name, subdb, (DBTYPE)type, flags))
|
|
!= NULL) {
|
|
/*
|
|
* We can share, clean up old ID, set new one.
|
|
*/
|
|
if (__dbsrv_verbose)
|
|
printf("Sharing db ID %ld\n", new_ctp->ct_id);
|
|
replyp->dbcl_id = new_ctp->ct_id;
|
|
ret = __db_close_int(dbpcl_id, 0);
|
|
goto out;
|
|
}
|
|
ret = dbp->open(txnp, name, subdb, (DBTYPE)type, flags, mode);
|
|
if (ret == 0) {
|
|
(void)dbp->get_type(&dbtype);
|
|
replyp->type = dbtype;
|
|
/* XXX
|
|
* Tcl needs to peek at dbp->flags for DB_AM_DUP. Send
|
|
* this dbp's flags back.
|
|
*/
|
|
replyp->dbflags = (int) dbp->get_DB()->flags;
|
|
/*
|
|
* We need to determine the byte order of the database
|
|
* and send it back to the client. Determine it by
|
|
* the server's native order and the swapped value of
|
|
* the DB itself.
|
|
*/
|
|
(void)dbp->get_byteswapped(&isswapped);
|
|
if (__db_byteorder(NULL, 1234) == 0) {
|
|
if (isswapped == 0)
|
|
replyp->lorder = 1234;
|
|
else
|
|
replyp->lorder = 4321;
|
|
} else {
|
|
if (isswapped == 0)
|
|
replyp->lorder = 4321;
|
|
else
|
|
replyp->lorder = 1234;
|
|
}
|
|
dbp_ctp->ct_dbdp.type = dbtype;
|
|
dbp_ctp->ct_dbdp.dbflags = LF_ISSET(DB_SERVER_DBFLAGS);
|
|
if (name == NULL)
|
|
dbp_ctp->ct_dbdp.db = NULL;
|
|
else if ((ret = __os_strdup(dbp->get_DB()->dbenv, name,
|
|
&dbp_ctp->ct_dbdp.db)) != 0)
|
|
goto out;
|
|
if (subdb == NULL)
|
|
dbp_ctp->ct_dbdp.subdb = NULL;
|
|
else if ((ret = __os_strdup(dbp->get_DB()->dbenv, subdb,
|
|
&dbp_ctp->ct_dbdp.subdb)) != 0)
|
|
goto out;
|
|
}
|
|
out:
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_pagesize_proc */
|
|
extern "C" void
|
|
__db_pagesize_proc(
|
|
long dbpcl_id,
|
|
u_int32_t pagesize,
|
|
__db_pagesize_reply *replyp)
|
|
/* END __db_pagesize_proc */
|
|
{
|
|
Db *dbp;
|
|
ct_entry *dbp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
|
|
ret = dbp->set_pagesize(pagesize);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_pget_proc */
|
|
extern "C" void
|
|
__db_pget_proc(
|
|
long dbpcl_id,
|
|
long txnpcl_id,
|
|
u_int32_t skeydlen,
|
|
u_int32_t skeydoff,
|
|
u_int32_t skeyulen,
|
|
u_int32_t skeyflags,
|
|
void *skeydata,
|
|
u_int32_t skeysize,
|
|
u_int32_t pkeydlen,
|
|
u_int32_t pkeydoff,
|
|
u_int32_t pkeyulen,
|
|
u_int32_t pkeyflags,
|
|
void *pkeydata,
|
|
u_int32_t pkeysize,
|
|
u_int32_t datadlen,
|
|
u_int32_t datadoff,
|
|
u_int32_t dataulen,
|
|
u_int32_t dataflags,
|
|
void *datadata,
|
|
u_int32_t datasize,
|
|
u_int32_t flags,
|
|
__db_pget_reply *replyp,
|
|
int * freep)
|
|
/* END __db_pget_proc */
|
|
{
|
|
Db *dbp;
|
|
DbTxn *txnp;
|
|
ct_entry *dbp_ctp, *txnp_ctp;
|
|
int key_alloc, ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
if (txnpcl_id != 0) {
|
|
ACTIVATE_CTP(txnp_ctp, txnpcl_id, CT_TXN);
|
|
txnp = (DbTxn *)txnp_ctp->ct_anyp;
|
|
} else
|
|
txnp = NULL;
|
|
|
|
*freep = 0;
|
|
|
|
/*
|
|
* Ignore memory related flags on server.
|
|
*/
|
|
/* Set up key and data */
|
|
Dbt skey(skeydata, skeysize);
|
|
skey.set_dlen(skeydlen);
|
|
skey.set_ulen(skeyulen);
|
|
skey.set_doff(skeydoff);
|
|
skey.set_flags(DB_DBT_MALLOC | (skeyflags & DB_DBT_PARTIAL));
|
|
|
|
Dbt pkey(pkeydata, pkeysize);
|
|
pkey.set_dlen(pkeydlen);
|
|
pkey.set_ulen(pkeyulen);
|
|
pkey.set_doff(pkeydoff);
|
|
pkey.set_flags(DB_DBT_MALLOC | (pkeyflags & DB_DBT_PARTIAL));
|
|
|
|
Dbt data(datadata, datasize);
|
|
data.set_dlen(datadlen);
|
|
data.set_ulen(dataulen);
|
|
data.set_doff(datadoff);
|
|
data.set_flags(DB_DBT_MALLOC | (dataflags & DB_DBT_PARTIAL));
|
|
|
|
/* Got all our stuff, now do the get */
|
|
ret = dbp->pget(txnp, &skey, &pkey, &data, flags);
|
|
/*
|
|
* Otherwise just status.
|
|
*/
|
|
if (ret == 0) {
|
|
/*
|
|
* XXX
|
|
* We need to xdr_free whatever we are returning, next time.
|
|
* However, DB does not allocate a new key if one was given
|
|
* and we'd be free'ing up space allocated in the request.
|
|
* So, allocate a new key/data pointer if it is the same one
|
|
* as in the request.
|
|
*/
|
|
*freep = 1;
|
|
/*
|
|
* Key
|
|
*/
|
|
key_alloc = 0;
|
|
if (skey.get_data() == skeydata) {
|
|
ret = __os_umalloc(dbp->get_DB()->dbenv,
|
|
skey.get_size(), &replyp->skeydata.skeydata_val);
|
|
if (ret != 0) {
|
|
__os_ufree(dbp->get_DB()->dbenv, skey.get_data());
|
|
__os_ufree(dbp->get_DB()->dbenv, pkey.get_data());
|
|
__os_ufree(dbp->get_DB()->dbenv, data.get_data());
|
|
goto err;
|
|
}
|
|
key_alloc = 1;
|
|
memcpy(replyp->skeydata.skeydata_val, skey.get_data(),
|
|
skey.get_size());
|
|
} else
|
|
replyp->skeydata.skeydata_val = (char *)skey.get_data();
|
|
|
|
replyp->skeydata.skeydata_len = skey.get_size();
|
|
|
|
/*
|
|
* Primary key
|
|
*/
|
|
if (pkey.get_data() == pkeydata) {
|
|
ret = __os_umalloc(dbp->get_DB()->dbenv,
|
|
pkey.get_size(), &replyp->pkeydata.pkeydata_val);
|
|
if (ret != 0) {
|
|
__os_ufree(dbp->get_DB()->dbenv, skey.get_data());
|
|
__os_ufree(dbp->get_DB()->dbenv, pkey.get_data());
|
|
__os_ufree(dbp->get_DB()->dbenv, data.get_data());
|
|
if (key_alloc)
|
|
__os_ufree(dbp->get_DB()->dbenv,
|
|
replyp->skeydata.skeydata_val);
|
|
goto err;
|
|
}
|
|
/*
|
|
* We can set it to 2, because they cannot send the
|
|
* pkey over without sending the skey over too.
|
|
* So if they did send a pkey, they must have sent
|
|
* the skey as well.
|
|
*/
|
|
key_alloc = 2;
|
|
memcpy(replyp->pkeydata.pkeydata_val, pkey.get_data(),
|
|
pkey.get_size());
|
|
} else
|
|
replyp->pkeydata.pkeydata_val = (char *)pkey.get_data();
|
|
replyp->pkeydata.pkeydata_len = pkey.get_size();
|
|
|
|
/*
|
|
* Data
|
|
*/
|
|
if (data.get_data() == datadata) {
|
|
ret = __os_umalloc(dbp->get_DB()->dbenv,
|
|
data.get_size(), &replyp->datadata.datadata_val);
|
|
if (ret != 0) {
|
|
__os_ufree(dbp->get_DB()->dbenv, skey.get_data());
|
|
__os_ufree(dbp->get_DB()->dbenv, pkey.get_data());
|
|
__os_ufree(dbp->get_DB()->dbenv, data.get_data());
|
|
/*
|
|
* If key_alloc is 1, just skey needs to be
|
|
* freed, if key_alloc is 2, both skey and pkey
|
|
* need to be freed.
|
|
*/
|
|
if (key_alloc--)
|
|
__os_ufree(dbp->get_DB()->dbenv,
|
|
replyp->skeydata.skeydata_val);
|
|
if (key_alloc)
|
|
__os_ufree(dbp->get_DB()->dbenv,
|
|
replyp->pkeydata.pkeydata_val);
|
|
goto err;
|
|
}
|
|
memcpy(replyp->datadata.datadata_val, data.get_data(),
|
|
data.get_size());
|
|
} else
|
|
replyp->datadata.datadata_val = (char *)data.get_data();
|
|
replyp->datadata.datadata_len = data.get_size();
|
|
} else {
|
|
err: replyp->skeydata.skeydata_val = NULL;
|
|
replyp->skeydata.skeydata_len = 0;
|
|
replyp->pkeydata.pkeydata_val = NULL;
|
|
replyp->pkeydata.pkeydata_len = 0;
|
|
replyp->datadata.datadata_val = NULL;
|
|
replyp->datadata.datadata_len = 0;
|
|
*freep = 0;
|
|
}
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_put_proc */
|
|
extern "C" void
|
|
__db_put_proc(
|
|
long dbpcl_id,
|
|
long txnpcl_id,
|
|
u_int32_t keydlen,
|
|
u_int32_t keydoff,
|
|
u_int32_t keyulen,
|
|
u_int32_t keyflags,
|
|
void *keydata,
|
|
u_int32_t keysize,
|
|
u_int32_t datadlen,
|
|
u_int32_t datadoff,
|
|
u_int32_t dataulen,
|
|
u_int32_t dataflags,
|
|
void *datadata,
|
|
u_int32_t datasize,
|
|
u_int32_t flags,
|
|
__db_put_reply *replyp,
|
|
int * freep)
|
|
/* END __db_put_proc */
|
|
{
|
|
Db *dbp;
|
|
DbTxn *txnp;
|
|
ct_entry *dbp_ctp, *txnp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
if (txnpcl_id != 0) {
|
|
ACTIVATE_CTP(txnp_ctp, txnpcl_id, CT_TXN);
|
|
txnp = (DbTxn *)txnp_ctp->ct_anyp;
|
|
} else
|
|
txnp = NULL;
|
|
|
|
*freep = 0;
|
|
|
|
/* Set up key and data */
|
|
Dbt key(keydata, keysize);
|
|
key.set_dlen(keydlen);
|
|
key.set_ulen(keyulen);
|
|
key.set_doff(keydoff);
|
|
key.set_flags(DB_DBT_MALLOC | (keyflags & DB_DBT_PARTIAL));
|
|
|
|
Dbt data(datadata, datasize);
|
|
data.set_dlen(datadlen);
|
|
data.set_ulen(dataulen);
|
|
data.set_doff(datadoff);
|
|
data.set_flags(dataflags);
|
|
|
|
/* Got all our stuff, now do the put */
|
|
ret = dbp->put(txnp, &key, &data, flags);
|
|
/*
|
|
* If the client did a DB_APPEND, set up key in reply.
|
|
* Otherwise just status.
|
|
*/
|
|
if (ret == 0 && (flags == DB_APPEND)) {
|
|
/*
|
|
* XXX
|
|
* We need to xdr_free whatever we are returning, next time.
|
|
* However, DB does not allocate a new key if one was given
|
|
* and we'd be free'ing up space allocated in the request.
|
|
* So, allocate a new key/data pointer if it is the same one
|
|
* as in the request.
|
|
*/
|
|
*freep = 1;
|
|
/*
|
|
* Key
|
|
*/
|
|
if (key.get_data() == keydata) {
|
|
ret = __os_umalloc(dbp->get_DB()->dbenv,
|
|
key.get_size(), &replyp->keydata.keydata_val);
|
|
if (ret != 0) {
|
|
__os_ufree(dbp->get_DB()->dbenv, key.get_data());
|
|
goto err;
|
|
}
|
|
memcpy(replyp->keydata.keydata_val, key.get_data(), key.get_size());
|
|
} else
|
|
replyp->keydata.keydata_val = (char *)key.get_data();
|
|
|
|
replyp->keydata.keydata_len = key.get_size();
|
|
} else {
|
|
err: replyp->keydata.keydata_val = NULL;
|
|
replyp->keydata.keydata_len = 0;
|
|
*freep = 0;
|
|
}
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_re_delim_proc */
|
|
extern "C" void
|
|
__db_re_delim_proc(
|
|
long dbpcl_id,
|
|
u_int32_t delim,
|
|
__db_re_delim_reply *replyp)
|
|
/* END __db_re_delim_proc */
|
|
{
|
|
Db *dbp;
|
|
ct_entry *dbp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
|
|
ret = dbp->set_re_delim(delim);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_re_len_proc */
|
|
extern "C" void
|
|
__db_re_len_proc(
|
|
long dbpcl_id,
|
|
u_int32_t len,
|
|
__db_re_len_reply *replyp)
|
|
/* END __db_re_len_proc */
|
|
{
|
|
Db *dbp;
|
|
ct_entry *dbp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
|
|
ret = dbp->set_re_len(len);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_re_pad_proc */
|
|
extern "C" void
|
|
__db_re_pad_proc(
|
|
long dbpcl_id,
|
|
u_int32_t pad,
|
|
__db_re_pad_reply *replyp)
|
|
/* END __db_re_pad_proc */
|
|
{
|
|
Db *dbp;
|
|
ct_entry *dbp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
|
|
ret = dbp->set_re_pad(pad);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_remove_proc */
|
|
extern "C" void
|
|
__db_remove_proc(
|
|
long dbpcl_id,
|
|
char *name,
|
|
char *subdb,
|
|
u_int32_t flags,
|
|
__db_remove_reply *replyp)
|
|
/* END __db_remove_proc */
|
|
{
|
|
Db *dbp;
|
|
ct_entry *dbp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
|
|
ret = dbp->remove(name, subdb, flags);
|
|
__dbdel_ctp(dbp_ctp);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_rename_proc */
|
|
extern "C" void
|
|
__db_rename_proc(
|
|
long dbpcl_id,
|
|
char *name,
|
|
char *subdb,
|
|
char *newname,
|
|
u_int32_t flags,
|
|
__db_rename_reply *replyp)
|
|
/* END __db_rename_proc */
|
|
{
|
|
Db *dbp;
|
|
ct_entry *dbp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
|
|
ret = dbp->rename(name, subdb, newname, flags);
|
|
__dbdel_ctp(dbp_ctp);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_stat_proc */
|
|
extern "C" void
|
|
__db_stat_proc(
|
|
long dbpcl_id,
|
|
u_int32_t flags,
|
|
__db_stat_reply *replyp,
|
|
int * freep)
|
|
/* END __db_stat_proc */
|
|
{
|
|
Db *dbp;
|
|
DBTYPE type;
|
|
ct_entry *dbp_ctp;
|
|
u_int32_t *q, *p, *retsp;
|
|
int i, len, ret;
|
|
void *sp;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
|
|
ret = dbp->stat(&sp, flags);
|
|
replyp->status = ret;
|
|
if (ret != 0)
|
|
return;
|
|
/*
|
|
* We get here, we have success. Allocate an array so that
|
|
* we can use the list generator. Generate the reply, free
|
|
* up the space.
|
|
*/
|
|
/*
|
|
* XXX This assumes that all elements of all stat structures
|
|
* are u_int32_t fields. They are, currently.
|
|
*/
|
|
(void)dbp->get_type(&type);
|
|
if (type == DB_HASH)
|
|
len = sizeof(DB_HASH_STAT);
|
|
else if (type == DB_QUEUE)
|
|
len = sizeof(DB_QUEUE_STAT);
|
|
else /* BTREE or RECNO are same stats */
|
|
len = sizeof(DB_BTREE_STAT);
|
|
replyp->stats.stats_len = len / sizeof(u_int32_t);
|
|
|
|
if ((ret = __os_umalloc(dbp->get_DB()->dbenv,
|
|
len * replyp->stats.stats_len, &retsp)) != 0)
|
|
goto out;
|
|
for (i = 0, q = retsp, p = (u_int32_t *)sp; i < len;
|
|
i++, q++, p++)
|
|
*q = *p;
|
|
replyp->stats.stats_val = retsp;
|
|
__os_ufree(dbp->get_DB()->dbenv, sp);
|
|
if (ret == 0)
|
|
*freep = 1;
|
|
out:
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_sync_proc */
|
|
extern "C" void
|
|
__db_sync_proc(
|
|
long dbpcl_id,
|
|
u_int32_t flags,
|
|
__db_sync_reply *replyp)
|
|
/* END __db_sync_proc */
|
|
{
|
|
Db *dbp;
|
|
ct_entry *dbp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
|
|
ret = dbp->sync(flags);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_truncate_proc */
|
|
extern "C" void
|
|
__db_truncate_proc(
|
|
long dbpcl_id,
|
|
long txnpcl_id,
|
|
u_int32_t flags,
|
|
__db_truncate_reply *replyp)
|
|
/* END __db_truncate_proc */
|
|
{
|
|
Db *dbp;
|
|
DbTxn *txnp;
|
|
ct_entry *dbp_ctp, *txnp_ctp;
|
|
u_int32_t count;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
if (txnpcl_id != 0) {
|
|
ACTIVATE_CTP(txnp_ctp, txnpcl_id, CT_TXN);
|
|
txnp = (DbTxn *)txnp_ctp->ct_anyp;
|
|
} else
|
|
txnp = NULL;
|
|
|
|
ret = dbp->truncate(txnp, &count, flags);
|
|
replyp->status = ret;
|
|
if (ret == 0)
|
|
replyp->count = count;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_cursor_proc */
|
|
extern "C" void
|
|
__db_cursor_proc(
|
|
long dbpcl_id,
|
|
long txnpcl_id,
|
|
u_int32_t flags,
|
|
__db_cursor_reply *replyp)
|
|
/* END __db_cursor_proc */
|
|
{
|
|
Db *dbp;
|
|
Dbc *dbc;
|
|
DbTxn *txnp;
|
|
ct_entry *dbc_ctp, *env_ctp, *dbp_ctp, *txnp_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
dbc_ctp = new_ct_ent(&replyp->status);
|
|
if (dbc_ctp == NULL)
|
|
return;
|
|
|
|
if (txnpcl_id != 0) {
|
|
ACTIVATE_CTP(txnp_ctp, txnpcl_id, CT_TXN);
|
|
txnp = (DbTxn *)txnp_ctp->ct_anyp;
|
|
dbc_ctp->ct_activep = txnp_ctp->ct_activep;
|
|
} else
|
|
txnp = NULL;
|
|
|
|
if ((ret = dbp->cursor(txnp, &dbc, flags)) == 0) {
|
|
dbc_ctp->ct_dbc = dbc;
|
|
dbc_ctp->ct_type = CT_CURSOR;
|
|
dbc_ctp->ct_parent = dbp_ctp;
|
|
env_ctp = dbp_ctp->ct_envparent;
|
|
dbc_ctp->ct_envparent = env_ctp;
|
|
__dbsrv_settimeout(dbc_ctp, env_ctp->ct_timeout);
|
|
__dbsrv_active(dbc_ctp);
|
|
replyp->dbcidcl_id = dbc_ctp->ct_id;
|
|
} else
|
|
__dbclear_ctp(dbc_ctp);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __db_join_proc */
|
|
extern "C" void
|
|
__db_join_proc(
|
|
long dbpcl_id,
|
|
u_int32_t *curs,
|
|
u_int32_t curslen,
|
|
u_int32_t flags,
|
|
__db_join_reply *replyp)
|
|
/* END __db_join_proc */
|
|
{
|
|
Db *dbp;
|
|
Dbc **jcurs, **c;
|
|
Dbc *dbc;
|
|
ct_entry *dbc_ctp, *ctp, *dbp_ctp;
|
|
size_t size;
|
|
u_int32_t *cl, i;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbp_ctp, dbpcl_id, CT_DB);
|
|
dbp = (Db *)dbp_ctp->ct_anyp;
|
|
|
|
dbc_ctp = new_ct_ent(&replyp->status);
|
|
if (dbc_ctp == NULL)
|
|
return;
|
|
|
|
size = (curslen + 1) * sizeof(Dbc *);
|
|
if ((ret = __os_calloc(dbp->get_DB()->dbenv,
|
|
curslen + 1, sizeof(Dbc *), &jcurs)) != 0) {
|
|
replyp->status = ret;
|
|
__dbclear_ctp(dbc_ctp);
|
|
return;
|
|
}
|
|
/*
|
|
* If our curslist has a parent txn, we need to use it too
|
|
* for the activity timeout. All cursors must be part of
|
|
* the same transaction, so just check the first.
|
|
*/
|
|
ctp = get_tableent(*curs);
|
|
DB_ASSERT(ctp->ct_type == CT_CURSOR);
|
|
/*
|
|
* If we are using a transaction, set the join activity timer
|
|
* to point to the parent transaction.
|
|
*/
|
|
if (ctp->ct_activep != &ctp->ct_active)
|
|
dbc_ctp->ct_activep = ctp->ct_activep;
|
|
for (i = 0, cl = curs, c = jcurs; i < curslen; i++, cl++, c++) {
|
|
ctp = get_tableent(*cl);
|
|
if (ctp == NULL) {
|
|
replyp->status = DB_NOSERVER_ID;
|
|
goto out;
|
|
}
|
|
/*
|
|
* If we are using a txn, the join cursor points to the
|
|
* transaction timeout. If we are not using a transaction,
|
|
* then all the curslist cursors must point to the join
|
|
* cursor's timeout so that we do not timeout any of the
|
|
* curlist cursors while the join cursor is active.
|
|
* Change the type of the curslist ctps to CT_JOIN so that
|
|
* we know they are part of a join list and we can distinguish
|
|
* them and later restore them when the join cursor is closed.
|
|
*/
|
|
DB_ASSERT(ctp->ct_type == CT_CURSOR);
|
|
ctp->ct_type |= CT_JOIN;
|
|
ctp->ct_origp = ctp->ct_activep;
|
|
/*
|
|
* Setting this to the ct_active field of the dbc_ctp is
|
|
* really just a way to distinguish which join dbc this
|
|
* cursor is part of. The ct_activep of this cursor is
|
|
* not used at all during its lifetime as part of a join
|
|
* cursor.
|
|
*/
|
|
ctp->ct_activep = &dbc_ctp->ct_active;
|
|
*c = ctp->ct_dbc;
|
|
}
|
|
*c = NULL;
|
|
if ((ret = dbp->join(jcurs, &dbc, flags)) == 0) {
|
|
dbc_ctp->ct_dbc = dbc;
|
|
dbc_ctp->ct_type = (CT_JOINCUR | CT_CURSOR);
|
|
dbc_ctp->ct_parent = dbp_ctp;
|
|
dbc_ctp->ct_envparent = dbp_ctp->ct_envparent;
|
|
__dbsrv_settimeout(dbc_ctp, dbp_ctp->ct_envparent->ct_timeout);
|
|
__dbsrv_active(dbc_ctp);
|
|
replyp->dbcidcl_id = dbc_ctp->ct_id;
|
|
} else {
|
|
__dbclear_ctp(dbc_ctp);
|
|
/*
|
|
* If we get an error, undo what we did above to any cursors.
|
|
*/
|
|
for (cl = curs; *cl != 0; cl++) {
|
|
ctp = get_tableent(*cl);
|
|
ctp->ct_type = CT_CURSOR;
|
|
ctp->ct_activep = ctp->ct_origp;
|
|
}
|
|
}
|
|
|
|
replyp->status = ret;
|
|
out:
|
|
__os_free(dbp->get_DB()->dbenv, jcurs);
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __dbc_close_proc */
|
|
extern "C" void
|
|
__dbc_close_proc(
|
|
long dbccl_id,
|
|
__dbc_close_reply *replyp)
|
|
/* END __dbc_close_proc */
|
|
{
|
|
ct_entry *dbc_ctp;
|
|
|
|
ACTIVATE_CTP(dbc_ctp, dbccl_id, CT_CURSOR);
|
|
replyp->status = __dbc_close_int(dbc_ctp);
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __dbc_count_proc */
|
|
extern "C" void
|
|
__dbc_count_proc(
|
|
long dbccl_id,
|
|
u_int32_t flags,
|
|
__dbc_count_reply *replyp)
|
|
/* END __dbc_count_proc */
|
|
{
|
|
Dbc *dbc;
|
|
ct_entry *dbc_ctp;
|
|
db_recno_t num;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbc_ctp, dbccl_id, CT_CURSOR);
|
|
dbc = (Dbc *)dbc_ctp->ct_anyp;
|
|
|
|
ret = dbc->count(&num, flags);
|
|
replyp->status = ret;
|
|
if (ret == 0)
|
|
replyp->dupcount = num;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __dbc_del_proc */
|
|
extern "C" void
|
|
__dbc_del_proc(
|
|
long dbccl_id,
|
|
u_int32_t flags,
|
|
__dbc_del_reply *replyp)
|
|
/* END __dbc_del_proc */
|
|
{
|
|
Dbc *dbc;
|
|
ct_entry *dbc_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbc_ctp, dbccl_id, CT_CURSOR);
|
|
dbc = (Dbc *)dbc_ctp->ct_anyp;
|
|
|
|
ret = dbc->del(flags);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __dbc_dup_proc */
|
|
extern "C" void
|
|
__dbc_dup_proc(
|
|
long dbccl_id,
|
|
u_int32_t flags,
|
|
__dbc_dup_reply *replyp)
|
|
/* END __dbc_dup_proc */
|
|
{
|
|
Dbc *dbc, *newdbc;
|
|
ct_entry *dbc_ctp, *new_ctp;
|
|
int ret;
|
|
|
|
ACTIVATE_CTP(dbc_ctp, dbccl_id, CT_CURSOR);
|
|
dbc = (Dbc *)dbc_ctp->ct_anyp;
|
|
|
|
new_ctp = new_ct_ent(&replyp->status);
|
|
if (new_ctp == NULL)
|
|
return;
|
|
|
|
if ((ret = dbc->dup(&newdbc, flags)) == 0) {
|
|
new_ctp->ct_dbc = newdbc;
|
|
new_ctp->ct_type = CT_CURSOR;
|
|
new_ctp->ct_parent = dbc_ctp->ct_parent;
|
|
new_ctp->ct_envparent = dbc_ctp->ct_envparent;
|
|
/*
|
|
* If our cursor has a parent txn, we need to use it too.
|
|
*/
|
|
if (dbc_ctp->ct_activep != &dbc_ctp->ct_active)
|
|
new_ctp->ct_activep = dbc_ctp->ct_activep;
|
|
__dbsrv_settimeout(new_ctp, dbc_ctp->ct_timeout);
|
|
__dbsrv_active(new_ctp);
|
|
replyp->dbcidcl_id = new_ctp->ct_id;
|
|
} else
|
|
__dbclear_ctp(new_ctp);
|
|
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __dbc_get_proc */
|
|
extern "C" void
|
|
__dbc_get_proc(
|
|
long dbccl_id,
|
|
u_int32_t keydlen,
|
|
u_int32_t keydoff,
|
|
u_int32_t keyulen,
|
|
u_int32_t keyflags,
|
|
void *keydata,
|
|
u_int32_t keysize,
|
|
u_int32_t datadlen,
|
|
u_int32_t datadoff,
|
|
u_int32_t dataulen,
|
|
u_int32_t dataflags,
|
|
void *datadata,
|
|
u_int32_t datasize,
|
|
u_int32_t flags,
|
|
__dbc_get_reply *replyp,
|
|
int * freep)
|
|
/* END __dbc_get_proc */
|
|
{
|
|
Dbc *dbc;
|
|
DbEnv *dbenv;
|
|
ct_entry *dbc_ctp;
|
|
int key_alloc, bulk_alloc, ret;
|
|
void *tmpdata;
|
|
|
|
ACTIVATE_CTP(dbc_ctp, dbccl_id, CT_CURSOR);
|
|
dbc = (Dbc *)dbc_ctp->ct_anyp;
|
|
dbenv = DbEnv::get_DbEnv(((DBC *)dbc)->dbp->dbenv);
|
|
|
|
*freep = 0;
|
|
bulk_alloc = 0;
|
|
|
|
/* Set up key and data */
|
|
Dbt key(keydata, keysize);
|
|
key.set_dlen(keydlen);
|
|
key.set_ulen(keyulen);
|
|
key.set_doff(keydoff);
|
|
key.set_flags(DB_DBT_MALLOC | (keyflags & DB_DBT_PARTIAL));
|
|
|
|
Dbt data(datadata, datasize);
|
|
data.set_dlen(datadlen);
|
|
data.set_ulen(dataulen);
|
|
data.set_doff(datadoff);
|
|
dataflags &= DB_DBT_PARTIAL;
|
|
if (flags & DB_MULTIPLE || flags & DB_MULTIPLE_KEY) {
|
|
if (data.get_data() == NULL) {
|
|
ret = __os_umalloc(dbenv->get_DB_ENV(),
|
|
data.get_ulen(), &tmpdata);
|
|
if (ret != 0)
|
|
goto err;
|
|
data.set_data(tmpdata);
|
|
bulk_alloc = 1;
|
|
}
|
|
dataflags |= DB_DBT_USERMEM;
|
|
} else
|
|
dataflags |= DB_DBT_MALLOC;
|
|
data.set_flags(dataflags);
|
|
|
|
/* Got all our stuff, now do the get */
|
|
ret = dbc->get(&key, &data, flags);
|
|
|
|
/*
|
|
* Otherwise just status.
|
|
*/
|
|
if (ret == 0) {
|
|
/*
|
|
* XXX
|
|
* We need to xdr_free whatever we are returning, next time.
|
|
* However, DB does not allocate a new key if one was given
|
|
* and we'd be free'ing up space allocated in the request.
|
|
* So, allocate a new key/data pointer if it is the same one
|
|
* as in the request.
|
|
*/
|
|
*freep = 1;
|
|
/*
|
|
* Key
|
|
*/
|
|
key_alloc = 0;
|
|
if (key.get_data() == keydata) {
|
|
ret = __os_umalloc(dbenv->get_DB_ENV(), key.get_size(),
|
|
&replyp->keydata.keydata_val);
|
|
if (ret != 0) {
|
|
__os_ufree(dbenv->get_DB_ENV(), key.get_data());
|
|
__os_ufree(dbenv->get_DB_ENV(), data.get_data());
|
|
goto err;
|
|
}
|
|
key_alloc = 1;
|
|
memcpy(replyp->keydata.keydata_val, key.get_data(), key.get_size());
|
|
} else
|
|
replyp->keydata.keydata_val = (char *)key.get_data();
|
|
|
|
replyp->keydata.keydata_len = key.get_size();
|
|
|
|
/*
|
|
* Data
|
|
*/
|
|
if (data.get_data() == datadata) {
|
|
ret = __os_umalloc(dbenv->get_DB_ENV(), data.get_size(),
|
|
&replyp->datadata.datadata_val);
|
|
if (ret != 0) {
|
|
__os_ufree(dbenv->get_DB_ENV(), key.get_data());
|
|
__os_ufree(dbenv->get_DB_ENV(), data.get_data());
|
|
if (key_alloc)
|
|
__os_ufree(dbenv->get_DB_ENV(),
|
|
replyp->keydata.keydata_val);
|
|
goto err;
|
|
}
|
|
memcpy(replyp->datadata.datadata_val, data.get_data(),
|
|
data.get_size());
|
|
} else
|
|
replyp->datadata.datadata_val = (char *)data.get_data();
|
|
replyp->datadata.datadata_len = data.get_size();
|
|
} else {
|
|
err: replyp->keydata.keydata_val = NULL;
|
|
replyp->keydata.keydata_len = 0;
|
|
replyp->datadata.datadata_val = NULL;
|
|
replyp->datadata.datadata_len = 0;
|
|
*freep = 0;
|
|
if (bulk_alloc)
|
|
__os_ufree(dbenv->get_DB_ENV(), data.get_data());
|
|
}
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __dbc_pget_proc */
|
|
extern "C" void
|
|
__dbc_pget_proc(
|
|
long dbccl_id,
|
|
u_int32_t skeydlen,
|
|
u_int32_t skeydoff,
|
|
u_int32_t skeyulen,
|
|
u_int32_t skeyflags,
|
|
void *skeydata,
|
|
u_int32_t skeysize,
|
|
u_int32_t pkeydlen,
|
|
u_int32_t pkeydoff,
|
|
u_int32_t pkeyulen,
|
|
u_int32_t pkeyflags,
|
|
void *pkeydata,
|
|
u_int32_t pkeysize,
|
|
u_int32_t datadlen,
|
|
u_int32_t datadoff,
|
|
u_int32_t dataulen,
|
|
u_int32_t dataflags,
|
|
void *datadata,
|
|
u_int32_t datasize,
|
|
u_int32_t flags,
|
|
__dbc_pget_reply *replyp,
|
|
int * freep)
|
|
/* END __dbc_pget_proc */
|
|
{
|
|
Dbc *dbc;
|
|
DbEnv *dbenv;
|
|
ct_entry *dbc_ctp;
|
|
int key_alloc, ret;
|
|
|
|
ACTIVATE_CTP(dbc_ctp, dbccl_id, CT_CURSOR);
|
|
dbc = (Dbc *)dbc_ctp->ct_anyp;
|
|
dbenv = DbEnv::get_DbEnv(((DBC *)dbc)->dbp->dbenv);
|
|
|
|
*freep = 0;
|
|
|
|
/*
|
|
* Ignore memory related flags on server.
|
|
*/
|
|
/* Set up key and data */
|
|
Dbt skey(skeydata, skeysize);
|
|
skey.set_dlen(skeydlen);
|
|
skey.set_ulen(skeyulen);
|
|
skey.set_doff(skeydoff);
|
|
skey.set_flags(DB_DBT_MALLOC | (skeyflags & DB_DBT_PARTIAL));
|
|
|
|
Dbt pkey(pkeydata, pkeysize);
|
|
pkey.set_dlen(pkeydlen);
|
|
pkey.set_ulen(pkeyulen);
|
|
pkey.set_doff(pkeydoff);
|
|
pkey.set_flags(DB_DBT_MALLOC | (pkeyflags & DB_DBT_PARTIAL));
|
|
|
|
Dbt data(datadata, datasize);
|
|
data.set_dlen(datadlen);
|
|
data.set_ulen(dataulen);
|
|
data.set_doff(datadoff);
|
|
data.set_flags(DB_DBT_MALLOC | (dataflags & DB_DBT_PARTIAL));
|
|
|
|
/* Got all our stuff, now do the get */
|
|
ret = dbc->pget(&skey, &pkey, &data, flags);
|
|
/*
|
|
* Otherwise just status.
|
|
*/
|
|
if (ret == 0) {
|
|
/*
|
|
* XXX
|
|
* We need to xdr_free whatever we are returning, next time.
|
|
* However, DB does not allocate a new key if one was given
|
|
* and we'd be free'ing up space allocated in the request.
|
|
* So, allocate a new key/data pointer if it is the same one
|
|
* as in the request.
|
|
*/
|
|
*freep = 1;
|
|
/*
|
|
* Key
|
|
*/
|
|
key_alloc = 0;
|
|
if (skey.get_data() == skeydata) {
|
|
ret = __os_umalloc(dbenv->get_DB_ENV(),
|
|
skey.get_size(), &replyp->skeydata.skeydata_val);
|
|
if (ret != 0) {
|
|
__os_ufree(dbenv->get_DB_ENV(), skey.get_data());
|
|
__os_ufree(dbenv->get_DB_ENV(), pkey.get_data());
|
|
__os_ufree(dbenv->get_DB_ENV(), data.get_data());
|
|
goto err;
|
|
}
|
|
key_alloc = 1;
|
|
memcpy(replyp->skeydata.skeydata_val, skey.get_data(),
|
|
skey.get_size());
|
|
} else
|
|
replyp->skeydata.skeydata_val = (char *)skey.get_data();
|
|
replyp->skeydata.skeydata_len = skey.get_size();
|
|
|
|
/*
|
|
* Primary key
|
|
*/
|
|
if (pkey.get_data() == pkeydata) {
|
|
ret = __os_umalloc(dbenv->get_DB_ENV(),
|
|
pkey.get_size(), &replyp->pkeydata.pkeydata_val);
|
|
if (ret != 0) {
|
|
__os_ufree(dbenv->get_DB_ENV(), skey.get_data());
|
|
__os_ufree(dbenv->get_DB_ENV(), pkey.get_data());
|
|
__os_ufree(dbenv->get_DB_ENV(), data.get_data());
|
|
if (key_alloc)
|
|
__os_ufree(dbenv->get_DB_ENV(),
|
|
replyp->skeydata.skeydata_val);
|
|
goto err;
|
|
}
|
|
/*
|
|
* We can set it to 2, because they cannot send the
|
|
* pkey over without sending the skey over too.
|
|
* So if they did send a pkey, they must have sent
|
|
* the skey as well.
|
|
*/
|
|
key_alloc = 2;
|
|
memcpy(replyp->pkeydata.pkeydata_val, pkey.get_data(),
|
|
pkey.get_size());
|
|
} else
|
|
replyp->pkeydata.pkeydata_val = (char *)pkey.get_data();
|
|
replyp->pkeydata.pkeydata_len = pkey.get_size();
|
|
|
|
/*
|
|
* Data
|
|
*/
|
|
if (data.get_data() == datadata) {
|
|
ret = __os_umalloc(dbenv->get_DB_ENV(),
|
|
data.get_size(), &replyp->datadata.datadata_val);
|
|
if (ret != 0) {
|
|
__os_ufree(dbenv->get_DB_ENV(), skey.get_data());
|
|
__os_ufree(dbenv->get_DB_ENV(), pkey.get_data());
|
|
__os_ufree(dbenv->get_DB_ENV(), data.get_data());
|
|
/*
|
|
* If key_alloc is 1, just skey needs to be
|
|
* freed, if key_alloc is 2, both skey and pkey
|
|
* need to be freed.
|
|
*/
|
|
if (key_alloc--)
|
|
__os_ufree(dbenv->get_DB_ENV(),
|
|
replyp->skeydata.skeydata_val);
|
|
if (key_alloc)
|
|
__os_ufree(dbenv->get_DB_ENV(),
|
|
replyp->pkeydata.pkeydata_val);
|
|
goto err;
|
|
}
|
|
memcpy(replyp->datadata.datadata_val, data.get_data(),
|
|
data.get_size());
|
|
} else
|
|
replyp->datadata.datadata_val = (char *)data.get_data();
|
|
replyp->datadata.datadata_len = data.get_size();
|
|
} else {
|
|
err: replyp->skeydata.skeydata_val = NULL;
|
|
replyp->skeydata.skeydata_len = 0;
|
|
replyp->pkeydata.pkeydata_val = NULL;
|
|
replyp->pkeydata.pkeydata_len = 0;
|
|
replyp->datadata.datadata_val = NULL;
|
|
replyp->datadata.datadata_len = 0;
|
|
*freep = 0;
|
|
}
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
|
|
/* BEGIN __dbc_put_proc */
|
|
extern "C" void
|
|
__dbc_put_proc(
|
|
long dbccl_id,
|
|
u_int32_t keydlen,
|
|
u_int32_t keydoff,
|
|
u_int32_t keyulen,
|
|
u_int32_t keyflags,
|
|
void *keydata,
|
|
u_int32_t keysize,
|
|
u_int32_t datadlen,
|
|
u_int32_t datadoff,
|
|
u_int32_t dataulen,
|
|
u_int32_t dataflags,
|
|
void *datadata,
|
|
u_int32_t datasize,
|
|
u_int32_t flags,
|
|
__dbc_put_reply *replyp,
|
|
int * freep)
|
|
/* END __dbc_put_proc */
|
|
{
|
|
Db *dbp;
|
|
Dbc *dbc;
|
|
ct_entry *dbc_ctp;
|
|
int ret;
|
|
DBTYPE dbtype;
|
|
|
|
ACTIVATE_CTP(dbc_ctp, dbccl_id, CT_CURSOR);
|
|
dbc = (Dbc *)dbc_ctp->ct_anyp;
|
|
dbp = (Db *)dbc_ctp->ct_parent->ct_anyp;
|
|
|
|
/* Set up key and data */
|
|
Dbt key(keydata, keysize);
|
|
key.set_dlen(keydlen);
|
|
key.set_ulen(keyulen);
|
|
key.set_doff(keydoff);
|
|
/*
|
|
* Ignore memory related flags on server.
|
|
*/
|
|
key.set_flags(DB_DBT_MALLOC | (keyflags & DB_DBT_PARTIAL));
|
|
|
|
Dbt data(datadata, datasize);
|
|
data.set_dlen(datadlen);
|
|
data.set_ulen(dataulen);
|
|
data.set_doff(datadoff);
|
|
data.set_flags(dataflags);
|
|
|
|
/* Got all our stuff, now do the put */
|
|
ret = dbc->put(&key, &data, flags);
|
|
|
|
*freep = 0;
|
|
replyp->keydata.keydata_val = NULL;
|
|
replyp->keydata.keydata_len = 0;
|
|
if (ret == 0 && (flags == DB_AFTER || flags == DB_BEFORE)) {
|
|
ret = dbp->get_type(&dbtype);
|
|
if (ret == 0 && dbtype == DB_RECNO) {
|
|
/*
|
|
* We need to xdr_free whatever we are returning, next time.
|
|
*/
|
|
replyp->keydata.keydata_val = (char *)key.get_data();
|
|
replyp->keydata.keydata_len = key.get_size();
|
|
}
|
|
}
|
|
replyp->status = ret;
|
|
return;
|
|
}
|
|
#endif /* HAVE_RPC */
|