X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;ds=sidebyside;f=index%2Fmain.c;h=553e280e83d4a56e99e8ec8ea41aeda9211107ad;hb=85df66537199c30a492ad54be4fbe25fa77e18c8;hp=f40cd03e4d14a35ae6500db349737e52b232f038;hpb=bf27228e5485151ee52bfd87dd91b025544ab6b2;p=idzebra-moved-to-github.git diff --git a/index/main.c b/index/main.c index f40cd03..553e280 100644 --- a/index/main.c +++ b/index/main.c @@ -4,7 +4,17 @@ * Sebastian Hammer, Adam Dickmeiss * * $Log: main.c,v $ - * Revision 1.28 1995-12-08 16:22:56 adam + * Revision 1.30 1995-12-12 16:00:59 adam + * System call sync(2) used after update/commit. + * Locking (based on fcntl) uses F_EXLCK and F_SHLCK instead of F_WRLCK + * and F_RDLCK. + * + * Revision 1.29 1995/12/11 11:43:30 adam + * Locking based on fcntl instead of flock. + * Setting commitEnable removed. Command line option -n can be used to + * prevent commit if commit setting is defined in the configuration file. + * + * Revision 1.28 1995/12/08 16:22:56 adam * Work on update while servers are running. Three lock files introduced. * The servers reload their registers when necessary, but they don't * reestablish result sets yet. @@ -123,6 +133,7 @@ int main (int argc, char **argv) char *arg; char *configName = NULL; int nsections; + int disableCommit = 0; struct recordGroup rGroupDef; @@ -142,16 +153,18 @@ int main (int argc, char **argv) " update Update index with files below .\n" " If is empty filenames are read from stdin.\n" " delete Delete index with files below .\n" + " commit Commit changes\n" "Options:\n" " -t Index files as (grs or text).\n" " -c Read configuration file .\n" " -g Index files according to group settings.\n" " -d Records belong to Z39.50 database .\n" " -m Use before flushing keys to disk.\n" + " -n Don't use commit system\n" " -v Set logging to .\n"); exit (1); } - while ((ret = options ("t:c:g:d:m:v:", argv, argc, &arg)) != -2) + while ((ret = options ("t:c:g:d:m:v:n", argv, argc, &arg)) != -2) { if (ret == 0) { @@ -177,10 +190,16 @@ int main (int argc, char **argv) else if (!strcmp (arg, "commit")) { zebraIndexLock (1); - rval = res_get (common_resource, "commitEnable"); - if (rval && atoi (rval)) + rval = res_get (common_resource, "commit"); + if (rval && *rval) bf_cache (1); - + else + { + logf (LOG_FATAL, "Cannot perform commit"); + logf (LOG_FATAL, "No commit area defined " + "in the configuration file"); + exit (1); + } if (bf_commitExists ()) { logf (LOG_LOG, "Commit start"); @@ -188,6 +207,7 @@ int main (int argc, char **argv) zebraIndexWait (1); logf (LOG_LOG, "Commit execute"); bf_commitExec (); + sync (); zebraIndexLockMsg ("d"); zebraIndexWait (0); logf (LOG_LOG, "Commit clean"); @@ -199,14 +219,8 @@ int main (int argc, char **argv) else if (!strcmp (arg, "stat") || !strcmp (arg, "status")) { zebraIndexLock (0); - bf_cache (0); - rec_prstat (); - } - else if (!strcmp (arg, "cstat") || !strcmp (arg, "cstatus")) - { - zebraIndexLock (1); - rval = res_get (common_resource, "commitEnable"); - if (rval && atoi(rval)) + rval = res_get (common_resource, "commit"); + if (rval && *rval) { bf_cache (1); zebraIndexLockMsg ("r"); @@ -224,14 +238,17 @@ int main (int argc, char **argv) struct recordGroup rGroup; zebraIndexLock (0); - rval = res_get (common_resource, "commitEnable"); - if (rval && atoi(rval)) + rval = res_get (common_resource, "commit"); + if (rval && *rval && !disableCommit) { bf_cache (1); zebraIndexLockMsg ("r"); } else + { + bf_cache (0); zebraIndexLockMsg ("w"); + } zebraIndexWait (0); memcpy (&rGroup, &rGroupDef, sizeof(rGroup)); @@ -254,6 +271,7 @@ int main (int argc, char **argv) logf (LOG_LOG, "Merging with index"); key_input (FNAME_WORD_DICT, FNAME_WORD_ISAM, nsections, 60); + sync (); } } } @@ -277,6 +295,8 @@ int main (int argc, char **argv) configName = arg; else if (ret == 't') rGroupDef.recordType = arg; + else if (ret == 'n') + disableCommit = 1; else { logf (LOG_FATAL, "Unknown option '-%s'", arg);