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

[t:3102] Restore brtloader_fi_close_all() to brtloader-internal.h (needed by...

[t:3102] Restore brtloader_fi_close_all() to brtloader-internal.h (needed by test programs).  Also clarify use of return values in brtloader_fi_close().

git-svn-id: file:///svn/toku/tokudb@26360 c7de825b-a66e-492c-adef-691d508d4ae1
parent 300cdf3b
...@@ -227,6 +227,7 @@ int brt_loader_write_file_to_dbfile (int outfile, FIDX infile, BRTLOADER bl, con ...@@ -227,6 +227,7 @@ int brt_loader_write_file_to_dbfile (int outfile, FIDX infile, BRTLOADER bl, con
int brtloader_init_file_infos (struct file_infos *fi); int brtloader_init_file_infos (struct file_infos *fi);
void brtloader_fi_destroy (struct file_infos *fi, BOOL is_error); void brtloader_fi_destroy (struct file_infos *fi, BOOL is_error);
int brtloader_fi_close (struct file_infos *fi, FIDX idx); int brtloader_fi_close (struct file_infos *fi, FIDX idx);
int brtloader_fi_close_all (struct file_infos *fi);
int brtloader_fi_reopen (struct file_infos *fi, FIDX idx, const char *mode); int brtloader_fi_reopen (struct file_infos *fi, FIDX idx, const char *mode);
int brtloader_fi_unlink (struct file_infos *fi, FIDX idx); int brtloader_fi_unlink (struct file_infos *fi, FIDX idx);
......
...@@ -248,19 +248,25 @@ int brtloader_fi_reopen (struct file_infos *fi, FIDX idx, const char *mode) { ...@@ -248,19 +248,25 @@ int brtloader_fi_reopen (struct file_infos *fi, FIDX idx, const char *mode) {
int brtloader_fi_close (struct file_infos *fi, FIDX idx) int brtloader_fi_close (struct file_infos *fi, FIDX idx)
{ {
int result = 0; int result = 0;
{ int r2 = toku_pthread_mutex_lock(&fi->lock); resource_assert_zero(r2); } {
int r = toku_pthread_mutex_lock(&fi->lock);
resource_assert_zero(r);
}
invariant(idx.idx >=0 && idx.idx < fi->n_files); invariant(idx.idx >=0 && idx.idx < fi->n_files);
if (fi->file_infos[idx.idx].is_open) { if (fi->file_infos[idx.idx].is_open) {
invariant(fi->n_files_open>0); // loader-cleanup-test failure invariant(fi->n_files_open>0); // loader-cleanup-test failure
fi->n_files_open--; fi->n_files_open--;
fi->file_infos[idx.idx].is_open = FALSE; fi->file_infos[idx.idx].is_open = FALSE;
result = toku_os_fclose(fi->file_infos[idx.idx].file); int r = toku_os_fclose(fi->file_infos[idx.idx].file);
cleanup_big_buffer(&fi->file_infos[idx.idx]); if (r)
if (result)
result = errno; result = errno;
cleanup_big_buffer(&fi->file_infos[idx.idx]);
} else } else
result = EINVAL; result = EINVAL;
{ int r2 = toku_pthread_mutex_unlock(&fi->lock); resource_assert_zero(r2); } {
int r = toku_pthread_mutex_unlock(&fi->lock);
resource_assert_zero(r);
}
return result; return result;
} }
...@@ -285,7 +291,7 @@ int brtloader_fi_unlink (struct file_infos *fi, FIDX idx) { ...@@ -285,7 +291,7 @@ int brtloader_fi_unlink (struct file_infos *fi, FIDX idx) {
return result; return result;
} }
static int int
brtloader_fi_close_all(struct file_infos *fi) { brtloader_fi_close_all(struct file_infos *fi) {
int rval = 0; int rval = 0;
for (int i = 0; i < fi->n_files; i++) { for (int i = 0; i < fi->n_files; i++) {
......
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