Definition of CPP changed. Output function can be customized.
[egate.git] / fml / fmltest.c
index 9c944e1..13dda1e 100644 (file)
@@ -2,7 +2,12 @@
  * FML interpreter. Europagate, 1995
  *
  * $Log: fmltest.c,v $
- * Revision 1.4  1995/02/09 16:06:08  adam
+ * Revision 1.5  1995/02/10 15:50:56  adam
+ * MARC interface implemented. Minor bugs fixed. fmltest can
+ * be used to format single MARC records. New function '\list'
+ * implemented.
+ *
+ * Revision 1.4  1995/02/09  16:06:08  adam
  * FML can be called from the outside multiple times by the functions:
  * fml_exec_call and fml_exec_call_str.
  * An interactive parameter (-i) to fmltest starts a shell-like
@@ -24,7 +29,9 @@
 
 #include <stdio.h>
 #include <string.h>
-#include "fml.h"
+#include <stdlib.h>
+
+#include <fmlmarc.h>
 
 static FILE *inf;
 
@@ -38,6 +45,7 @@ int main (int argc, char **argv)
     Fml fml;
     int nfiles = 0;
     int interactive = 0;
+    Iso2709Rec rec = NULL;
 
     fml = fml_open ();
     while (-- argc > 0)
@@ -50,12 +58,38 @@ int main (int argc, char **argv)
             else if (argv[0][1] == 'm')
                 fml->debug |= 2;
             else if (argv[0][1] == 'i')
-            {
                 interactive = 1;
+            else if (argv[0][1] == '2')
+            {
+                if (argc > 1)
+                {
+                    char *buf;
+                    FILE *inf;
+                    ++argv;
+                    --argc;
+
+                    inf = fopen (*argv, "r");
+                    if (!inf)
+                    {
+                        fprintf (stderr, "cannot open record `%s'\n", *argv);
+                        exit (1);
+                    }
+                    if ((buf = iso2709_read (inf)))
+                    {
+                        rec = iso2709_cvt (buf);
+                        free (buf);
+                    }
+                    else
+                    {
+                        fprintf (stderr, "no record in `%s'\n", *argv);
+                        exit (1);
+                    }
+                    fclose (inf);
+                }
             }
             else
             {
-                fprintf (stderr, "uknown option `%s'\n", *argv);
+                fprintf (stderr, "unknown option `%s'\n", *argv);
                 exit (1);
             }
         }
@@ -65,7 +99,7 @@ int main (int argc, char **argv)
             inf = fopen (*argv, "r");
             if (!inf)
             {
-                fprintf (stderr, "cannot open `%s'\n", *argv);
+                fprintf (stderr, "cannot open FML file `%s'\n", *argv);
                 exit (1);
             }
             fml->read_func = inf_read;
@@ -88,6 +122,7 @@ int main (int argc, char **argv)
             while (1)
             {
                 char *cp;
+                const char *nargv[4];
 
                 printf ("\nFML>");
                 fflush (stdout);
@@ -96,7 +131,20 @@ int main (int argc, char **argv)
                     break;
                 if ((cp = strchr (arg, '\n')))
                     *cp = '\0';
-                fml_exec_call_str (fml, arg);
+                if (*arg == '!' && rec)
+                {
+                    nargv[0] = arg+1;
+                    nargv[1] = " ";
+                    nargv[2] = marc_to_str (fml, rec);
+                    printf ("passing '%s'\n", nargv[2]);
+                    nargv[3] = NULL;
+                }
+                else
+                {
+                    nargv[0] = arg;
+                    nargv[1] = NULL;
+                }
+                fml_exec_call_argv (fml, nargv);
             }
         }
     }