X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=tclmain.c;h=d426d1c0b7650f3984fe34052c32890d6de0548e;hb=d026c3e06f6e19e5ed4174ab1a504a4b5af79183;hp=6c085daaeec12f677ed5e76dc3102d33e181346b;hpb=81c7aeedca99611b86c068f0663b322be3800248;p=ir-tcl-moved-to-github.git diff --git a/tclmain.c b/tclmain.c index 6c085da..d426d1c 100644 --- a/tclmain.c +++ b/tclmain.c @@ -1,38 +1,85 @@ /* * IR toolkit for tcl/tk - * (c) Index Data 1995 + * (c) Index Data 1995-1996 + * See the file LICENSE for details. + * Sebastian Hammer, Adam Dickmeiss + * + * $Log: tclmain.c,v $ + * Revision 1.21 2000-02-22 23:11:03 adam + * Fixed include statements. + * + * Revision 1.20 1997/04/30 07:26:08 adam + * Added support for shared libaries (if supported by Tcl itself). + * + * Revision 1.19 1996/08/20 09:27:49 adam + * More work on explain. + * Renamed tkinit.c to tkmain.c. The tcl shell uses the Tcl 7.5 interface + * for socket i/o instead of the handcrafted one (for Tcl 7.3 and Tcl7.4). * - * $Id: tclmain.c,v 1.3 1995-03-09 08:35:58 adam Exp $ */ +#include #include #include +#ifdef _AIX +#include +#endif + #include -#include #include - +#include #include "ir-tcl.h" -static char *fileName = NULL; - -static fd_set fdset_tcl; - -void tcl_mainloop (Tcl_Interp *interp); - 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; +#if USE_WAIS + if (Waistcl_Init(interp) == TCL_ERROR) + return TCL_ERROR; +#endif return TCL_OK; } +#if TCL_MAJOR_VERSION > 7 || (TCL_MAJOR_VERSION == 7 && TCL_MINOR_VERSION > 4) +/* new version of tcl: version > 7.4 */ +extern int matherr (); +int *tclDummyMathPtr = (int*) matherr; + +int main (int argc, char **argv) +{ + Tcl_Main (argc, argv, Tcl_AppInit); + return 0; +} + +#else +/* old version of tcl: version <= 7.4 */ + +static char *fileName = NULL; +extern int main (); +int *tclDummyMainPtr = (int*) main; + +/* select(2) callbacks */ +struct callback { + void (*handle)(ClientData, int, int, int); + int r, w, e; + ClientData 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, int interactive); + 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); @@ -42,6 +89,8 @@ 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); } } } } -void ir_select_add (int fd, void *obj) +void ir_tcl_select_set (void (*f)(ClientData clientData, int r, int w, int e), + int fd, ClientData clientData, int r, int w, int e) { - callback_table[fd].obj = obj; - callback_table[fd].handle = ir_select_proc; + callback_table[fd].handle = f; + callback_table[fd].obj = clientData; + callback_table[fd].r = r; + callback_table[fd].w = w; + callback_table[fd].e = e; + if (fd > max_fd) + max_fd = fd; } -void ir_select_remove (int fd, void *obj) -{ - callback_table[fd].handle = NULL; -} +#endif