X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=fml%2Ffmlcalls.c;h=2d0759053d281df4a59b31bd8decfc51b7fa0315;hb=c3d25c24fb405af98c6879fa7f5f619ccc895151;hp=5e73f0e332a2a44f81d29d2107ac47359fac483e;hpb=5f82d212861388cc73741917b38f67d773d01549;p=egate.git diff --git a/fml/fmlcalls.c b/fml/fmlcalls.c index 5e73f0e..2d07590 100644 --- a/fml/fmlcalls.c +++ b/fml/fmlcalls.c @@ -2,7 +2,15 @@ * FML interpreter. Europagate, 1995 * * $Log: fmlcalls.c,v $ - * Revision 1.1 1995/02/09 16:06:07 adam + * Revision 1.4 1995/02/23 08:32:04 adam + * Changed header. + * + * Revision 1.2 1995/02/10 15:50:55 adam + * MARC interface implemented. Minor bugs fixed. fmltest can + * be used to format single MARC records. New function '\list' + * implemented. + * + * Revision 1.1 1995/02/09 16:06:07 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 @@ -15,22 +23,46 @@ #include "fmlp.h" -static const char *str_ptr; +static const char **str_args; static int eof_mark; static int str_reader (void) { - if (!*str_ptr) - return eof_mark; - return *str_ptr++; + int c; + while (! (c = **str_args)) + { + if (! str_args[1]) + return eof_mark; + ++str_args; + } + ++ *str_args; + return c; } +void fml_exec_call_argv (Fml fml, const char **argv) +{ + int (*old_func)(void) = fml->read_func; + + fml->read_func = str_reader; + str_args = argv; + eof_mark = fml->eof_mark; + fml_exec_call (fml); + fml->read_func = old_func; +} + + void fml_exec_call_str (Fml fml, const char *str) { int (*old_func)(void) = fml->read_func; + const char *argv[2]; + + argv[0] = str; + argv[1] = NULL; fml->read_func = str_reader; - str_ptr = str; + str_args = argv; eof_mark = fml->eof_mark; fml_exec_call (fml); fml->read_func = old_func; } + +