Commit 97e5fa15 authored by Yoni Fogel's avatar Yoni Fogel

Addresses #1378

dbremove will delete dirty dbs (if no subname)

git-svn-id: file:///svn/toku/tokudb@9151 c7de825b-a66e-492c-adef-691d508d4ae1
parent 23acaa97
...@@ -3177,6 +3177,10 @@ static int toku_db_remove(DB * db, const char *fname, const char *dbname, u_int3 ...@@ -3177,6 +3177,10 @@ static int toku_db_remove(DB * db, const char *fname, const char *dbname, u_int3
//TODO: Verify DB* db not yet opened //TODO: Verify DB* db not yet opened
//TODO: Verify db file not in use. (all dbs in the file must be unused) //TODO: Verify db file not in use. (all dbs in the file must be unused)
r = toku_db_open(db, NULL, fname, dbname, DB_UNKNOWN, 0, S_IRWXU|S_IRWXG|S_IRWXO); r = toku_db_open(db, NULL, fname, dbname, DB_UNKNOWN, 0, S_IRWXU|S_IRWXG|S_IRWXO);
if (r==TOKUDB_DIRTY_DICTIONARY && !dbname) {
need_close = FALSE;
goto delete_db_file;
}
if (r!=0) { goto cleanup; } if (r!=0) { goto cleanup; }
if (db->i->lt) { if (db->i->lt) {
/* Lock tree exists, therefore: /* Lock tree exists, therefore:
...@@ -3197,6 +3201,7 @@ static int toku_db_remove(DB * db, const char *fname, const char *dbname, u_int3 ...@@ -3197,6 +3201,7 @@ static int toku_db_remove(DB * db, const char *fname, const char *dbname, u_int3
if (r!=0) { goto cleanup; } if (r!=0) { goto cleanup; }
} }
if (!dbname) { if (!dbname) {
delete_db_file:
r = find_db_file(db->dbenv, fname, &full_name); r = find_db_file(db->dbenv, fname, &full_name);
if (r!=0) { goto cleanup; } if (r!=0) { goto cleanup; }
assert(full_name); assert(full_name);
......
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