Commit cd86a31e authored by Barry Perlman's avatar Barry Perlman Committed by Yoni Fogel

[t:2499] Replace multiple free_loader() calls for each error condition in...

[t:2499] Replace multiple free_loader() calls for each error condition in toku_loader_create_loader() with single call on exit.


git-svn-id: file:///svn/toku/tokudb@20207 c7de825b-a66e-492c-adef-691d508d4ae1
parent aa244950
......@@ -156,7 +156,6 @@ int toku_loader_create_loader(DB_ENV *env,
int n = snprintf(loader->i->temp_file_template, MAX_FILE_SIZE, "%s/%s%s", env->i->dir, loader_temp_prefix, loader_temp_suffix);
if ( !(n>0 && n<MAX_FILE_SIZE) ) {
free_loader(loader);
rval = -1;
goto create_exit;
}
......@@ -186,7 +185,6 @@ int toku_loader_create_loader(DB_ENV *env,
if (r!=0) break;
}
if ( r!=0 ) {
free_loader(loader);
rval = -1;
goto create_exit;
}
......@@ -221,7 +219,6 @@ int toku_loader_create_loader(DB_ENV *env,
if ( r!=0 ) {
toku_free(new_inames_in_env);
toku_free(descriptors);
free_loader(loader);
rval = r;
goto create_exit;
}
......@@ -249,8 +246,10 @@ int toku_loader_create_loader(DB_ENV *env,
if (status.current > status.max)
status.max = status.current; // not worth a lock to make threadsafe, may be inaccurate
}
else
else {
(void) toku_sync_fetch_and_increment_uint64(&status.create_fail);
free_loader(loader);
}
return rval;
}
......
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