Commit 4be4ba99 authored by Yoni Fogel's avatar Yoni Fogel

DB_ENV->set_data_dir cleaned up and tightened

Fixes a bug where I forgot to set the reallocced memory.
Addresses #42

git-svn-id: file:///svn/tokudb@1305 c7de825b-a66e-492c-adef-691d508d4ae1
parent d9a3af8b
...@@ -375,7 +375,8 @@ static int toku_db_env_set_cachesize(DB_ENV * env, u_int32_t gbytes, u_int32_t b ...@@ -375,7 +375,8 @@ static int toku_db_env_set_cachesize(DB_ENV * env, u_int32_t gbytes, u_int32_t b
static int toku_db_env_set_data_dir(DB_ENV * env, const char *dir) { static int toku_db_env_set_data_dir(DB_ENV * env, const char *dir) {
u_int32_t i; u_int32_t i;
int r; int r;
void* temp; char** temp;
char* new_dir;
if (db_env_opened(env) || !dir) if (db_env_opened(env) || !dir)
return EINVAL; return EINVAL;
...@@ -390,19 +391,17 @@ static int toku_db_env_set_data_dir(DB_ENV * env, const char *dir) { ...@@ -390,19 +391,17 @@ static int toku_db_env_set_data_dir(DB_ENV * env, const char *dir) {
} }
} }
else assert(env->i->n_data_dirs == 0); else assert(env->i->n_data_dirs == 0);
temp = (char**) toku_realloc(env->i->data_dirs, (1 + env->i->n_data_dirs) * sizeof(char*)); new_dir = toku_strdup(dir);
if (temp==NULL) {assert(errno == ENOMEM); return ENOMEM;} if (0) {
env->i->data_dirs[env->i->n_data_dirs] = toku_strdup(dir); died1:
if (env->i->data_dirs[env->i->n_data_dirs]==NULL) { toku_free(new_dir);
assert(errno==ENOMEM);
r = ENOMEM;
if (env->i->n_data_dirs > 0) {
toku_free(env->i->data_dirs);
env->i->data_dirs = NULL;
}
else env->i->data_dirs = toku_realloc(env->i->data_dirs, env->i->n_data_dirs * sizeof(char*));
return r; return r;
} }
if (new_dir==NULL) {assert(errno == ENOMEM); return ENOMEM;}
temp = (char**) toku_realloc(env->i->data_dirs, (1 + env->i->n_data_dirs) * sizeof(char*));
if (temp==NULL) {assert(errno == ENOMEM); r = ENOMEM; goto died1;}
else env->i->data_dirs = temp;
env->i->data_dirs[env->i->n_data_dirs] = new_dir;
env->i->n_data_dirs++; env->i->n_data_dirs++;
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment