* Europagate 1995
*
* $Log: cclsh.c,v $
- * Revision 1.3 1997-04-30 08:52:07 quinn
+ * Revision 1.8 2001-03-18 20:45:39 ja7
+ * Added readline and history support to cclsh
+ *
+ * Revision 1.7 2000/10/17 19:50:28 adam
+ * Implemented and-list and or-list for CCL module.
+ *
+ * Revision 1.6 2000/01/31 13:15:21 adam
+ * Removed uses of assert(3). Cleanup of ODR. CCL parser update so
+ * that some characters are not surrounded by spaces in resulting term.
+ * ILL-code updates.
+ *
+ * Revision 1.5 1999/12/16 23:36:19 adam
+ * Implemented ILL protocol. Minor updates ASN.1 compiler.
+ *
+ * Revision 1.4 1999/03/31 11:15:37 adam
+ * Fixed memory leaks in ccl_find_str and ccl_qual_rm.
+ *
+ * Revision 1.3 1997/04/30 08:52:07 quinn
* Null
*
* Revision 1.2 1996/10/11 15:00:25 adam
#include <stdio.h>
#include <stdlib.h>
-#include <assert.h>
-#include <ccl.h>
+#include <yaz/ccl.h>
+
+
+#if HAVE_READLINE_READLINE_H
+#include <readline/readline.h>
+#endif
+#if HAVE_READLINE_HISTORY_H
+#include <readline/history.h>
+#endif
+
static int debug = 0;
static char *prog;
+void usage(const char *prog)
+{
+ fprintf (stderr, "%s: [-d] [-b configfile]\n", prog);
+ exit (1);
+}
+
int main (int argc, char **argv)
{
CCL_bibset bibset;
{
switch (argv[0][1])
{
- case 'c':
- ccl_case_sensitive = 0;
- break;
case 'd':
debug = 1;
break;
fclose (bib_inf);
break;
default:
- fprintf (stderr, "%s: unknown option '%s'\n",
- prog, *argv);
- exit (1);
+ usage(prog);
}
}
else
}
while (1)
{
- char buf[80];
- int error, pos;
+ char buf[1000];
+ int i, error, pos;
struct ccl_rpn_node *rpn;
+#if HAVE_READLINE_READLINE_H
+ char* line_in;
+ line_in=readline("CCLSH>");
+ if (!line_in)
+ break;
+#if HAVE_READLINE_HISTORY_H
+ if (*line_in)
+ add_history(line_in);
+#endif
+ if(strlen(line_in) > 999) {
+ fprintf(stderr,"Input line to long\n");
+ break;
+ };
+ strcpy(buf,line_in);
+ free (line_in);
+#else
printf ("CCLSH>"); fflush (stdout);
- if (!fgets (buf, 79, stdin))
+ if (!fgets (buf, 999, stdin))
break;
- rpn = ccl_find_str (bibset, buf, &error, &pos);
- if (error)
- {
- printf ("%*s^ - ", 6+pos, " ");
- printf ("%s\n", ccl_err_msg (error));
- }
- else
+#endif
+
+ for (i = 0; i<1; i++)
{
- assert (rpn);
- ccl_pr_tree (rpn, stdout);
- putchar ('\n');
+ rpn = ccl_find_str (bibset, buf, &error, &pos);
+ if (error)
+ {
+ printf ("%*s^ - ", 6+pos, " ");
+ printf ("%s\n", ccl_err_msg (error));
+ }
+ else
+ {
+ if (rpn && i == 0)
+ {
+ ccl_pr_tree (rpn, stdout);
+ putchar ('\n');
+ }
+ }
+ if (rpn)
+ ccl_rpn_delete(rpn);
}
}
putchar ('\n');