Ruby
2.7.1p83(2020-03-31revisiona0c7c23c9cec0d0ffcba012279cd652d28ad5bf3)
|
Go to the documentation of this file.
17 #ifdef HAVE_SYS_CDEFS_H
18 # include <sys/cdefs.h>
24 #define DSIZE_TYPE TYPEOF_DATUM_DSIZE
25 #if SIZEOF_DATUM_DSIZE > SIZEOF_INT
26 # define RSTRING_DSIZE(s) RSTRING_LEN(s)
27 # define TOO_LONG(n) ((void)(n),0)
29 # define RSTRING_DSIZE(s) RSTRING_LENINT(s)
30 # define TOO_LONG(n) ((long)(+(DSIZE_TYPE)(n)) != (n))
33 static VALUE rb_cDBM, rb_eDBMError;
35 #define RUBY_DBM_RW_BIT 0x20000000
42 NORETURN(
static void closed_dbm(
void));
47 rb_raise(rb_eDBMError,
"closed DBM file");
50 #define GetDBM(obj, dbmp) do {\
51 TypedData_Get_Struct((obj), struct dbmdata, &dbm_type, (dbmp));\
52 if ((dbmp)->di_dbm == 0) closed_dbm();\
55 #define GetDBM2(obj, dbmp, dbm) do {\
56 GetDBM((obj), (dbmp));\
57 (dbm) = (dbmp)->di_dbm;\
70 memsize_dbm(
const void *
ptr)
73 size_t size =
sizeof(*dbmp);
75 size += DBM_SIZEOF_DBM;
81 {0, free_dbm, memsize_dbm,},
146 VALUE file, vmode, vflags;
155 else if (
NIL_P(vmode)) {
211 #if defined(HAVE_DBM_PAGFNO)
214 #if defined(HAVE_DBM_DIRFNO)
218 #if defined(RUBYDBM_DB_HEADER) && defined(HAVE_TYPE_DBC)
221 ((DBC*)dbm)->dbp->set_errfile(((DBC*)dbm)->dbp,
NULL);
226 if (mode == -1)
return Qnil;
277 value = dbm_fetch(dbm,
key);
278 if (value.
dptr == 0) {
299 return fdbm_fetch(
obj, keystr,
Qnil);
313 VALUE keystr, valstr, ifnone;
316 valstr = fdbm_fetch(
obj, keystr, ifnone);
342 for (
key = dbm_firstkey(dbm);
key.dptr;
key = dbm_nextkey(dbm)) {
343 val = dbm_fetch(dbm,
key);
356 rb_warn(
"DBM#index is deprecated; use DBM#key");
357 return fdbm_key(hash, value);
376 for (
key = dbm_firstkey(dbm);
key.dptr;
key = dbm_nextkey(dbm)) {
378 val = dbm_fetch(dbm,
key);
440 value = dbm_fetch(dbm,
key);
441 if (value.
dptr == 0) {
450 if (dbm_delete(dbm,
key)) {
452 rb_raise(rb_eDBMError,
"dbm_delete failed");
474 VALUE keystr, valstr;
480 key = dbm_firstkey(dbm);
482 val = dbm_fetch(dbm,
key);
485 dbm_delete(dbm,
key);
504 VALUE keystr, valstr;
514 for (
key = dbm_firstkey(dbm);
key.dptr;
key = dbm_nextkey(dbm)) {
515 val = dbm_fetch(dbm,
key);
520 if (status != 0)
break;
529 if (dbm_delete(dbm,
key)) {
530 rb_raise(rb_eDBMError,
"dbm_delete failed");
556 while (
key = dbm_firstkey(dbm),
key.dptr) {
557 if (dbm_delete(dbm,
key)) {
558 rb_raise(rb_eDBMError,
"dbm_delete failed");
579 VALUE keystr, valstr;
583 for (
key = dbm_firstkey(dbm);
key.dptr;
key = dbm_nextkey(dbm)) {
584 val = dbm_fetch(dbm,
key);
603 fdbm_store(dbm,
ptr[0],
ptr[1]);
668 rb_raise(rb_eDBMError,
"dbm_store failed");
692 for (
key = dbm_firstkey(dbm);
key.dptr;
key = dbm_nextkey(dbm)) {
717 for (
key = dbm_firstkey(dbm);
key.dptr;
key = dbm_nextkey(dbm)) {
744 for (
key = dbm_firstkey(dbm);
key.dptr;
key = dbm_nextkey(dbm)) {
745 val = dbm_fetch(dbm,
key);
768 for (
key = dbm_firstkey(dbm);
key.dptr;
key = dbm_nextkey(dbm)) {
788 VALUE keystr, valstr;
794 for (
key = dbm_firstkey(dbm);
key.dptr;
key = dbm_nextkey(dbm)) {
795 val = dbm_fetch(dbm,
key);
822 for (
key = dbm_firstkey(dbm);
key.dptr;
key = dbm_nextkey(dbm)) {
845 for (
key = dbm_firstkey(dbm);
key.dptr;
key = dbm_nextkey(dbm)) {
846 val = dbm_fetch(dbm,
key);
877 val = dbm_fetch(dbm,
key);
905 for (
key = dbm_firstkey(dbm);
key.dptr;
key = dbm_nextkey(dbm)) {
906 val = dbm_fetch(dbm,
key);
931 for (
key = dbm_firstkey(dbm);
key.dptr;
key = dbm_nextkey(dbm)) {
932 val = dbm_fetch(dbm,
key);
957 for (
key = dbm_firstkey(dbm);
key.dptr;
key = dbm_nextkey(dbm)) {
958 val = dbm_fetch(dbm,
key);
1112 #if defined(_DBM_IOERR)
1114 #elif defined(RUBYDBM_GDBM_HEADER)
1115 # if defined(HAVE_DECLARED_LIBVAR_GDBM_VERSION)
1118 # elif defined(HAVE_UNDECLARED_LIBVAR_GDBM_VERSION)
1126 #elif defined(RUBYDBM_DB_HEADER)
1127 # if defined(HAVE_DB_VERSION)
1133 #elif defined(_RELIC_H)
1134 # if defined(HAVE_DPVERSION)
VALUE rb_define_class(const char *name, VALUE super)
Defines a top-level class.
#define TypedData_Make_Struct(klass, type, data_type, sval)
void rb_include_module(VALUE klass, VALUE module)
VALUE rb_assoc_new(VALUE car, VALUE cdr)
void rb_warn(const char *fmt,...)
int rb_block_given_p(void)
Determines if the current method is given a block.
VALUE rb_obj_as_string(VALUE)
void rb_fd_fix_cloexec(int fd)
NORETURN(static void closed_dbm(void))
void rb_define_singleton_method(VALUE obj, const char *name, VALUE(*func)(ANYARGS), int argc)
Defines a singleton method for obj.
void rb_define_method(VALUE klass, const char *name, VALUE(*func)(ANYARGS), int argc)
#define ExportStringValue(v)
#define RB_BLOCK_CALL_FUNC_ARGLIST(yielded_arg, callback_arg)
VALUE rb_protect(VALUE(*proc)(VALUE), VALUE data, int *pstate)
Protects a function call from potential global escapes from the function.
void rb_error_frozen(const char *what)
void rb_raise(VALUE exc, const char *fmt,...)
VALUE rb_ary_tmp_new(long capa)
void rb_jump_tag(int tag)
Continues the exception caught by rb_protect() and rb_eval_string_protect().
VALUE rb_hash_delete_if(VALUE hash)
VALUE rb_ary_push(VALUE ary, VALUE item)
#define GetDBM(obj, dbmp)
void rb_sys_fail(const char *mesg)
#define RETURN_ENUMERATOR(obj, argc, argv)
#define RARRAY_AREF(a, i)
int memcmp(const void *s1, const void *s2, size_t len)
#define RARRAY_CONST_PTR(a)
VALUE rb_ary_clear(VALUE ary)
RUBY_EXTERN VALUE rb_cObject
#define TypedData_Get_Struct(obj, type, data_type, sval)
VALUE rb_sprintf(const char *format,...)
#define RUBY_TYPED_FREE_IMMEDIATELY
VALUE rb_hash_aset(VALUE hash, VALUE key, VALUE val)
VALUE rb_block_call(VALUE q, ID w, int e, const VALUE *r, type *t, VALUE y)
Call a method with a block.
#define GetDBM2(obj, dbmp, dbm)
void rb_sys_fail_str(VALUE mesg)
void rb_define_const(VALUE, const char *, VALUE)
VALUE rb_ensure(VALUE(*b_proc)(VALUE), VALUE data1, VALUE(*e_proc)(VALUE), VALUE data2)
An equivalent to ensure clause.
void rb_define_alloc_func(VALUE, rb_alloc_func_t)