X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=index%2Fmain.c;h=a3fb5107dd9aaaa7fd2de2c66ac428ed4e3b6d8c;hb=4495fac3b7f760814dd3b41d0f64e5077193eeee;hp=f40cd03e4d14a35ae6500db349737e52b232f038;hpb=77006d65669383febd8cd4d1541278723c578564;p=idzebra-moved-to-github.git diff --git a/index/main.c b/index/main.c index f40cd03..a3fb510 100644 --- a/index/main.c +++ b/index/main.c @@ -4,7 +4,12 @@ * Sebastian Hammer, Adam Dickmeiss * * $Log: main.c,v $ - * Revision 1.28 1995-12-08 16:22:56 adam + * 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 +128,7 @@ int main (int argc, char **argv) char *arg; char *configName = NULL; int nsections; + int disableCommit = 0; struct recordGroup rGroupDef; @@ -148,10 +154,11 @@ int main (int argc, char **argv) " -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 +184,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"); @@ -205,8 +218,8 @@ int main (int argc, char **argv) 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 +237,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)); @@ -277,6 +293,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);