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

[t:3102] Propogate error return up call stack when fclose() fails. Make...

[t:3102] Propogate error return up call stack when fclose() fails.  Make brtloader_fi_close_all() static to brtloader.c and delete its signature from brtloader-internal.h.

git-svn-id: file:///svn/toku/tokudb@26318 c7de825b-a66e-492c-adef-691d508d4ae1
parent c09af40a
...@@ -227,7 +227,6 @@ int brt_loader_write_file_to_dbfile (int outfile, FIDX infile, BRTLOADER bl, con ...@@ -227,7 +227,6 @@ 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);
void 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);
......
...@@ -254,10 +254,9 @@ int brtloader_fi_close (struct file_infos *fi, FIDX idx) ...@@ -254,10 +254,9 @@ int brtloader_fi_close (struct file_infos *fi, FIDX idx)
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;
int r = toku_os_fclose(fi->file_infos[idx.idx].file); result = toku_os_fclose(fi->file_infos[idx.idx].file);
if (r == 0)
cleanup_big_buffer(&fi->file_infos[idx.idx]); cleanup_big_buffer(&fi->file_infos[idx.idx]);
else if (result)
result = errno; result = errno;
} else } else
result = EINVAL; result = EINVAL;
...@@ -286,11 +285,17 @@ int brtloader_fi_unlink (struct file_infos *fi, FIDX idx) { ...@@ -286,11 +285,17 @@ int brtloader_fi_unlink (struct file_infos *fi, FIDX idx) {
return result; return result;
} }
void brtloader_fi_close_all(struct file_infos *fi) { static int
brtloader_fi_close_all(struct file_infos *fi) {
int rval = 0;
for (int i = 0; i < fi->n_files; i++) { for (int i = 0; i < fi->n_files; i++) {
int r;
FIDX idx = { i }; FIDX idx = { i };
(void ) brtloader_fi_close(fi, idx); r = brtloader_fi_close(fi, idx);
if (rval == 0 && r)
rval = r; // capture first error
} }
return rval;
} }
int brtloader_open_temp_file (BRTLOADER bl, FIDX *file_idx) int brtloader_open_temp_file (BRTLOADER bl, FIDX *file_idx)
...@@ -1031,9 +1036,12 @@ static int loader_do_put(BRTLOADER bl, ...@@ -1031,9 +1036,12 @@ static int loader_do_put(BRTLOADER bl,
return result; return result;
} }
static int finish_extractor (BRTLOADER bl) { static int
finish_extractor (BRTLOADER bl) {
//printf("%s:%d now finishing extraction\n", __FILE__, __LINE__); //printf("%s:%d now finishing extraction\n", __FILE__, __LINE__);
int rval;
BL_TRACE(blt_do_put); BL_TRACE(blt_do_put);
if (bl->primary_rowset.n_rows>0) { if (bl->primary_rowset.n_rows>0) {
enqueue_for_extraction(bl); enqueue_for_extraction(bl);
...@@ -1060,10 +1068,10 @@ static int finish_extractor (BRTLOADER bl) { ...@@ -1060,10 +1068,10 @@ static int finish_extractor (BRTLOADER bl) {
invariant(r==0); invariant(r==0);
} }
brtloader_fi_close_all(&bl->file_infos); rval = brtloader_fi_close_all(&bl->file_infos);
//printf("%s:%d joined\n", __FILE__, __LINE__); //printf("%s:%d joined\n", __FILE__, __LINE__);
return 0; return rval;
} }
static const DBT zero_dbt = {0,0,0,0}; static const DBT zero_dbt = {0,0,0,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