mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
gdbm, dbm, sdbm: prevent memory leak in #initialize
Have the allocator function allocate struct dbmdata too. #initialize should not call ALLOC() after opening a file since it can fail with NoMemoryError, leaking the opened file. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@60355 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
15c78e30d6
commit
de7a010a50
3 changed files with 18 additions and 19 deletions
|
|
@ -47,7 +47,6 @@ closed_dbm(void)
|
|||
|
||||
#define GetDBM(obj, dbmp) do {\
|
||||
TypedData_Get_Struct((obj), struct dbmdata, &dbm_type, (dbmp));\
|
||||
if ((dbmp) == 0) closed_dbm();\
|
||||
if ((dbmp)->di_dbm == 0) closed_dbm();\
|
||||
} while (0)
|
||||
|
||||
|
|
@ -115,8 +114,6 @@ fdbm_closed(VALUE obj)
|
|||
struct dbmdata *dbmp;
|
||||
|
||||
TypedData_Get_Struct(obj, struct dbmdata, &dbm_type, dbmp);
|
||||
if (dbmp == 0)
|
||||
return Qtrue;
|
||||
if (dbmp->di_dbm == 0)
|
||||
return Qtrue;
|
||||
|
||||
|
|
@ -126,7 +123,9 @@ fdbm_closed(VALUE obj)
|
|||
static VALUE
|
||||
fdbm_alloc(VALUE klass)
|
||||
{
|
||||
return TypedData_Wrap_Struct(klass, &dbm_type, 0);
|
||||
struct dbmdata *dbmp;
|
||||
|
||||
return TypedData_Make_Struct(klass, struct dbmdata, &dbm_type, dbmp);
|
||||
}
|
||||
|
||||
/*
|
||||
|
|
@ -150,6 +149,7 @@ fdbm_initialize(int argc, VALUE *argv, VALUE obj)
|
|||
struct dbmdata *dbmp;
|
||||
int mode, flags = 0;
|
||||
|
||||
TypedData_Get_Struct(obj, struct dbmdata, &dbm_type, dbmp);
|
||||
if (rb_scan_args(argc, argv, "12", &file, &vmode, &vflags) == 1) {
|
||||
mode = 0666; /* default value */
|
||||
}
|
||||
|
|
@ -228,8 +228,8 @@ fdbm_initialize(int argc, VALUE *argv, VALUE obj)
|
|||
rb_sys_fail_str(file);
|
||||
}
|
||||
|
||||
dbmp = ALLOC(struct dbmdata);
|
||||
DATA_PTR(obj) = dbmp;
|
||||
if (dbmp->di_dbm)
|
||||
dbm_close(dbmp->di_dbm);
|
||||
dbmp->di_dbm = dbm;
|
||||
dbmp->di_size = -1;
|
||||
|
||||
|
|
|
|||
|
|
@ -102,7 +102,6 @@ closed_dbm(void)
|
|||
|
||||
#define GetDBM(obj, dbmp) do {\
|
||||
TypedData_Get_Struct((obj), struct dbmdata, &dbm_type, (dbmp));\
|
||||
if ((dbmp) == 0) closed_dbm();\
|
||||
if ((dbmp)->di_dbm == 0) closed_dbm();\
|
||||
} while (0)
|
||||
|
||||
|
|
@ -170,8 +169,6 @@ fgdbm_closed(VALUE obj)
|
|||
struct dbmdata *dbmp;
|
||||
|
||||
TypedData_Get_Struct(obj, struct dbmdata, &dbm_type, dbmp);
|
||||
if (dbmp == 0)
|
||||
return Qtrue;
|
||||
if (dbmp->di_dbm == 0)
|
||||
return Qtrue;
|
||||
|
||||
|
|
@ -181,7 +178,9 @@ fgdbm_closed(VALUE obj)
|
|||
static VALUE
|
||||
fgdbm_s_alloc(VALUE klass)
|
||||
{
|
||||
return TypedData_Wrap_Struct(klass, &dbm_type, 0);
|
||||
struct dbmdata *dbmp;
|
||||
|
||||
return TypedData_Make_Struct(klass, struct dbmdata, &dbm_type, dbmp);
|
||||
}
|
||||
|
||||
/*
|
||||
|
|
@ -215,6 +214,7 @@ fgdbm_initialize(int argc, VALUE *argv, VALUE obj)
|
|||
struct dbmdata *dbmp;
|
||||
int mode, flags = 0;
|
||||
|
||||
TypedData_Get_Struct(obj, struct dbmdata, &dbm_type, dbmp);
|
||||
if (rb_scan_args(argc, argv, "12", &file, &vmode, &vflags) == 1) {
|
||||
mode = 0666; /* default value */
|
||||
}
|
||||
|
|
@ -268,9 +268,8 @@ fgdbm_initialize(int argc, VALUE *argv, VALUE obj)
|
|||
rb_raise(rb_eGDBMError, "%s", gdbm_strerror(gdbm_errno));
|
||||
}
|
||||
|
||||
dbmp = ALLOC(struct dbmdata);
|
||||
free_dbm(DATA_PTR(obj));
|
||||
DATA_PTR(obj) = dbmp;
|
||||
if (dbmp->di_dbm)
|
||||
gdbm_close(dbmp->di_dbm);
|
||||
dbmp->di_dbm = dbm;
|
||||
dbmp->di_size = -1;
|
||||
|
||||
|
|
|
|||
|
|
@ -79,7 +79,6 @@ closed_sdbm(void)
|
|||
|
||||
#define GetDBM(obj, dbmp) do {\
|
||||
TypedData_Get_Struct((obj), struct dbmdata, &sdbm_type, (dbmp));\
|
||||
if ((dbmp) == 0) closed_sdbm();\
|
||||
if ((dbmp)->di_dbm == 0) closed_sdbm();\
|
||||
} while (0)
|
||||
|
||||
|
|
@ -148,8 +147,6 @@ fsdbm_closed(VALUE obj)
|
|||
struct dbmdata *dbmp;
|
||||
|
||||
TypedData_Get_Struct(obj, struct dbmdata, &sdbm_type, dbmp);
|
||||
if (dbmp == 0)
|
||||
return Qtrue;
|
||||
if (dbmp->di_dbm == 0)
|
||||
return Qtrue;
|
||||
|
||||
|
|
@ -159,7 +156,9 @@ fsdbm_closed(VALUE obj)
|
|||
static VALUE
|
||||
fsdbm_alloc(VALUE klass)
|
||||
{
|
||||
return TypedData_Wrap_Struct(klass, &sdbm_type, 0);
|
||||
struct dbmdata *dbmp;
|
||||
|
||||
return TypedData_Make_Struct(klass, struct dbmdata, &sdbm_type, dbmp);
|
||||
}
|
||||
/*
|
||||
* call-seq:
|
||||
|
|
@ -184,6 +183,7 @@ fsdbm_initialize(int argc, VALUE *argv, VALUE obj)
|
|||
struct dbmdata *dbmp;
|
||||
int mode;
|
||||
|
||||
TypedData_Get_Struct(obj, struct dbmdata, &sdbm_type, dbmp);
|
||||
if (rb_scan_args(argc, argv, "11", &file, &vmode) == 1) {
|
||||
mode = 0666; /* default value */
|
||||
}
|
||||
|
|
@ -208,8 +208,8 @@ fsdbm_initialize(int argc, VALUE *argv, VALUE obj)
|
|||
rb_sys_fail_str(file);
|
||||
}
|
||||
|
||||
dbmp = ALLOC(struct dbmdata);
|
||||
DATA_PTR(obj) = dbmp;
|
||||
if (dbmp->di_dbm)
|
||||
sdbm_close(dbmp->di_dbm);
|
||||
dbmp->di_dbm = dbm;
|
||||
dbmp->di_size = -1;
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue