Commit b1e6d85b authored by Yoni Fogel's avatar Yoni Fogel

tokudb_dump handles signals without corrupting db

git-svn-id: file:///svn/tokudb@1045 c7de825b-a66e-492c-adef-691d508d4ae1
parent 2ef7951f
...@@ -192,4 +192,29 @@ int verify_library_version() ...@@ -192,4 +192,29 @@ int verify_library_version()
return EXIT_SUCCESS; return EXIT_SUCCESS;
} }
static int last_caught = 0;
static void catch_signal(int signal) {
last_caught = signal;
if (last_caught == 0) last_caught = SIGINT;
}
void init_catch_signals(void) {
signal(SIGHUP, catch_signal);
signal(SIGINT, catch_signal);
signal(SIGPIPE, catch_signal);
signal(SIGTERM, catch_signal);
}
int caught_any_signals(void) {
return last_caught != 0;
}
void resend_signals(void) {
if (last_caught) {
signal(last_caught, SIG_DFL);
raise(last_caught);
}
}
#endif /* #if !defined(TOKUDB_COMMON_H) */ #endif /* #if !defined(TOKUDB_COMMON_H) */
...@@ -160,10 +160,13 @@ int main(int argc, char *argv[]) { ...@@ -160,10 +160,13 @@ int main(int argc, char *argv[]) {
g.exitcode = usage(); g.exitcode = usage();
goto cleanup; goto cleanup;
} }
//TODO: /* Handle possible interruptions/signals. */
init_catch_signals();
g.database = argv[0]; g.database = argv[0];
if (caught_any_signals()) goto cleanup;
if (create_init_env() != 0) goto error; if (create_init_env() != 0) goto error;
if (caught_any_signals()) goto cleanup;
if (dump_database() != 0) goto error; if (dump_database() != 0) goto error;
if (false) { if (false) {
error: error:
...@@ -175,7 +178,7 @@ cleanup: ...@@ -175,7 +178,7 @@ cleanup:
g.exitcode = EXIT_FAILURE; g.exitcode = EXIT_FAILURE;
fprintf(stderr, "%s: %s: dbenv->close\n", g.progname, db_strerror(retval)); fprintf(stderr, "%s: %s: dbenv->close\n", g.progname, db_strerror(retval));
} }
//TODO: /* Resend any caught signal. */ resend_signals();
if (g.subdatabase) free(g.subdatabase); if (g.subdatabase) free(g.subdatabase);
return g.exitcode; return g.exitcode;
...@@ -200,8 +203,11 @@ int dump_database() ...@@ -200,8 +203,11 @@ int dump_database()
} }
*/ */
if (open_database() != 0) goto error; if (open_database() != 0) goto error;
if (caught_any_signals()) goto cleanup;
if (g.header && dump_header() != 0) goto error; if (g.header && dump_header() != 0) goto error;
if (caught_any_signals()) goto cleanup;
if (dump_pairs() != 0) goto error; if (dump_pairs() != 0) goto error;
if (caught_any_signals()) goto cleanup;
if (g.footer && dump_footer() != 0) goto error; if (g.footer && dump_footer() != 0) goto error;
if (false) { if (false) {
...@@ -299,7 +305,7 @@ int dump_header() ...@@ -299,7 +305,7 @@ int dump_header()
/*assert(g.dbtype == DB_BTREE || (g.dbtype == DB_UNKNOWN && g.opened_dbtype == DB_BTREE));*/ /*assert(g.dbtype == DB_BTREE || (g.dbtype == DB_UNKNOWN && g.opened_dbtype == DB_BTREE));*/
printf("type=btree\n"); printf("type=btree\n");
//TODO: Get page size from db. Currently tokudb does not support db->get_pagesize. //TODO: Get page size from db. Currently tokudb does not support db->get_pagesize.
printf("db_pagesize=4096\n"); //Don't print this out //printf("db_pagesize=4096\n");
if (g.subdatabase) { if (g.subdatabase) {
printf("subdatabase="); printf("subdatabase=");
outputplaintextstring(g.subdatabase); outputplaintextstring(g.subdatabase);
...@@ -413,6 +419,7 @@ int dump_pairs() ...@@ -413,6 +419,7 @@ int dump_pairs()
goto error; goto error;
} }
while ((retval = dbc->c_get(dbc, &key, &data, DB_NEXT)) == 0) { while ((retval = dbc->c_get(dbc, &key, &data, DB_NEXT)) == 0) {
if (caught_any_signals()) goto cleanup;
if (dump_dbt(&key) != 0) goto error; if (dump_dbt(&key) != 0) goto error;
if (dump_dbt(&data) != 0) goto error; if (dump_dbt(&data) != 0) goto error;
} }
......
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