X-Git-Url: http://git.tuebingen.mpg.de/?p=paraslash.git;a=blobdiff_plain;f=fsck.c;h=9688a729ef473ec1a83555479aa79d978c71caef;hp=bbacdf26e9a39ad5cfdb7b785b73e01aff9ea1de;hb=5d581fbd46a6d1949bfd876aec63041dc6724eb0;hpb=a3b11ab44695864ba80eb3d883cb6c99e394b36a;ds=inline diff --git a/fsck.c b/fsck.c index bbacdf26..9688a729 100644 --- a/fsck.c +++ b/fsck.c @@ -1,5 +1,5 @@ /* - * Copyright (C) 1997-2007 Andre Noll + * Copyright (C) 1997-2008 Andre Noll * * Licensed under the GPL v2. For licencing details see COPYING. */ @@ -621,6 +621,9 @@ out: static void fsck_cleanup(struct osl_table *t) { int i; + + if (!t) + return; if (t->desc->column_descriptions) { struct osl_column_description *cd; for (i = 0; i < t->desc->num_columns; i++) { @@ -629,10 +632,8 @@ static void fsck_cleanup(struct osl_table *t) } free(t->desc->column_descriptions); } - if (t) { - free(t->columns); - free(t); - } + free(t->columns); + free(t); } @@ -884,14 +885,22 @@ static int check_table(char *base_dir, char *table_name) }; int ret; + PARA_INFO_LOG("checking table %s\n", table_name); if (!conf.no_fsck_given) { ret = fsck(&desc); if (ret < 0) - return ret; + goto out; } + ret = 1; if (!conf.dump_dir_given || !*conf.dump_dir_arg) - return 1; - return dump_table(conf.dump_dir_arg, &desc); + goto out; + ret = dump_table(conf.dump_dir_arg, &desc); +out: + if (ret < 0) + PARA_ERROR_LOG("failed to check table %s\n", table_name); + else + PARA_NOTICE_LOG("successfully checked table %s\n", table_name); + return ret; } static int check_all_tables(char *base_dir) @@ -938,7 +947,7 @@ int main(int argc, char **argv) } HANDLE_VERSION_FLAG("fsck", conf); if (conf.base_dir_given) - base_dir = conf.base_dir_arg; + base_dir = para_strdup(conf.base_dir_arg); else { char *home = para_homedir(); base_dir = make_message("%s/.paraslash/afs_database", home); @@ -954,9 +963,18 @@ int main(int argc, char **argv) break; } out: - if (!conf.base_dir_given) + if (ret < 0) { + PARA_ERROR_LOG("%s%s: %s\n", + base_dir? "base_dir: " : "", + base_dir? base_dir : "", + para_strerror(-ret) + ); + if (conf.loglevel_arg > 1) + PARA_EMERG_LOG("re-run with \"--logelvel %d\" to increase verbosity\n", + conf.loglevel_arg - 1); + } else + PARA_NOTICE_LOG("success\n"); + if (base_dir) free(base_dir); - if (ret < 0) - PARA_ERROR_LOG("%s\n", PARA_STRERROR(-ret)); return ret < 0? EXIT_FAILURE : EXIT_SUCCESS; }