ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/BDB/BDB.xs
(Generate patch)

Comparing BDB/BDB.xs (file contents):
Revision 1.5 by root, Mon Feb 5 23:46:15 2007 UTC vs.
Revision 1.9 by root, Sun Feb 11 22:38:37 2007 UTC

40# else 40# else
41# define WORDACCESS_UNSAFE 1 41# define WORDACCESS_UNSAFE 1
42# endif 42# endif
43#endif 43#endif
44 44
45typedef DB_ENV DB_ENV_ornull; 45typedef DB_ENV DB_ENV_ornull;
46typedef DB_TXN DB_TXN_ornull; 46typedef DB_TXN DB_TXN_ornull;
47typedef DBC DBC_ornull; 47typedef DBC DBC_ornull;
48typedef DB DB_ornull; 48typedef DB DB_ornull;
49typedef DB_SEQUENCE DB_SEQUENCE_ornull;
49 50
50typedef SV SV8; /* byte-sv, used for argument-checking */ 51typedef SV SV8; /* byte-sv, used for argument-checking */
51typedef char *octetstring; 52typedef char *octetstring;
52 53
53static SV *prepare_cb; 54static SV *prepare_cb;
56strdup_ornull (const char *s) 57strdup_ornull (const char *s)
57{ 58{
58 return s ? strdup (s) : 0; 59 return s ? strdup (s) : 0;
59} 60}
60 61
61inline void 62static inline void
62sv_to_dbt (DBT *dbt, SV *sv) 63sv_to_dbt (DBT *dbt, SV *sv)
63{ 64{
64 STRLEN len; 65 STRLEN len;
65 char *data = SvPVbyte (sv, len); 66 char *data = SvPVbyte (sv, len);
66 67
67 dbt->data = malloc (len); 68 dbt->data = malloc (len);
68 memcpy (dbt->data, data, len); 69 memcpy (dbt->data, data, len);
69 dbt->size = len; 70 dbt->size = len;
71 dbt->flags = DB_DBT_REALLOC;
70} 72}
71 73
72inline void 74static inline void
73dbt_to_sv (SV *sv, DBT *dbt) 75dbt_to_sv (SV *sv, DBT *dbt)
74{ 76{
77 if (sv)
78 {
75 SvREADONLY_off (sv); 79 SvREADONLY_off (sv);
76 sv_setpvn_mg (sv, dbt->data, dbt->size); 80 sv_setpvn_mg (sv, dbt->data, dbt->size);
81 SvREFCNT_dec (sv);
82 }
77 83
78 free (dbt->data); 84 free (dbt->data);
79} 85}
80 86
81enum { 87enum {
82 REQ_QUIT, 88 REQ_QUIT,
83 REQ_ENV_OPEN, REQ_ENV_CLOSE, 89 REQ_ENV_OPEN, REQ_ENV_CLOSE, REQ_ENV_TXN_CHECKPOINT, REQ_ENV_LOCK_DETECT,
90 REQ_ENV_MEMP_SYNC, REQ_ENV_MEMP_TRICKLE,
84 REQ_DB_OPEN, REQ_DB_CLOSE, REQ_DB_COMPACT, REQ_DB_SYNC, REQ_DB_PUT, REQ_DB_GET, REQ_DB_PGET, 91 REQ_DB_OPEN, REQ_DB_CLOSE, REQ_DB_COMPACT, REQ_DB_SYNC,
92 REQ_DB_PUT, REQ_DB_GET, REQ_DB_PGET, REQ_DB_DEL, REQ_DB_KEY_RANGE,
85 REQ_TXN_COMMIT, REQ_TXN_ABORT, 93 REQ_TXN_COMMIT, REQ_TXN_ABORT,
94 REQ_C_CLOSE, REQ_C_COUNT, REQ_C_PUT, REQ_C_GET, REQ_C_PGET, REQ_C_DEL,
95 REQ_SEQ_OPEN, REQ_SEQ_CLOSE, REQ_SEQ_GET, REQ_SEQ_REMOVE,
86}; 96};
87 97
88typedef struct aio_cb 98typedef struct aio_cb
89{ 99{
90 struct aio_cb *volatile next; 100 struct aio_cb *volatile next;
92 int type, pri, result; 102 int type, pri, result;
93 103
94 DB_ENV *env; 104 DB_ENV *env;
95 DB *db; 105 DB *db;
96 DB_TXN *txn; 106 DB_TXN *txn;
97 DBC *cursor; 107 DBC *dbc;
108
109 UV uv1;
98 int int1, int2; 110 int int1, int2;
99 U32 uint1, uint2; 111 U32 uint1, uint2;
100 char *buf1, *buf2; 112 char *buf1, *buf2;
101 SV *sv1, *sv2; 113 SV *sv1, *sv2, *sv3;
102 114
103 DBT dbt1, dbt2, dbt3; 115 DBT dbt1, dbt2, dbt3;
116 DB_KEY_RANGE key_range;
117 DB_SEQUENCE *seq;
118 db_seq_t seq_t;
104} aio_cb; 119} aio_cb;
105 120
106typedef aio_cb *aio_req; 121typedef aio_cb *aio_req;
107 122
108enum { 123enum {
285 if (SvOK (req->callback)) 300 if (SvOK (req->callback))
286 { 301 {
287 ENTER; 302 ENTER;
288 SAVETMPS; 303 SAVETMPS;
289 PUSHMARK (SP); 304 PUSHMARK (SP);
290 EXTEND (SP, 1);
291 305
292 switch (req->type) 306 switch (req->type)
293 { 307 {
308 case REQ_DB_CLOSE:
309 SvREFCNT_dec (req->sv1);
310 break;
311
294 case REQ_DB_GET: 312 case REQ_DB_GET:
295 case REQ_DB_PGET: 313 case REQ_DB_PGET:
296 dbt_to_sv (req->sv1, &req->dbt3); 314 dbt_to_sv (req->sv3, &req->dbt3);
315 break;
316
317 case REQ_C_GET:
318 case REQ_C_PGET:
319 dbt_to_sv (req->sv1, &req->dbt1);
320 dbt_to_sv (req->sv2, &req->dbt2);
321 dbt_to_sv (req->sv3, &req->dbt3);
322 break;
323
324 case REQ_DB_KEY_RANGE:
325 {
326 AV *av = newAV ();
327
328 av_push (av, newSVnv (req->key_range.less));
329 av_push (av, newSVnv (req->key_range.equal));
330 av_push (av, newSVnv (req->key_range.greater));
331
332 SvREADONLY_off (req->sv1);
333 sv_setsv_mg (req->sv1, newRV_noinc ((SV *)av));
297 SvREFCNT_dec (req->sv1); 334 SvREFCNT_dec (req->sv1);
298 break; 335 }
336 break;
299 337
300 case REQ_DB_CLOSE: 338 case REQ_SEQ_GET:
339 SvREADONLY_off (req->sv1);
340
341 if (sizeof (IV) > 4)
342 sv_setiv_mg (req->sv1, req->seq_t);
343 else
344 sv_setnv_mg (req->sv1, req->seq_t);
345
301 SvREFCNT_dec (req->sv1); 346 SvREFCNT_dec (req->sv1);
302 break; 347 break;
303 } 348 }
304 349
305 errno = req->result; 350 errno = req->result;
626 671
627 case REQ_ENV_CLOSE: 672 case REQ_ENV_CLOSE:
628 req->result = req->env->close (req->env, req->uint1); 673 req->result = req->env->close (req->env, req->uint1);
629 break; 674 break;
630 675
676 case REQ_ENV_TXN_CHECKPOINT:
677 req->result = req->env->txn_checkpoint (req->env, req->uint1, req->int1, req->uint2);
678 break;
679
680 case REQ_ENV_LOCK_DETECT:
681 req->result = req->env->lock_detect (req->env, req->uint1, req->uint2, &req->int1);
682 break;
683
684 case REQ_ENV_MEMP_SYNC:
685 req->result = req->env->memp_sync (req->env, 0);
686 break;
687
688 case REQ_ENV_MEMP_TRICKLE:
689 req->result = req->env->memp_trickle (req->env, req->int1, &req->int2);
690 break;
691
631 case REQ_DB_OPEN: 692 case REQ_DB_OPEN:
632 req->result = req->db->open (req->db, req->txn, req->buf1, req->buf2, req->int1, req->uint1, req->int2); 693 req->result = req->db->open (req->db, req->txn, req->buf1, req->buf2, req->int1, req->uint1, req->int2);
633 break; 694 break;
634 695
635 case REQ_DB_CLOSE: 696 case REQ_DB_CLOSE:
654 715
655 case REQ_DB_PGET: 716 case REQ_DB_PGET:
656 req->result = req->db->pget (req->db, req->txn, &req->dbt1, &req->dbt2, &req->dbt3, req->uint1); 717 req->result = req->db->pget (req->db, req->txn, &req->dbt1, &req->dbt2, &req->dbt3, req->uint1);
657 break; 718 break;
658 719
720 case REQ_DB_DEL:
721 req->result = req->db->del (req->db, req->txn, &req->dbt1, req->uint1);
722 break;
723
724 case REQ_DB_KEY_RANGE:
725 req->result = req->db->key_range (req->db, req->txn, &req->dbt1, &req->key_range, req->uint1);
726 break;
727
659 case REQ_TXN_COMMIT: 728 case REQ_TXN_COMMIT:
660 req->result = req->txn->commit (req->txn, req->uint1); 729 req->result = req->txn->commit (req->txn, req->uint1);
661 break; 730 break;
662 731
663 case REQ_TXN_ABORT: 732 case REQ_TXN_ABORT:
664 req->result = req->txn->abort (req->txn); 733 req->result = req->txn->abort (req->txn);
734 break;
735
736 case REQ_C_CLOSE:
737 req->result = req->dbc->c_close (req->dbc);
738 break;
739
740 case REQ_C_COUNT:
741 {
742 db_recno_t recno;
743 req->result = req->dbc->c_count (req->dbc, &recno, req->uint1);
744 req->uv1 = recno;
745 }
746 break;
747
748 case REQ_C_PUT:
749 req->result = req->dbc->c_put (req->dbc, &req->dbt1, &req->dbt2, req->uint1);
750 break;
751
752 case REQ_C_GET:
753 req->result = req->dbc->c_get (req->dbc, &req->dbt1, &req->dbt3, req->uint1);
754 break;
755
756 case REQ_C_PGET:
757 req->result = req->dbc->c_pget (req->dbc, &req->dbt1, &req->dbt2, &req->dbt3, req->uint1);
758 break;
759
760 case REQ_C_DEL:
761 req->result = req->dbc->c_del (req->dbc, req->uint1);
762 break;
763
764 case REQ_SEQ_OPEN:
765 req->result = req->seq->open (req->seq, req->txn, &req->dbt1, req->uint1);
766 break;
767
768 case REQ_SEQ_CLOSE:
769 req->result = req->seq->close (req->seq, req->uint1);
770 break;
771
772 case REQ_SEQ_GET:
773 req->result = req->seq->get (req->seq, req->txn, req->int1, &req->seq_t, req->uint1);
774 break;
775
776 case REQ_SEQ_REMOVE:
777 req->result = req->seq->remove (req->seq, req->txn, req->uint1);
665 break; 778 break;
666 779
667 default: 780 default:
668 req->result = ENOSYS; 781 req->result = ENOSYS;
669 break; 782 break;
762 875
763#define SvPTR(var, arg, type, class, nullok) \ 876#define SvPTR(var, arg, type, class, nullok) \
764 if (!SvOK (arg)) \ 877 if (!SvOK (arg)) \
765 { \ 878 { \
766 if (!nullok) \ 879 if (!nullok) \
767 Perl_croak (# var " must be a " # class " object, not undef"); \ 880 croak (# var " must be a " # class " object, not undef"); \
768 \ 881 \
769 (var) = 0; \ 882 (var) = 0; \
770 } \ 883 } \
771 else if (sv_derived_from ((arg), # class)) \ 884 else if (sv_derived_from ((arg), # class)) \
772 { \ 885 { \
773 IV tmp = SvIV ((SV*) SvRV (arg)); \ 886 IV tmp = SvIV ((SV*) SvRV (arg)); \
774 (var) = INT2PTR (type, tmp); \ 887 (var) = INT2PTR (type, tmp); \
775 if (!var) \ 888 if (!var) \
776 Perl_croak (# var " is not a valid " # class " object anymore"); \ 889 croak (# var " is not a valid " # class " object anymore"); \
777 } \ 890 } \
778 else \ 891 else \
779 Perl_croak (# var " is not of type " # class); \ 892 croak (# var " is not of type " # class); \
780 \ 893 \
781 894
782static void 895static void
783ptr_nuke (SV *sv) 896ptr_nuke (SV *sv)
784{ 897{
859 const_iv (REVSPLITOFF) 972 const_iv (REVSPLITOFF)
860 const_iv (INORDER) 973 const_iv (INORDER)
861 const_iv (CONSUME) 974 const_iv (CONSUME)
862 const_iv (CONSUME_WAIT) 975 const_iv (CONSUME_WAIT)
863 const_iv (GET_BOTH) 976 const_iv (GET_BOTH)
977 const_iv (GET_BOTH_RANGE)
864 //const_iv (SET_RECNO) 978 //const_iv (SET_RECNO)
865 //const_iv (MULTIPLE) 979 //const_iv (MULTIPLE)
866 const_iv (SNAPSHOT) 980 const_iv (SNAPSHOT)
867 const_iv (JOIN_ITEM) 981 const_iv (JOIN_ITEM)
868 const_iv (RMW) 982 const_iv (RMW)
873 const_iv (LOCK_NOTGRANTED) 987 const_iv (LOCK_NOTGRANTED)
874 const_iv (RUNRECOVERY) 988 const_iv (RUNRECOVERY)
875 const_iv (OLD_VERSION) 989 const_iv (OLD_VERSION)
876 const_iv (REP_HANDLE_DEAD) 990 const_iv (REP_HANDLE_DEAD)
877 const_iv (REP_LOCKOUT) 991 const_iv (REP_LOCKOUT)
992 const_iv (SECONDARY_BAD)
878 993
879 const_iv (FREE_SPACE) 994 const_iv (FREE_SPACE)
880 const_iv (FREELIST_ONLY) 995 const_iv (FREELIST_ONLY)
881 996
882 const_iv (APPEND) 997 const_iv (APPEND)
887 const_iv (TXN_SNAPSHOT) 1002 const_iv (TXN_SNAPSHOT)
888 const_iv (TXN_SYNC) 1003 const_iv (TXN_SYNC)
889 1004
890 const_iv (SET_LOCK_TIMEOUT) 1005 const_iv (SET_LOCK_TIMEOUT)
891 const_iv (SET_TXN_TIMEOUT) 1006 const_iv (SET_TXN_TIMEOUT)
1007
1008 const_iv (JOIN_ITEM)
1009 const_iv (FIRST)
1010 const_iv (NEXT)
1011 const_iv (NEXT_DUP)
1012 const_iv (NEXT_NODUP)
1013 const_iv (PREV)
1014 const_iv (PREV_NODUP)
1015 const_iv (SET)
1016 const_iv (SET_RANGE)
1017 const_iv (LAST)
1018 const_iv (BEFORE)
1019 const_iv (AFTER)
1020 const_iv (CURRENT)
1021 const_iv (KEYFIRST)
1022 const_iv (KEYLAST)
1023 const_iv (NODUPDATA)
1024
1025 const_iv (FORCE)
1026
1027 const_iv (LOCK_DEFAULT)
1028 const_iv (LOCK_EXPIRE)
1029 const_iv (LOCK_MAXLOCKS)
1030 const_iv (LOCK_MAXWRITE)
1031 const_iv (LOCK_MINLOCKS)
1032 const_iv (LOCK_MINWRITE)
1033 const_iv (LOCK_OLDEST)
1034 const_iv (LOCK_RANDOM)
1035 const_iv (LOCK_YOUNGEST)
1036
1037 const_iv (SEQ_DEC)
1038 const_iv (SEQ_INC)
1039 const_iv (SEQ_WRAP)
892 }; 1040 };
893 1041
894 for (civ = const_iv + sizeof (const_iv) / sizeof (const_iv [0]); civ-- > const_iv; ) 1042 for (civ = const_iv + sizeof (const_iv) / sizeof (const_iv [0]); civ-- > const_iv; )
895 newCONSTSUB (stash, (char *)civ->name, newSViv (civ->iv)); 1043 newCONSTSUB (stash, (char *)civ->name, newSViv (civ->iv));
896 1044
1035 PROTOTYPE: & 1183 PROTOTYPE: &
1036 CODE: 1184 CODE:
1037 SvREFCNT_dec (prepare_cb); 1185 SvREFCNT_dec (prepare_cb);
1038 prepare_cb = newSVsv (cb); 1186 prepare_cb = newSVsv (cb);
1039 1187
1188
1040DB_ENV * 1189DB_ENV *
1041db_env_create (U32 env_flags = 0) 1190db_env_create (U32 env_flags = 0)
1042 CODE: 1191 CODE:
1043{ 1192{
1044 errno = db_env_create (&RETVAL, env_flags); 1193 errno = db_env_create (&RETVAL, env_flags);
1050 1199
1051void 1200void
1052db_env_open (DB_ENV *env, octetstring db_home, U32 open_flags, int mode, SV *callback = &PL_sv_undef) 1201db_env_open (DB_ENV *env, octetstring db_home, U32 open_flags, int mode, SV *callback = &PL_sv_undef)
1053 CODE: 1202 CODE:
1054{ 1203{
1204 env->set_thread_count (env, get_nthreads ());
1205
1055 dREQ (REQ_ENV_OPEN); 1206 dREQ (REQ_ENV_OPEN);
1056 req->env = env; 1207 req->env = env;
1057 req->uint1 = open_flags | DB_THREAD; 1208 req->uint1 = open_flags | DB_THREAD;
1058 req->int1 = mode; 1209 req->int1 = mode;
1059 req->buf1 = strdup_ornull (db_home); 1210 req->buf1 = strdup_ornull (db_home);
1069 req->uint1 = flags; 1220 req->uint1 = flags;
1070 REQ_SEND; 1221 REQ_SEND;
1071 ptr_nuke (ST (0)); 1222 ptr_nuke (ST (0));
1072} 1223}
1073 1224
1225void
1226db_env_txn_checkpoint (DB_ENV *env, U32 kbyte = 0, U32 min = 0, U32 flags = 0, SV *callback = &PL_sv_undef)
1227 CODE:
1228{
1229 dREQ (REQ_ENV_TXN_CHECKPOINT);
1230 req->env = env;
1231 req->uint1 = kbyte;
1232 req->int1 = min;
1233 req->uint2 = flags;
1234 REQ_SEND;
1235}
1236
1237void
1238db_env_lock_detect (DB_ENV *env, U32 flags = 0, U32 atype = DB_LOCK_DEFAULT, SV *dummy = 0, SV *callback = &PL_sv_undef)
1239 CODE:
1240{
1241 dREQ (REQ_ENV_LOCK_DETECT);
1242 req->env = env;
1243 req->uint1 = flags;
1244 req->uint2 = atype;
1245 REQ_SEND;
1246}
1247
1248void
1249db_env_memp_sync (DB_ENV *env, SV *dummy = 0, SV *callback = &PL_sv_undef)
1250 CODE:
1251{
1252 dREQ (REQ_ENV_MEMP_SYNC);
1253 req->env = env;
1254 REQ_SEND;
1255}
1256
1257void
1258db_env_memp_trickle (DB_ENV *env, int percent, SV *dummy = 0, SV *callback = &PL_sv_undef)
1259 CODE:
1260{
1261 dREQ (REQ_ENV_MEMP_TRICKLE);
1262 req->env = env;
1263 req->int1 = percent;
1264 REQ_SEND;
1265}
1266
1267
1074DB * 1268DB *
1075db_create (DB_ENV *env = 0, U32 flags = 0) 1269db_create (DB_ENV *env = 0, U32 flags = 0)
1076 CODE: 1270 CODE:
1077{ 1271{
1078 errno = db_create (&RETVAL, env, flags); 1272 errno = db_create (&RETVAL, env, flags);
1079 if (errno) 1273 if (errno)
1080 croak ("db_env_create: %s", db_strerror (errno)); 1274 croak ("db_create: %s", db_strerror (errno));
1081 1275
1082 if (RETVAL) 1276 if (RETVAL)
1083 RETVAL->app_private = (void *)newSVsv (ST (0)); 1277 RETVAL->app_private = (void *)newSVsv (ST (0));
1084} 1278}
1085 OUTPUT: 1279 OUTPUT:
1134 req->uint1 = flags; 1328 req->uint1 = flags;
1135 REQ_SEND; 1329 REQ_SEND;
1136} 1330}
1137 1331
1138void 1332void
1333db_key_range (DB *db, DB_TXN_ornull *txn, SV *key, SV *key_range, U32 flags = 0, SV *callback = &PL_sv_undef)
1334 CODE:
1335{
1336 dREQ (REQ_DB_KEY_RANGE);
1337 req->db = db;
1338 req->txn = txn;
1339 sv_to_dbt (&req->dbt1, key);
1340 req->uint1 = flags;
1341 req->sv1 = SvREFCNT_inc (key_range); SvREADONLY_on (key_range);
1342 REQ_SEND;
1343}
1344
1345void
1139db_put (DB *db, DB_TXN_ornull *txn, SV *key, SV *data, U32 flags = 0, SV *callback = &PL_sv_undef) 1346db_put (DB *db, DB_TXN_ornull *txn, SV *key, SV *data, U32 flags = 0, SV *callback = &PL_sv_undef)
1140 CODE: 1347 CODE:
1141{ 1348{
1142 dREQ (REQ_DB_PUT); 1349 dREQ (REQ_DB_PUT);
1143 req->db = db; 1350 req->db = db;
1153 CODE: 1360 CODE:
1154{ 1361{
1155 dREQ (REQ_DB_GET); 1362 dREQ (REQ_DB_GET);
1156 req->db = db; 1363 req->db = db;
1157 req->txn = txn; 1364 req->txn = txn;
1365 req->uint1 = flags;
1158 sv_to_dbt (&req->dbt1, key); 1366 sv_to_dbt (&req->dbt1, key);
1159 req->dbt3.flags = DB_DBT_MALLOC; 1367 req->dbt3.flags = DB_DBT_MALLOC;
1160 req->uint1 = flags;
1161 req->sv1 = SvREFCNT_inc (data); 1368 req->sv3 = SvREFCNT_inc (data); SvREADONLY_on (data);
1162 SvREADONLY_on (data);
1163 REQ_SEND; 1369 REQ_SEND;
1164} 1370}
1165 1371
1166void 1372void
1167db_pget (DB *db, DB_TXN_ornull *txn, SV *key, SV *pkey, SV *data, U32 flags = 0, SV *callback = &PL_sv_undef) 1373db_pget (DB *db, DB_TXN_ornull *txn, SV *key, SV *pkey, SV *data, U32 flags = 0, SV *callback = &PL_sv_undef)
1168 CODE: 1374 CODE:
1169{ 1375{
1170 dREQ (REQ_DB_PGET); 1376 dREQ (REQ_DB_PGET);
1171 req->db = db; 1377 req->db = db;
1172 req->txn = txn; 1378 req->txn = txn;
1379 req->uint1 = flags;
1173 sv_to_dbt (&req->dbt1, key); 1380 sv_to_dbt (&req->dbt1, key);
1174 sv_to_dbt (&req->dbt2, pkey); 1381 sv_to_dbt (&req->dbt2, pkey);
1175 req->dbt3.flags = DB_DBT_MALLOC; 1382 req->dbt3.flags = DB_DBT_MALLOC;
1383 req->sv3 = SvREFCNT_inc (data); SvREADONLY_on (data);
1384 REQ_SEND;
1385}
1386
1387void
1388db_del (DB *db, DB_TXN_ornull *txn, SV *key, U32 flags = 0, SV *callback = &PL_sv_undef)
1389 CODE:
1390{
1391 dREQ (REQ_DB_DEL);
1392 req->db = db;
1393 req->txn = txn;
1176 req->uint1 = flags; 1394 req->uint1 = flags;
1177 req->sv1 = SvREFCNT_inc (data); 1395 sv_to_dbt (&req->dbt1, key);
1178 SvREADONLY_on (data);
1179 REQ_SEND; 1396 REQ_SEND;
1180} 1397}
1181 1398
1182void 1399void
1183db_txn_commit (DB_TXN *txn, U32 flags = 0, SV *callback = &PL_sv_undef) 1400db_txn_commit (DB_TXN *txn, U32 flags = 0, SV *callback = &PL_sv_undef)
1198 req->txn = txn; 1415 req->txn = txn;
1199 REQ_SEND; 1416 REQ_SEND;
1200 ptr_nuke (ST (0)); 1417 ptr_nuke (ST (0));
1201} 1418}
1202 1419
1420void
1421db_c_close (DBC *dbc, SV *callback = &PL_sv_undef)
1422 CODE:
1423{
1424 dREQ (REQ_C_CLOSE);
1425 req->dbc = dbc;
1426 REQ_SEND;
1427 ptr_nuke (ST (0));
1428}
1429
1430void
1431db_c_count (DBC *dbc, SV *count, U32 flags = 0, SV *callback = &PL_sv_undef)
1432 CODE:
1433{
1434 dREQ (REQ_C_COUNT);
1435 req->dbc = dbc;
1436 req->sv1 = SvREFCNT_inc (count);
1437 REQ_SEND;
1438}
1439
1440void
1441db_c_put (DBC *dbc, SV *key, SV *data, U32 flags = 0, SV *callback = &PL_sv_undef)
1442 CODE:
1443{
1444 dREQ (REQ_C_PUT);
1445 req->dbc = dbc;
1446 sv_to_dbt (&req->dbt1, key);
1447 sv_to_dbt (&req->dbt2, data);
1448 req->uint1 = flags;
1449 REQ_SEND;
1450}
1451
1452void
1453db_c_get (DBC *dbc, SV *key, SV *data, U32 flags = 0, SV *callback = &PL_sv_undef)
1454 CODE:
1455{
1456 dREQ (REQ_C_GET);
1457 req->dbc = dbc;
1458 req->uint1 = flags;
1459 if ((flags & DB_SET) == DB_SET
1460 || (flags & DB_SET_RANGE) == DB_SET_RANGE)
1461 sv_to_dbt (&req->dbt1, key);
1462 else
1463 req->dbt1.flags = DB_DBT_MALLOC;
1464
1465 req->sv1 = SvREFCNT_inc (key); SvREADONLY_on (key);
1466
1467 if ((flags & DB_GET_BOTH) == DB_GET_BOTH
1468 || (flags & DB_GET_BOTH_RANGE) == DB_GET_BOTH_RANGE)
1469 sv_to_dbt (&req->dbt3, data);
1470 else
1471 req->dbt3.flags = DB_DBT_MALLOC;
1472
1473 req->sv3 = SvREFCNT_inc (data); SvREADONLY_on (data);
1474 REQ_SEND;
1475}
1476
1477void
1478db_c_pget (DBC *dbc, SV *key, SV *pkey, SV *data, U32 flags = 0, SV *callback = &PL_sv_undef)
1479 CODE:
1480{
1481 dREQ (REQ_C_PGET);
1482 req->dbc = dbc;
1483 req->uint1 = flags;
1484 if ((flags & DB_SET) == DB_SET
1485 || (flags & DB_SET_RANGE) == DB_SET_RANGE)
1486 sv_to_dbt (&req->dbt1, key);
1487 else
1488 req->dbt1.flags = DB_DBT_MALLOC;
1489
1490 req->sv1 = SvREFCNT_inc (key); SvREADONLY_on (key);
1491
1492 req->dbt2.flags = DB_DBT_MALLOC;
1493 req->sv2 = SvREFCNT_inc (pkey); SvREADONLY_on (pkey);
1494
1495 if ((flags & DB_GET_BOTH) == DB_GET_BOTH
1496 || (flags & DB_GET_BOTH_RANGE) == DB_GET_BOTH_RANGE)
1497 sv_to_dbt (&req->dbt3, data);
1498 else
1499 req->dbt3.flags = DB_DBT_MALLOC;
1500
1501 req->sv3 = SvREFCNT_inc (data); SvREADONLY_on (data);
1502 REQ_SEND;
1503}
1504
1505void
1506db_c_del (DBC *dbc, U32 flags = 0, SV *callback = &PL_sv_undef)
1507 CODE:
1508{
1509 dREQ (REQ_C_DEL);
1510 req->dbc = dbc;
1511 req->uint1 = flags;
1512 REQ_SEND;
1513}
1514
1515
1516void
1517db_sequence_open (DB_SEQUENCE *seq, DB_TXN_ornull *txnid, SV *key, U32 flags = 0, SV *callback = &PL_sv_undef)
1518 CODE:
1519{
1520 dREQ (REQ_SEQ_OPEN);
1521 req->seq = seq;
1522 req->txn = txnid;
1523 req->uint1 = flags | DB_THREAD;
1524 sv_to_dbt (&req->dbt1, key);
1525 REQ_SEND;
1526}
1527
1528void
1529db_sequence_close (DB_SEQUENCE *seq, U32 flags = 0, SV *callback = &PL_sv_undef)
1530 CODE:
1531{
1532 dREQ (REQ_SEQ_CLOSE);
1533 req->seq = seq;
1534 req->uint1 = flags;
1535 REQ_SEND;
1536 ptr_nuke (ST (0));
1537}
1538
1539void
1540db_sequence_get (DB_SEQUENCE *seq, DB_TXN_ornull *txnid, int delta, SV *seq_value, U32 flags = DB_TXN_NOSYNC, SV *callback = &PL_sv_undef)
1541 CODE:
1542{
1543 dREQ (REQ_SEQ_GET);
1544 req->seq = seq;
1545 req->txn = txnid;
1546 req->int1 = delta;
1547 req->uint1 = flags;
1548 req->sv1 = SvREFCNT_inc (seq_value); SvREADONLY_on (seq_value);
1549 REQ_SEND;
1550}
1551
1552void
1553db_sequence_remove (DB_SEQUENCE *seq, DB_TXN_ornull *txnid = 0, U32 flags = 0, SV *callback = &PL_sv_undef)
1554 CODE:
1555{
1556 dREQ (REQ_SEQ_REMOVE);
1557 req->seq = seq;
1558 req->txn = txnid;
1559 req->uint1 = flags;
1560 REQ_SEND;
1561}
1562
1203 1563
1204MODULE = BDB PACKAGE = BDB::Env 1564MODULE = BDB PACKAGE = BDB::Env
1205 1565
1206void 1566void
1207DESTROY (DB_ENV_ornull *env) 1567DESTROY (DB_ENV_ornull *env)
1208 CODE: 1568 CODE:
1209 if (env) 1569 if (env)
1210 env->close (env, 0); 1570 env->close (env, 0);
1211 1571
1572int set_data_dir (DB_ENV *env, const char *dir)
1573 CODE:
1574 RETVAL = env->set_data_dir (env, dir);
1575 OUTPUT:
1576 RETVAL
1577
1578int set_tmp_dir (DB_ENV *env, const char *dir)
1579 CODE:
1580 RETVAL = env->set_tmp_dir (env, dir);
1581 OUTPUT:
1582 RETVAL
1583
1584int set_lg_dir (DB_ENV *env, const char *dir)
1585 CODE:
1586 RETVAL = env->set_lg_dir (env, dir);
1587 OUTPUT:
1588 RETVAL
1589
1590int set_shm_key (DB_ENV *env, long shm_key)
1591 CODE:
1592 RETVAL = env->set_shm_key (env, shm_key);
1593 OUTPUT:
1594 RETVAL
1595
1212int set_cachesize (DB_ENV *env, U32 gbytes, U32 bytes, int ncache = 0) 1596int set_cachesize (DB_ENV *env, U32 gbytes, U32 bytes, int ncache = 0)
1213 CODE: 1597 CODE:
1214 RETVAL = env->set_cachesize (env, gbytes, bytes, ncache); 1598 RETVAL = env->set_cachesize (env, gbytes, bytes, ncache);
1215 OUTPUT: 1599 OUTPUT:
1216 RETVAL 1600 RETVAL
1228 RETVAL 1612 RETVAL
1229 1613
1230int set_timeout (DB_ENV *env, NV timeout, U32 flags) 1614int set_timeout (DB_ENV *env, NV timeout, U32 flags)
1231 CODE: 1615 CODE:
1232 RETVAL = env->set_timeout (env, timeout * 1000000, flags); 1616 RETVAL = env->set_timeout (env, timeout * 1000000, flags);
1617 OUTPUT:
1618 RETVAL
1619
1620int set_mp_max_openfd (DB_ENV *env, int maxopenfd);
1621 CODE:
1622 RETVAL = env->set_mp_max_openfd (env, maxopenfd);
1623 OUTPUT:
1624 RETVAL
1625
1626int set_mp_max_write (DB_ENV *env, int maxwrite, int maxwrite_sleep);
1627 CODE:
1628 RETVAL = env->set_mp_max_write (env, maxwrite, maxwrite_sleep);
1629 OUTPUT:
1630 RETVAL
1631
1632int set_mp_mmapsize (DB_ENV *env, int mmapsize_mb)
1633 CODE:
1634 RETVAL = env->set_mp_mmapsize (env, ((size_t)mmapsize_mb) << 20);
1635 OUTPUT:
1636 RETVAL
1637
1638int set_lk_detect (DB_ENV *env, U32 detect = DB_LOCK_DEFAULT)
1639 CODE:
1640 RETVAL = env->set_lk_detect (env, detect);
1641 OUTPUT:
1642 RETVAL
1643
1644int set_lk_max_lockers (DB_ENV *env, U32 max)
1645 CODE:
1646 RETVAL = env->set_lk_max_lockers (env, max);
1647 OUTPUT:
1648 RETVAL
1649
1650int set_lk_max_locks (DB_ENV *env, U32 max)
1651 CODE:
1652 RETVAL = env->set_lk_max_locks (env, max);
1653 OUTPUT:
1654 RETVAL
1655
1656int set_lk_max_objects (DB_ENV *env, U32 max)
1657 CODE:
1658 RETVAL = env->set_lk_max_objects (env, max);
1659 OUTPUT:
1660 RETVAL
1661
1662int set_lg_bsize (DB_ENV *env, U32 max)
1663 CODE:
1664 RETVAL = env->set_lg_bsize (env, max);
1665 OUTPUT:
1666 RETVAL
1667
1668int set_lg_max (DB_ENV *env, U32 max)
1669 CODE:
1670 RETVAL = env->set_lg_max (env, max);
1233 OUTPUT: 1671 OUTPUT:
1234 RETVAL 1672 RETVAL
1235 1673
1236DB_TXN * 1674DB_TXN *
1237txn_begin (DB_ENV *env, DB_TXN_ornull *parent = 0, U32 flags = 0) 1675txn_begin (DB_ENV *env, DB_TXN_ornull *parent = 0, U32 flags = 0)
1238 CODE: 1676 CODE:
1239 errno = env->txn_begin (env, parent, &RETVAL, flags); 1677 errno = env->txn_begin (env, parent, &RETVAL, flags);
1240 if (errno) 1678 if (errno)
1241 croak ("txn_begin: %s", db_strerror (errno)); 1679 croak ("DB_ENV->txn_begin: %s", db_strerror (errno));
1242 OUTPUT: 1680 OUTPUT:
1243 RETVAL 1681 RETVAL
1244 1682
1245MODULE = BDB PACKAGE = BDB::Db 1683MODULE = BDB PACKAGE = BDB::Db
1246 1684
1276 CODE: 1714 CODE:
1277 RETVAL = db->set_lorder (db, lorder); 1715 RETVAL = db->set_lorder (db, lorder);
1278 OUTPUT: 1716 OUTPUT:
1279 RETVAL 1717 RETVAL
1280 1718
1281
1282int set_bt_minkey (DB *db, U32 minkey) 1719int set_bt_minkey (DB *db, U32 minkey)
1283 CODE: 1720 CODE:
1284 RETVAL = db->set_bt_minkey (db, minkey); 1721 RETVAL = db->set_bt_minkey (db, minkey);
1285 OUTPUT: 1722 OUTPUT:
1286 RETVAL 1723 RETVAL
1324int set_q_extentsize (DB *db, U32 extentsize) 1761int set_q_extentsize (DB *db, U32 extentsize)
1325 CODE: 1762 CODE:
1326 RETVAL = db->set_q_extentsize (db, extentsize); 1763 RETVAL = db->set_q_extentsize (db, extentsize);
1327 OUTPUT: 1764 OUTPUT:
1328 RETVAL 1765 RETVAL
1766
1767DBC *
1768cursor (DB *db, DB_TXN_ornull *txn = 0, U32 flags = 0)
1769 CODE:
1770 errno = db->cursor (db, txn, &RETVAL, flags);
1771 if (errno)
1772 croak ("DB->cursor: %s", db_strerror (errno));
1773 OUTPUT:
1774 RETVAL
1775
1776DB_SEQUENCE *
1777sequence (DB *db, U32 flags = 0)
1778 CODE:
1779{
1780 errno = db_sequence_create (&RETVAL, db, flags);
1781 if (errno)
1782 croak ("db_sequence_create: %s", db_strerror (errno));
1783}
1784 OUTPUT:
1785 RETVAL
1786
1329 1787
1330MODULE = BDB PACKAGE = BDB::Txn 1788MODULE = BDB PACKAGE = BDB::Txn
1331 1789
1332void 1790void
1333DESTROY (DB_TXN_ornull *txn) 1791DESTROY (DB_TXN_ornull *txn)
1340 RETVAL = txn->set_timeout (txn, timeout * 1000000, flags); 1798 RETVAL = txn->set_timeout (txn, timeout * 1000000, flags);
1341 OUTPUT: 1799 OUTPUT:
1342 RETVAL 1800 RETVAL
1343 1801
1344 1802
1803MODULE = BDB PACKAGE = BDB::Cursor
1804
1805void
1806DESTROY (DBC_ornull *dbc)
1807 CODE:
1808 if (dbc)
1809 dbc->c_close (dbc);
1810
1811MODULE = BDB PACKAGE = BDB::Sequence
1812
1813void
1814DESTROY (DB_SEQUENCE_ornull *seq)
1815 CODE:
1816 if (seq)
1817 seq->close (seq, 0);
1818
1819int initial_value (DB_SEQUENCE *seq, db_seq_t value)
1820 CODE:
1821 RETVAL = seq->initial_value (seq, value);
1822 OUTPUT:
1823 RETVAL
1824
1825int set_cachesize (DB_SEQUENCE *seq, U32 size)
1826 CODE:
1827 RETVAL = seq->set_cachesize (seq, size);
1828 OUTPUT:
1829 RETVAL
1830
1831int set_flags (DB_SEQUENCE *seq, U32 flags)
1832 CODE:
1833 RETVAL = seq->set_flags (seq, flags);
1834 OUTPUT:
1835 RETVAL
1836
1837int set_range (DB_SEQUENCE *seq, db_seq_t min, db_seq_t max)
1838 CODE:
1839 RETVAL = seq->set_range (seq, min, max);
1840 OUTPUT:
1841 RETVAL
1842

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines