Clients prints options in InitResponse.
[yaz-moved-to-github.git] / util / marcdump.c
index 2eddc42..551bd07 100644 (file)
@@ -1,10 +1,38 @@
 /*
- * Copyright (c) 1995, Index Data
+ * Copyright (c) 1995-2000, Index Data
  * See the file LICENSE for details.
  * Sebastian Hammer, Adam Dickmeiss
  *
  * $Log: marcdump.c,v $
- * Revision 1.3  1995-05-16 08:51:12  quinn
+ * Revision 1.12  2000-10-02 11:07:45  adam
+ * Added peer_name member for bend_init handler. Changed the YAZ
+ * client so that tcp: can be avoided in target spec.
+ *
+ * Revision 1.11  2000/07/04 08:53:22  adam
+ * Fixed bug.
+ *
+ * Revision 1.10  2000/02/29 13:44:55  adam
+ * Check for config.h (currently not generated).
+ *
+ * Revision 1.9  1999/11/30 13:47:12  adam
+ * Improved installation. Moved header files to include/yaz.
+ *
+ * Revision 1.8  1999/05/26 07:49:35  adam
+ * C++ compilation.
+ *
+ * Revision 1.7  1998/02/11 11:53:36  adam
+ * Changed code so that it compiles as C++.
+ *
+ * Revision 1.6  1997/12/12 06:32:33  adam
+ * Added include of string.h.
+ *
+ * Revision 1.5  1997/09/24 13:29:40  adam
+ * Added verbose option -v to marcdump utility.
+ *
+ * Revision 1.4  1995/11/01 13:55:05  quinn
+ * Minor adjustments
+ *
+ * Revision 1.3  1995/05/16  08:51:12  quinn
  * License, documentation, and memory fixes
  *
  * Revision 1.2  1995/05/15  11:56:56  quinn
  *
  */
 
+#if HAVE_CONFIG_H
+#include <config.h>
+#endif
+
 #include <stdio.h>
 #include <stdlib.h>
+#include <string.h>
 #include <errno.h>
-#include <marcdisp.h>
-#include <dmalloc.h>
+#include <yaz/marcdisp.h>
+#include <yaz/xmalloc.h>
+#include <yaz/options.h>
 
 #ifndef SEEK_SET
 #define SEEK_SET 0
  
 int main (int argc, char **argv)
 {
+    int ret;
+    char *arg;
+    int verbose = 0;
     FILE *inf;
     long file_size;
-    char *buf;
-    int r;
+    char *buf, *p;
+    char *prog = *argv;
+    int count = 0;
+    int no = 0;
+    FILE *cfile = 0;
 
-    if (argc < 2)
+    while ((ret = options("vc:", argv, argc, &arg)) != -2)
     {
-        fprintf (stderr, "usage\n%s <file>\n", *argv);
-       exit (1);
-    }
-    inf = fopen (argv[1], "r");
-    if (!inf)
-    {
-        fprintf (stderr, "%s: cannot open %s:%s\n",
-                *argv, argv[1], strerror (errno));
-        exit (1);
-    }
-    if (fseek (inf, 0L, SEEK_END))
-    {
-        fprintf (stderr, "%s: cannot seek in %s:%s\n",
-                *argv, argv[1], strerror (errno));
-        exit (1);
+       no++;
+        switch (ret)
+        {
+       case 'c':
+           if (cfile)
+               fclose (cfile);
+           cfile = fopen (arg, "w");
+           break;
+        case 0:
+           inf = fopen (arg, "r");
+           if (!inf)
+           {
+               fprintf (stderr, "%s: cannot open %s:%s\n",
+                        prog, arg, strerror (errno));
+               exit (1);
+           }
+           if (fseek (inf, 0L, SEEK_END))
+           {
+               fprintf (stderr, "%s: cannot seek in %s:%s\n",
+                        prog, arg, strerror (errno));
+               exit (1);
+           }
+           file_size = ftell (inf);    
+           if (fseek (inf, 0L, SEEK_SET))
+           {
+               fprintf (stderr, "%s: cannot seek in %s:%s\n",
+                        prog, arg, strerror (errno));
+               exit (1);
+           }
+           buf = (char *)xmalloc (file_size);
+           if (!buf)
+           {
+               fprintf (stderr, "%s: cannot xmalloc: %s\n",
+                        prog, strerror (errno));
+               exit (1);
+           }
+           if ((long) fread (buf, 1, file_size, inf) != file_size)
+           {
+               fprintf (stderr, "%s: cannot read %s: %s\n",
+                        prog, arg, strerror (errno));
+               exit (1);
+           }
+           if (cfile)
+           {
+               fprintf (cfile, "char *marc_records[] = {\n");
+           }
+           for (p = buf; (ret = marc_display_ex (p, stdout, verbose)) > 0;)
+           {
+               if (cfile)
+               {
+                   int i;
+                   if (p != buf)
+                       fprintf (cfile, ",");
+                   fprintf (cfile, "{\n");
+                   for (i = 0; i<ret; i++)
+                   {
+                       if ((i & 15) == 0)
+                           fprintf (cfile, "  \"");
+                       fprintf (cfile, "\\x%02X", p[i] & 255);
+                       
+                       if (i < ret - 1 && (i & 15) == 15)
+                           fprintf (cfile, "\"\n");
+                       
+                   }
+                   fprintf (cfile, "\"\n}");
+               }
+               p += ret;
+               count++;
+           }
+           if (cfile)
+           {
+               fprintf (cfile, "};\n");
+           }
+           fclose (inf);
+           xfree (buf);
+            break;
+        case 'v':
+           verbose++;
+            break;
+        default:
+            fprintf (stderr, "Usage: %s [-c cfile] [-v] file...\n", prog);
+            exit (1);
+        }
     }
-    file_size = ftell (inf);    
-    if (fseek (inf, 0L, SEEK_SET))
+    if (cfile)
+       fclose (cfile);
+    if (!no)
     {
-        fprintf (stderr, "%s: cannot seek in %s:%s\n",
-                *argv, argv[1], strerror (errno));
-        exit (1);
-    }
-    buf = malloc (file_size);
-    if (!buf)
-    {
-        fprintf (stderr, "%s: cannot malloc: %s\n",
-                *argv, strerror (errno));
-        exit (1);
-    }
-    if (fread (buf, 1, file_size, inf) != file_size)
-    {
-        fprintf (stderr, "%s: cannot read %s: %s\n",
-                *argv, argv[1], strerror (errno));
-        exit (1);
+       fprintf (stderr, "Usage: %s [-v] file...\n", prog);
+       exit (1);
     }
-    while ((r = marc_display (buf, stdout)) > 0)
-        buf += r;
     exit (0);
 }