Commit 3449ee16 authored by Zardosht Kasheff's avatar Zardosht Kasheff Committed by Yoni Fogel

[t:2151], more changes as result of code review, assert all db->close succeeds

git-svn-id: file:///svn/mysql/tokudb-engine/src@16275 c7de825b-a66e-492c-adef-691d508d4ae1
parent 42498ddc
...@@ -197,6 +197,7 @@ static int free_share(TOKUDB_SHARE * share, bool mutex_is_locked) { ...@@ -197,6 +197,7 @@ static int free_share(TOKUDB_SHARE * share, bool mutex_is_locked) {
} }
if (share->key_file[i]) { if (share->key_file[i]) {
error = share->key_file[i]->close(share->key_file[i], 0); error = share->key_file[i]->close(share->key_file[i], 0);
assert(error == 0);
if (error) { if (error) {
result = error; result = error;
} }
...@@ -216,6 +217,7 @@ static int free_share(TOKUDB_SHARE * share, bool mutex_is_locked) { ...@@ -216,6 +217,7 @@ static int free_share(TOKUDB_SHARE * share, bool mutex_is_locked) {
my_free(share->blob_fields, MYF(MY_ALLOW_ZERO_PTR)); my_free(share->blob_fields, MYF(MY_ALLOW_ZERO_PTR));
if (share->status_block && (error = share->status_block->close(share->status_block, 0))) { if (share->status_block && (error = share->status_block->close(share->status_block, 0))) {
assert(error == 0);
result = error; result = error;
} }
...@@ -1053,7 +1055,8 @@ int ha_tokudb::open_status_dictionary(DB** ptr, const char* name, DB_TXN* txn) { ...@@ -1053,7 +1055,8 @@ int ha_tokudb::open_status_dictionary(DB** ptr, const char* name, DB_TXN* txn) {
cleanup: cleanup:
if (error) { if (error) {
if (*ptr) { if (*ptr) {
(*ptr)->close(*ptr, 0); int r = (*ptr)->close(*ptr, 0);
assert(r==0);
*ptr = NULL; *ptr = NULL;
} }
} }
...@@ -1099,10 +1102,11 @@ int ha_tokudb::open_main_dictionary(const char* name, bool is_read_only, DB_TXN* ...@@ -1099,10 +1102,11 @@ int ha_tokudb::open_main_dictionary(const char* name, bool is_read_only, DB_TXN*
exit: exit:
if (error) { if (error) {
if (share->file) { if (share->file) {
share->file->close( int r = share->file->close(
share->file, share->file,
0 0
); );
assert(r==0);
share->file = NULL; share->file = NULL;
share->key_file[primary_key] = NULL; share->key_file[primary_key] = NULL;
} }
...@@ -1149,7 +1153,8 @@ int ha_tokudb::open_secondary_dictionary(DB** ptr, KEY* key_info, const char* na ...@@ -1149,7 +1153,8 @@ int ha_tokudb::open_secondary_dictionary(DB** ptr, KEY* key_info, const char* na
cleanup: cleanup:
if (error) { if (error) {
if (*ptr) { if (*ptr) {
(*ptr)->close(*ptr, 0); int r = (*ptr)->close(*ptr, 0);
assert(r==0);
*ptr = NULL; *ptr = NULL;
} }
} }
...@@ -4761,7 +4766,8 @@ static int create_sub_table(const char *table_name, DBT* row_descriptor, DB_TXN* ...@@ -4761,7 +4766,8 @@ static int create_sub_table(const char *table_name, DBT* row_descriptor, DB_TXN*
error = 0; error = 0;
exit: exit:
if (file) { if (file) {
file->close(file, 0); int r = file->close(file, 0);
assert(r==0);
} }
TOKUDB_DBUG_RETURN(error); TOKUDB_DBUG_RETURN(error);
} }
...@@ -5022,7 +5028,8 @@ int ha_tokudb::create(const char *name, TABLE * form, HA_CREATE_INFO * create_in ...@@ -5022,7 +5028,8 @@ int ha_tokudb::create(const char *name, TABLE * form, HA_CREATE_INFO * create_in
error = 0; error = 0;
cleanup: cleanup:
if (status_block != NULL) { if (status_block != NULL) {
status_block->close(status_block, 0); int r = status_block->close(status_block, 0);
assert(r==0);
} }
if (txn) { if (txn) {
if (error) { if (error) {
...@@ -5180,11 +5187,11 @@ int ha_tokudb::delete_or_rename_table (const char* from_name, const char* to_nam ...@@ -5180,11 +5187,11 @@ int ha_tokudb::delete_or_rename_table (const char* from_name, const char* to_nam
if (error) { goto cleanup; } if (error) { goto cleanup; }
error = status_cursor->c_close(status_cursor); error = status_cursor->c_close(status_cursor);
if (error) { goto cleanup; }
status_cursor = NULL; status_cursor = NULL;
if (error) { goto cleanup; }
error = status_db->close(status_db, 0); error = status_db->close(status_db, 0);
if (error) { goto cleanup; } assert(error == 0);
status_db = NULL; status_db = NULL;
// //
...@@ -5199,7 +5206,8 @@ cleanup: ...@@ -5199,7 +5206,8 @@ cleanup:
status_cursor->c_close(status_cursor); status_cursor->c_close(status_cursor);
} }
if (status_db) { if (status_db) {
status_db->close(status_db, 0); int r = status_db->close(status_db, 0);
assert(r==0);
} }
if (txn) { if (txn) {
if (error) { if (error) {
...@@ -5837,10 +5845,11 @@ cleanup: ...@@ -5837,10 +5845,11 @@ cleanup:
curr_index = curr_num_DBs; curr_index = curr_num_DBs;
for (uint i = 0; i < num_of_keys; i++, curr_index++) { for (uint i = 0; i < num_of_keys; i++, curr_index++) {
if (share->key_file[curr_index]) { if (share->key_file[curr_index]) {
share->key_file[curr_index]->close( int r = share->key_file[curr_index]->close(
share->key_file[curr_index], share->key_file[curr_index],
0 0
); );
assert(r==0);
share->key_file[curr_index] = NULL; share->key_file[curr_index] = NULL;
} }
} }
...@@ -5887,7 +5896,8 @@ int ha_tokudb::prepare_drop_index(TABLE *table_arg, uint *key_num, uint num_of_k ...@@ -5887,7 +5896,8 @@ int ha_tokudb::prepare_drop_index(TABLE *table_arg, uint *key_num, uint num_of_k
for (uint i = 0; i < num_of_keys; i++) { for (uint i = 0; i < num_of_keys; i++) {
uint curr_index = key_num[i]; uint curr_index = key_num[i];
share->key_file[curr_index]->close(share->key_file[curr_index],0); int r = share->key_file[curr_index]->close(share->key_file[curr_index],0);
assert(r==0);
share->key_file[curr_index] = NULL; share->key_file[curr_index] = NULL;
error = remove_key_name_from_status(share->status_block, table_arg->key_info[curr_index].name, txn); error = remove_key_name_from_status(share->status_block, table_arg->key_info[curr_index].name, txn);
...@@ -6060,7 +6070,7 @@ int ha_tokudb::truncate_dictionary( uint keynr, DB_TXN* txn ) { ...@@ -6060,7 +6070,7 @@ int ha_tokudb::truncate_dictionary( uint keynr, DB_TXN* txn ) {
bool is_pk = (keynr == primary_key); bool is_pk = (keynr == primary_key);
error = share->key_file[keynr]->close(share->key_file[keynr], 0); error = share->key_file[keynr]->close(share->key_file[keynr], 0);
if (error) { goto cleanup; } assert(error == 0);
share->key_file[keynr] = NULL; share->key_file[keynr] = NULL;
if (is_pk) { share->file = NULL; } if (is_pk) { share->file = NULL; }
......
...@@ -322,7 +322,8 @@ static int tokudb_init_func(void *p) { ...@@ -322,7 +322,8 @@ static int tokudb_init_func(void *p) {
error: error:
if (metadata_db) { if (metadata_db) {
metadata_db->close(metadata_db, 0); int rr = metadata_db->close(metadata_db, 0);
assert(rr==0);
} }
if (db_env) { if (db_env) {
db_env->close(db_env, 0); db_env->close(db_env, 0);
...@@ -356,7 +357,8 @@ int tokudb_end(handlerton * hton, ha_panic_function type) { ...@@ -356,7 +357,8 @@ int tokudb_end(handlerton * hton, ha_panic_function type) {
TOKUDB_DBUG_ENTER("tokudb_end"); TOKUDB_DBUG_ENTER("tokudb_end");
int error = 0; int error = 0;
if (metadata_db) { if (metadata_db) {
metadata_db->close(metadata_db, 0); int r = metadata_db->close(metadata_db, 0);
assert(r==0);
} }
if (db_env) { if (db_env) {
if (tokudb_init_flags & DB_INIT_LOG) if (tokudb_init_flags & DB_INIT_LOG)
...@@ -645,9 +647,11 @@ static bool tokudb_show_data_size(THD * thd, stat_print_fn * stat_print, bool ex ...@@ -645,9 +647,11 @@ static bool tokudb_show_data_size(THD * thd, stat_print_fn * stat_print, bool ex
num_bytes_in_db += curr_num_bytes; num_bytes_in_db += curr_num_bytes;
curr_db->close(curr_db, 0); {
int r = curr_db->close(curr_db, 0);
assert(r==0);
curr_db = NULL; curr_db = NULL;
}
my_free(newname,MYF(MY_ALLOW_ZERO_PTR)); my_free(newname,MYF(MY_ALLOW_ZERO_PTR));
} }
} }
...@@ -667,7 +671,8 @@ static bool tokudb_show_data_size(THD * thd, stat_print_fn * stat_print, bool ex ...@@ -667,7 +671,8 @@ static bool tokudb_show_data_size(THD * thd, stat_print_fn * stat_print, bool ex
cleanup: cleanup:
if (curr_db) { if (curr_db) {
curr_db->close(curr_db, 0); int r = curr_db->close(curr_db, 0);
assert(r==0);
} }
if (tmp_cursor) { if (tmp_cursor) {
tmp_cursor->c_close(tmp_cursor); tmp_cursor->c_close(tmp_cursor);
......
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