Index statistics working again
[idzebra-moved-to-github.git] / index / main.c
index 1b91efc..73a0515 100644 (file)
@@ -2,7 +2,7 @@
  * Copyright (C) 1994-2002, Index Data
  * All rights reserved.
  *
- * $Id: main.c,v 1.83 2002-04-04 14:14:13 adam Exp $
+ * $Id: main.c,v 1.89 2002-04-26 08:44:47 adam Exp $
  */
 #include <stdio.h>
 #include <string.h>
@@ -12,6 +12,9 @@
 #else
 #include <unistd.h>
 #endif
+#if HAVE_SYS_TIMES_H
+#include <sys/times.h>
+#endif
 
 #include <yaz/data1.h>
 #include "zebraapi.h"
@@ -27,6 +30,9 @@ int main (int argc, char **argv)
     int nsections = 0;
     int disableCommit = 0;
     size_t mem_max = 0;
+#if HAVE_SYS_TIMES_H
+    struct tms tms1, tms2;
+#endif
 #ifndef WIN32
     char nbuf[100];
 #endif
@@ -41,6 +47,9 @@ int main (int argc, char **argv)
     sprintf(nbuf, "%.40s(%d)", *argv, getpid());
     yaz_log_init_prefix (nbuf);
 #endif
+#if HAVE_SYS_TIMES_H
+    times(&tms1);
+#endif
 
     rGroupDef.groupName = NULL;
     rGroupDef.databaseName = NULL;
@@ -89,20 +98,29 @@ int main (int argc, char **argv)
                 if (!zs)
                 {
 #if ZMBOL
-                    logf (LOG_LOG, "zmbol version %s %s",
+                    logf (LOG_LOG, "Z'mbol version %s %s",
                           ZEBRAVER, ZEBRADATE);
 #else
-                    logf (LOG_LOG, "zebra version %s %s",
+                    logf (LOG_LOG, "Zebra version %s %s",
                           ZEBRAVER, ZEBRADATE);
 #endif
                     zs = zebra_start (configName ? configName : "zebra.cfg");
-
+                    if (!zs)
+                        exit (1);
                     zh = zebra_open (zs);
+                    if (disableCommit)
+                        zebra_shadow_enable (zh, 0);
                 }
                 if (rGroupDef.databaseName)
-                    zebra_select_database (zh, rGroupDef.databaseName);
+                {
+                    if (zebra_select_database (zh, rGroupDef.databaseName))
+                        exit (1);
+                }
                 else
-                    zebra_select_database (zh, "Default");
+                {
+                    if (zebra_select_database (zh, "Default"))
+                        exit (1);
+                }
 
                 if (!strcmp (arg, "update"))
                     cmd = 'u';
@@ -128,7 +146,7 @@ int main (int argc, char **argv)
                 }
                 else if (!strcmp (arg, "stat") || !strcmp (arg, "status"))
                 {
-                    assert (!"todo");
+                    zebra_register_statistics (zh);
                 }
                 else if (!strcmp (arg, "compact"))
                 {
@@ -212,6 +230,12 @@ int main (int argc, char **argv)
     }
     zebra_close (zh);
     zebra_stop (zs);
+#if HAVE_SYS_TIMES_H
+    times(&tms2);
+    yaz_log (LOG_LOG, "zebraidx user/system: %ld/%ld",
+               (long) tms2.tms_utime - tms1.tms_utime,
+               (long) tms2.tms_stime - tms1.tms_stime);
+#endif
     exit (0);
     return 0;
 }