X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=tclmain.c;h=376e56feaa312bfac842d6e851733216a2e3ba8d;hb=f25d0ab1672bff45ed845baf786f23aac60ca243;hp=c782cf45b73234e7ad8be6de1fe5c7d25819dcf2;hpb=5ab718625d35ca64c34d9962427feeaaa1b00086;p=ir-tcl-moved-to-github.git diff --git a/tclmain.c b/tclmain.c index c782cf4..376e56f 100644 --- a/tclmain.c +++ b/tclmain.c @@ -1,33 +1,85 @@ /* * IR toolkit for tcl/tk * (c) Index Data 1995 + * See the file LICENSE for details. + * Sebastian Hammer, Adam Dickmeiss * * $Log: tclmain.c,v $ - * Revision 1.4 1995-03-17 07:50:31 adam + * Revision 1.14 1995-09-21 13:11:53 adam + * Support of dynamic loading. + * Test script uses load command if necessary. + * + * Revision 1.13 1995/08/28 12:21:22 adam + * Removed lines and list as synonyms of list in MARC extractron. + * Configure searches also for tk4.0 / tcl7.4. + * + * Revision 1.12 1995/08/28 11:07:16 adam + * Minor changes. + * + * Revision 1.11 1995/08/03 13:23:02 adam + * Request queue. + * + * Revision 1.10 1995/06/30 12:39:28 adam + * Bug fix: loadFile didn't set record type. + * The MARC routines are a little less strict in the interpretation. + * Script display.tcl replaces the old marc.tcl. + * New interactive script: shell.tcl. + * + * Revision 1.9 1995/06/26 10:20:20 adam + * ir-tk works like wish. + * + * Revision 1.8 1995/06/21 15:16:44 adam + * More work on configuration. + * + * Revision 1.7 1995/06/21 11:04:54 adam + * Uses GNU autoconf 2.3. + * Install procedure implemented. + * boook bitmaps moved to sub directory bitmaps. + * + * Revision 1.6 1995/05/29 08:44:28 adam + * Work on delete of objects. + * + * Revision 1.5 1995/03/20 08:53:30 adam + * Event loop in tclmain.c rewritten. New method searchStatus. + * + * Revision 1.4 1995/03/17 07:50:31 adam * Headers have changed a little. * */ +#include #include #include +#ifdef _AIX +#include +#endif #include -#include #include - +#include #include "ir-tcl.h" static char *fileName = NULL; -static fd_set fdset_tcl; +/* select(2) callbacks */ +struct callback { + void (*r_handle)(ClientData); + void (*w_handle)(ClientData); + void (*x_handle)(ClientData); + void *obj; +}; +#define MAX_CALLBACK 200 + +static struct callback callback_table[MAX_CALLBACK]; +static int max_fd = 3; /* don't worry: it will grow... */ -void tcl_mainloop (Tcl_Interp *interp); +void tcl_mainloop (Tcl_Interp *interp, int interactive); int Tcl_AppInit (Tcl_Interp *interp) { if (Tcl_Init(interp) == TCL_ERROR) return TCL_ERROR; - if (ir_tcl_init(interp) == TCL_ERROR) + if (Irtcl_Init(interp) == TCL_ERROR) return TCL_ERROR; return TCL_OK; } @@ -36,6 +88,7 @@ int main (int argc, char **argv) { Tcl_Interp *interp; int code; + int i; interp = Tcl_CreateInterp(); Tcl_SetVar (interp, "tcl_interactive", "0", TCL_GLOBAL_ONLY); @@ -45,6 +98,12 @@ int main (int argc, char **argv) if (Tcl_AppInit(interp) != TCL_OK) { fprintf(stderr, "Tcl_AppInit failed: %s\n", interp->result); } + for (i=0; iresult); if (code != TCL_OK) exit (1); + tcl_mainloop (interp, 0); } - Tcl_SetVar (interp, "tcl_interactive", "1", TCL_GLOBAL_ONLY); - tcl_mainloop (interp); - exit (0); -} - -struct callback { - void (*handle)(void *p); - void *obj; -}; + else if (isatty(0)) + { -#define MAX_CALLBACK 20 + Tcl_SetVar (interp, "tcl_interactive", "1", TCL_GLOBAL_ONLY); + tcl_mainloop (interp, 1); + } + else + { + Tcl_DString command; + char input_buf[1024]; + int count; -struct callback callback_table[MAX_CALLBACK]; + printf ("xx\n"); + Tcl_DStringInit (&command); + while (fgets (input_buf, 1024, stdin)) + { + count = strlen(input_buf); + Tcl_DStringAppend (&command, input_buf, count); + if (Tcl_CommandComplete (Tcl_DStringValue (&command))) + { + int code = Tcl_Eval (interp, Tcl_DStringValue (&command)); + Tcl_DStringFree (&command); + if (code) + printf ("Error: %s\n", interp->result); + } + } + tcl_mainloop (interp, 0); + } + exit (0); +} -void tcl_mainloop (Tcl_Interp *interp) +void tcl_mainloop (Tcl_Interp *interp, int interactive) { int i; int res; - int count; - char input_buf[256]; Tcl_DString command; + static fd_set fdset_tcl_r; + static fd_set fdset_tcl_w; + static fd_set fdset_tcl_x; + int min_fd; - for (i=0; iresult); - else - printf ("[RES:%s]\n", interp->result); - printf ("[TCL]"); fflush (stdout); + printf ("Error: %s\n", interp->result); + else if (*interp->result) + printf ("%s\n", interp->result); + printf ("%% "); fflush (stdout); } } } @@ -122,10 +238,28 @@ void tcl_mainloop (Tcl_Interp *interp) void ir_select_add (int fd, void *obj) { callback_table[fd].obj = obj; - callback_table[fd].handle = ir_select_proc; + callback_table[fd].r_handle = ir_select_read; + callback_table[fd].w_handle = NULL; + callback_table[fd].x_handle = NULL; + if (fd > max_fd) + max_fd = fd; +} + +void ir_select_add_write (int fd, void *obj) +{ + callback_table[fd].w_handle = ir_select_write; + if (fd > max_fd) + max_fd = fd; +} + +void ir_select_remove_write (int fd, void *obj) +{ + callback_table[fd].w_handle = NULL; } void ir_select_remove (int fd, void *obj) { - callback_table[fd].handle = NULL; + callback_table[fd].r_handle = NULL; + callback_table[fd].w_handle = NULL; + callback_table[fd].x_handle = NULL; }