expect/expect-warnings.patch

2509 lines
64 KiB
Diff
Raw Normal View History

Index: exp_command.c
===================================================================
--- exp_command.c.orig
+++ exp_command.c
@@ -29,7 +29,6 @@ would appreciate credit if this program
# include <fcntl.h>
#endif
#include <sys/file.h>
-#include "exp_tty.h"
#include <errno.h>
#include <signal.h>
@@ -66,6 +65,7 @@ would appreciate credit if this program
#include "tcl.h"
#include "string.h"
+#include "expect.h"
#include "expect_tcl.h"
#include "exp_rename.h"
#include "exp_prog.h"
@@ -73,6 +73,7 @@ would appreciate credit if this program
#include "exp_log.h"
#include "exp_event.h"
#include "exp_pty.h"
+#include "exp_tty_in.h"
#ifdef TCL_DEBUGGER
#include "tcldbg.h"
#endif
@@ -86,8 +87,8 @@ would appreciate credit if this program
#define SPAWN_ID_VARNAME "spawn_id"
-int exp_getptymaster();
-int exp_getptyslave();
+void exp_ecmd_remove_state_direct_and_indirect(Tcl_Interp *interp, ExpState *esPtr);
+
int exp_forked = FALSE; /* whether we are child process */
@@ -151,8 +152,7 @@ static Tcl_ThreadDataKey dataKey;
#ifdef FULLTRAPS
static void
-init_traps(traps)
- RETSIGTYPE (*traps[])();
+init_traps(RETSIGTYPE (*traps[])())
{
int i;
@@ -183,11 +183,11 @@ exp_error TCL_VARARGS_DEF(Tcl_Interp *,a
/* returns current ExpState or 0. If 0, may be immediately followed by return TCL_ERROR. */
struct ExpState *
-expStateCurrent(interp,opened,adjust,any)
- Tcl_Interp *interp;
- int opened;
- int adjust;
- int any;
+expStateCurrent(
+ Tcl_Interp *interp,
+ int opened,
+ int adjust,
+ int any)
{
static char *user_spawn_id = "exp0";
@@ -198,12 +198,12 @@ expStateCurrent(interp,opened,adjust,any
}
ExpState *
-expStateCheck(interp,esPtr,open,adjust,msg)
- Tcl_Interp *interp;
- ExpState *esPtr;
- int open;
- int adjust;
- char *msg;
+expStateCheck(
+ Tcl_Interp *interp,
+ ExpState *esPtr,
+ int open,
+ int adjust,
+ char *msg)
{
if (open && !esPtr->open) {
exp_error(interp,"%s: spawn id %s not open",msg,esPtr->name);
@@ -214,12 +214,13 @@ expStateCheck(interp,esPtr,open,adjust,m
}
ExpState *
-expStateFromChannelName(interp,name,open,adjust,any,msg)
- Tcl_Interp *interp;
- char *name;
- int open;
- int adjust;
- char *msg;
+expStateFromChannelName(
+ Tcl_Interp *interp,
+ char *name,
+ int open,
+ int adjust,
+ int any,
+ char *msg)
{
ExpState *esPtr;
Tcl_Channel channel;
@@ -248,8 +249,7 @@ expStateFromChannelName(interp,name,open
/* zero out the wait status field */
static void
-exp_wait_zero(status)
-WAIT_STATUS_TYPE *status;
+exp_wait_zero(WAIT_STATUS_TYPE *status)
{
int i;
@@ -260,9 +260,9 @@ WAIT_STATUS_TYPE *status;
/* called just before an ExpState entry is about to be invalidated */
void
-exp_state_prep_for_invalidation(interp,esPtr)
-Tcl_Interp *interp;
-ExpState *esPtr;
+exp_state_prep_for_invalidation(
+ Tcl_Interp *interp,
+ ExpState *esPtr)
{
exp_ecmd_remove_state_direct_and_indirect(interp,esPtr);
@@ -275,8 +275,7 @@ ExpState *esPtr;
/*ARGSUSED*/
void
-exp_trap_on(master)
-int master;
+exp_trap_on(int master)
{
#ifdef HAVE_PTYTRAP
if (master == -1) return;
@@ -285,8 +284,7 @@ int master;
}
int
-exp_trap_off(name)
-char *name;
+exp_trap_off(char *name)
{
#ifdef HAVE_PTYTRAP
ExpState *esPtr;
@@ -310,8 +308,7 @@ char *name;
static
void
-expBusy(esPtr)
- ExpState *esPtr;
+expBusy(ExpState *esPtr)
{
int x = open("/dev/null",0);
if (x != esPtr->fdin) {
@@ -323,9 +320,9 @@ expBusy(esPtr)
}
int
-exp_close(interp,esPtr)
- Tcl_Interp *interp;
- ExpState *esPtr;
+exp_close(
+ Tcl_Interp *interp,
+ ExpState *esPtr)
{
if (0 == expStateCheck(interp,esPtr,1,0,"close")) return TCL_ERROR;
esPtr->open = FALSE;
@@ -404,8 +401,7 @@ exp_close(interp,esPtr)
/* we need a separate function because spawn_id_any is thread-specific */
/* and can't be seen outside this file */
int
-expStateAnyIs(esPtr)
- ExpState *esPtr;
+expStateAnyIs(ExpState *esPtr)
{
ThreadSpecificData *tsdPtr = TCL_TSD_INIT(&dataKey);
@@ -413,8 +409,7 @@ expStateAnyIs(esPtr)
}
int
-expDevttyIs(esPtr)
- ExpState *esPtr;
+expDevttyIs(ExpState *esPtr)
{
ThreadSpecificData *tsdPtr = TCL_TSD_INIT(&dataKey);
@@ -422,8 +417,7 @@ expDevttyIs(esPtr)
}
int
-expStdinoutIs(esPtr)
- ExpState *esPtr;
+expStdinoutIs(ExpState *esPtr)
{
ThreadSpecificData *tsdPtr = TCL_TSD_INIT(&dataKey);
@@ -447,8 +441,7 @@ expDevttyGet()
}
void
-exp_init_spawn_id_vars(interp)
- Tcl_Interp *interp;
+exp_init_spawn_id_vars(Tcl_Interp *interp)
{
ThreadSpecificData *tsdPtr = TCL_TSD_INIT(&dataKey);
@@ -467,8 +460,7 @@ exp_init_spawn_id_vars(interp)
}
void
-exp_init_spawn_ids(interp)
- Tcl_Interp *interp;
+exp_init_spawn_ids(Tcl_Interp *interp)
{
static ExpState any_placeholder; /* can be shared process-wide */
@@ -504,8 +496,7 @@ exp_init_spawn_ids(interp)
}
void
-expCloseOnExec(fd)
- int fd;
+expCloseOnExec(int fd)
{
(void) fcntl(fd,F_SETFD,1);
}
@@ -516,9 +507,9 @@ expCloseOnExec(fd)
/*
* DEBUGGING UTILITIES - DON'T DELETE */
static void
-show_pgrp(fd,string)
- int fd;
- char *string;
+show_pgrp(
+ int fd,
+ char *string)
{
int pgrp;
@@ -532,8 +523,7 @@ show_pgrp(fd,string)
}
static void
-set_pgrp(fd)
- int fd;
+set_pgrp(int fd)
{
int pgrp = getpgrp(0);
if (-1 == ioctl(fd,TIOCSETPGRP,&pgrp)) perror("TIOCSETPGRP");
@@ -562,9 +552,9 @@ expSetpgrp()
/*ARGSUSED*/
static void
-set_slave_name(esPtr,name)
- ExpState *esPtr;
- char *name;
+set_slave_name(
+ ExpState *esPtr,
+ char *name)
{
#ifdef HAVE_PTYTRAP
int newptr;
@@ -582,11 +572,11 @@ set_slave_name(esPtr,name)
/* arguments are passed verbatim to execvp() */
/*ARGSUSED*/
static int
-Exp_SpawnObjCmd(clientData,interp,objc,objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_SpawnObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
ExpState *esPtr = 0;
int slave;
@@ -910,16 +900,16 @@ Exp_SpawnObjCmd(clientData,interp,objc,o
return TCL_ERROR;
}
if (mode & TCL_READABLE) {
- if (TCL_ERROR == Tcl_GetChannelHandle(channel, TCL_READABLE, (ClientData *) &rfdc)) {
+ if (TCL_ERROR == Tcl_GetChannelHandle(channel, TCL_READABLE, &rfdc)) {
return TCL_ERROR;
}
- rfd = (int) rfdc;
+ rfd = (int)(long) rfdc;
}
if (mode & TCL_WRITABLE) {
- if (TCL_ERROR == Tcl_GetChannelHandle(channel, TCL_WRITABLE, (ClientData *) &wfdc)) {
+ if (TCL_ERROR == Tcl_GetChannelHandle(channel, TCL_WRITABLE, &wfdc)) {
return TCL_ERROR;
}
- wfd = (int) wfdc;
+ wfd = (int)(long) wfdc;
}
master = ((mode & TCL_READABLE)?rfd:wfd);
@@ -1346,7 +1336,7 @@ Exp_SpawnObjCmd(clientData,interp,objc,o
}
argv[k] = NULL;
- (void) execvp(command,argv);
+ execvp(command,argv);
for (k=0,i=cmdIndex;i<objc;k++,i++) {
ckfree (argv[k]);
@@ -1377,11 +1367,11 @@ Exp_SpawnObjCmd(clientData,interp,objc,o
/*ARGSUSED*/
static int
-Exp_ExpPidObjCmd(clientData,interp,objc,objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_ExpPidObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
char *chanName = 0;
ExpState *esPtr = 0;
@@ -1427,11 +1417,11 @@ Exp_ExpPidObjCmd(clientData,interp,objc,
/*ARGSUSED*/
static int
-Exp_GetpidDeprecatedObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_GetpidDeprecatedObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
expDiagLog("getpid is deprecated, use pid\r\n");
Tcl_SetObjResult (interp, Tcl_NewIntObj (getpid()));
@@ -1440,11 +1430,11 @@ Exp_GetpidDeprecatedObjCmd(clientData, i
/*ARGSUSED*/
static int
-Exp_SleepObjCmd(clientData,interp,objc,objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_SleepObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
double s;
@@ -1471,9 +1461,9 @@ struct slow_arg {
/* returns 0 for success, -1 for failure */
static int
-get_slow_args(interp,x)
- Tcl_Interp *interp;
- struct slow_arg *x;
+get_slow_args(
+ Tcl_Interp *interp,
+ struct slow_arg *x)
{
int sc; /* return from scanf */
CONST char *s = exp_get_var(interp,"send_slow");
@@ -1498,12 +1488,12 @@ get_slow_args(interp,x)
/* returns 0 for success, -1 for failure, pos. for Tcl return value */
static int
-slow_write(interp,esPtr,buffer,rembytes,arg) /* INTL */
- Tcl_Interp *interp;
- ExpState *esPtr;
- char *buffer;
- int rembytes;
- struct slow_arg *arg;
+slow_write(
+ Tcl_Interp *interp,
+ ExpState *esPtr,
+ char *buffer,
+ int rembytes,
+ struct slow_arg *arg)
{
int rc;
@@ -1542,9 +1532,9 @@ struct human_arg {
/* returns -1 if error, 0 if success */
static int
-get_human_args(interp,x)
- Tcl_Interp *interp;
- struct human_arg *x;
+get_human_args(
+ Tcl_Interp *interp,
+ struct human_arg *x)
{
int sc; /* return from scanf */
CONST char *s = exp_get_var(interp,"send_human");
@@ -1606,11 +1596,11 @@ exp_init_unit_random()
/* transitions. */
/* returns 0 for success, -1 for failure, pos. for Tcl return value */
static int
-human_write(interp,esPtr,buffer,arg) /* INTL */
- Tcl_Interp *interp;
- ExpState *esPtr;
- char *buffer;
- struct human_arg *arg;
+human_write(
+ Tcl_Interp *interp,
+ ExpState *esPtr,
+ char *buffer,
+ struct human_arg *arg)
{
char *sp;
int size;
@@ -1684,8 +1674,7 @@ exp_new_i()
}
struct exp_state_list *
-exp_new_state(esPtr)
- ExpState *esPtr;
+exp_new_state(ExpState *esPtr)
{
int n;
struct exp_state_list *fd;
@@ -1710,8 +1699,7 @@ exp_new_state(esPtr)
}
void
-exp_free_state(fd_first)
- struct exp_state_list *fd_first;
+exp_free_state(struct exp_state_list *fd_first)
{
struct exp_state_list *fd, *penultimate;
@@ -1730,18 +1718,17 @@ exp_free_state(fd_first)
/* free a single fd */
void
-exp_free_state_single(fd)
- struct exp_state_list *fd;
+exp_free_state_single(struct exp_state_list *fd)
{
fd->next = exp_state_list_pool;
exp_state_list_pool = fd;
}
void
-exp_free_i(interp,i,updateproc)
- Tcl_Interp *interp;
- struct exp_i *i;
- Tcl_VarTraceProc *updateproc; /* proc to invoke if indirect is written */
+exp_free_i(
+ Tcl_Interp *interp,
+ struct exp_i *i,
+ Tcl_VarTraceProc *updateproc)/* proc to invoke if indirect is written */
{
if (i->next) exp_free_i(interp,i->next,updateproc);
@@ -1781,12 +1768,12 @@ exp_free_i(interp,i,updateproc)
/* can only fail on bad direct descriptors */
/* indirect descriptors always succeed */
struct exp_i *
-exp_new_i_complex(interp,arg,duration,updateproc)
- Tcl_Interp *interp;
- char *arg; /* spawn id list or a variable containing a list */
- int duration; /* if we have to copy the args */
+exp_new_i_complex(
+ Tcl_Interp *interp,
+ char *arg, /* spawn id list or a variable containing a list */
+ int duration, /* if we have to copy the args */
/* should only need do this in expect_before/after */
- Tcl_VarTraceProc *updateproc; /* proc to invoke if indirect is written */
+ Tcl_VarTraceProc *updateproc) /* proc to invoke if indirect is written */
{
struct exp_i *i;
char **stringp;
@@ -1829,9 +1816,9 @@ exp_new_i_complex(interp,arg,duration,up
}
void
-exp_i_add_state(i,esPtr)
- struct exp_i *i;
- ExpState *esPtr;
+exp_i_add_state(
+ struct exp_i *i,
+ ExpState *esPtr)
{
struct exp_state_list *new_state;
@@ -1844,9 +1831,9 @@ exp_i_add_state(i,esPtr)
/* returns TCL_ERROR only on direct */
/* indirects always succeed */
static int
-exp_i_parse_states(interp,i) /* INTL */
- Tcl_Interp *interp;
- struct exp_i *i;
+exp_i_parse_states(
+ Tcl_Interp *interp,
+ struct exp_i *i)
{
struct ExpState *esPtr;
char *p = i->value;
@@ -1873,9 +1860,9 @@ exp_i_parse_states(interp,i) /* INTL */
/* return TCL_ERROR only on direct variables */
/* indirect variables always succeed */
int
-exp_i_update(interp,i)
- Tcl_Interp *interp;
- struct exp_i *i;
+exp_i_update(
+ Tcl_Interp *interp,
+ struct exp_i *i)
{
char *p; /* string representation of list of spawn ids */
@@ -1907,9 +1894,9 @@ exp_i_update(interp,i)
}
struct exp_i *
-exp_new_i_simple(esPtr,duration)
- ExpState *esPtr;
- int duration; /* if we have to copy the args */
+exp_new_i_simple(
+ ExpState *esPtr,
+ int duration) /* if we have to copy the args */
/* should only need do this in expect_before/after */
{
struct exp_i *i;
@@ -1926,11 +1913,11 @@ exp_new_i_simple(esPtr,duration)
/*ARGSUSED*/
static int
-Exp_SendLogObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_SendLogObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
static char* options[] = { "--", NULL };
enum options { LOG_QUOTE };
@@ -1970,11 +1957,11 @@ Exp_SendLogObjCmd(clientData, interp, ob
/* you should quote all your send args to make them one single argument. */
/*ARGSUSED*/
static int
-Exp_SendObjCmd(clientData, interp, objc, objv) /* INTL */
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[];
+Exp_SendObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[])
{
ThreadSpecificData *tsdPtr = TCL_TSD_INIT(&dataKey);
ExpState *esPtr = 0;
@@ -2168,11 +2155,11 @@ Exp_SendObjCmd(clientData, interp, objc,
/*ARGSUSED*/
static int
-Exp_LogFileObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_LogFileObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
static char resultbuf[1000];
char *chanName = 0;
@@ -2301,11 +2288,11 @@ Exp_LogFileObjCmd(clientData, interp, ob
/*ARGSUSED*/
static int
-Exp_LogUserObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_LogUserObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
int old_loguser = expLogUserGet();
@@ -2333,11 +2320,11 @@ Exp_LogUserObjCmd(clientData, interp, ob
#ifdef TCL_DEBUGGER
/*ARGSUSED*/
static int
-Exp_DebugObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_DebugObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
int now = FALSE; /* soon if FALSE, now if TRUE */
int exp_tcl_debugger_was_available = exp_tcl_debugger_available;
@@ -2403,11 +2390,11 @@ Exp_DebugObjCmd(clientData, interp, objc
/*ARGSUSED*/
static int
-Exp_ExpInternalObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_ExpInternalObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
int newChannel = FALSE;
Tcl_Channel oldChannel;
@@ -2483,11 +2470,11 @@ char *exp_onexit_action = 0;
/*ARGSUSED*/
static int
-Exp_ExitObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_ExitObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
int value = 0;
@@ -2534,20 +2521,21 @@ Exp_ExitObjCmd(clientData, interp, objc,
Tcl_Eval(interp, "rename _close.pre_expect close");
Tcl_Exit(value);
/*NOTREACHED*/
+ return TCL_ERROR;
}
/*ARGSUSED*/
static int
-Exp_ConfigureObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_ConfigureObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
/* Magic configuration stuff. */
int i, opt, val;
- static CONST char* options [] = {
+ static CONST84 char* options [] = {
"-strictwrite", NULL
};
enum options {
@@ -2579,11 +2567,11 @@ Exp_ConfigureObjCmd(clientData, interp,
/*ARGSUSED*/
static int
-Exp_CloseObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_CloseObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
int onexec_flag = FALSE; /* true if -onexec seen */
int close_onexec;
@@ -2690,14 +2678,14 @@ Exp_CloseObjCmd(clientData, interp, objc
/*ARGSUSED*/
static int
-tcl_tracer(clientData,interp,level,command,cmdInfo,objc,objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int level;
- CONST char *command;
- Tcl_Command cmdInfo;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+tcl_tracer(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int level,
+ CONST char *command,
+ Tcl_Command cmdInfo,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
int i;
@@ -2710,19 +2698,18 @@ tcl_tracer(clientData,interp,level,comma
}
static void
-tcl_tracer_del(clientData)
- ClientData clientData;
+tcl_tracer_del(ClientData clientData)
{
/* Nothing */
}
/*ARGSUSED*/
static int
-Exp_StraceObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_StraceObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
static int trace_level = 0;
static Tcl_Trace trace_handle;
@@ -2829,9 +2816,9 @@ fork_clear_all()
}
void
-fork_init(f,pid)
- struct forked_proc *f;
- int pid;
+fork_init(
+ struct forked_proc *f,
+ int pid)
{
f->pid = pid;
f->link_status = wait_not_done;
@@ -2839,8 +2826,7 @@ fork_init(f,pid)
/* make an entry for a new proc */
void
-fork_add(pid)
- int pid;
+fork_add(int pid)
{
struct forked_proc *f;
@@ -2873,11 +2859,11 @@ fork_add(pid)
*/
/*ARGSUSED*/
static int
-Exp_WaitObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_WaitObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
char *chanName = 0;
struct ExpState *esPtr;
@@ -2940,7 +2926,7 @@ Exp_WaitObjCmd(clientData, interp, objc,
/* are marked sys_waited already */
if (!esPtr->sys_waited) {
if (nowait) {
- Tcl_Pid pid = (Tcl_Pid)esPtr->pid;
+ Tcl_Pid pid = (Tcl_Pid)(long)esPtr->pid;
/* should probably generate an error */
/* if SIGCHLD is trapped. */
@@ -3086,11 +3072,11 @@ Exp_WaitObjCmd(clientData, interp, objc,
/*ARGSUSED*/
static int
-Exp_ForkObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_ForkObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
int rc;
if (objc > 1) {
@@ -3120,11 +3106,11 @@ Exp_ForkObjCmd(clientData, interp, objc,
/*ARGSUSED*/
static int
-Exp_DisconnectObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_DisconnectObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
ThreadSpecificData *tsdPtr = TCL_TSD_INIT(&dataKey);
@@ -3230,11 +3216,11 @@ Exp_DisconnectObjCmd(clientData, interp,
/*ARGSUSED*/
static int
-Exp_OverlayObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_OverlayObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
int newfd, oldfd;
int dash_name = 0;
@@ -3317,11 +3303,11 @@ Exp_OverlayObjCmd(clientData, interp, ob
/*ARGSUSED*/
int
-Exp_InterpreterObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_InterpreterObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
Tcl_Obj *eofObj = 0;
int i;
@@ -3365,11 +3351,11 @@ Exp_InterpreterObjCmd(clientData, interp
/* this command supercede's Tcl's builtin CONTINUE command */
/*ARGSUSED*/
int
-Exp_ExpContinueObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_ExpContinueObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
if (objc == 1) {
return EXP_CONTINUE;
@@ -3385,11 +3371,11 @@ Exp_ExpContinueObjCmd(clientData, interp
/* most of this is directly from Tcl's definition for return */
/*ARGSUSED*/
int
-Exp_InterReturnObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[];
+Exp_InterReturnObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[])
{
/* let Tcl's return command worry about args */
/* if successful (i.e., TCL_RETURN is returned) */
@@ -3406,11 +3392,11 @@ Exp_InterReturnObjCmd(clientData, interp
/*ARGSUSED*/
int
-Exp_OpenObjCmd(clientData, interp, objc, objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_OpenObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
ExpState *esPtr;
char *chanName = 0;
@@ -3469,7 +3455,7 @@ Exp_OpenObjCmd(clientData, interp, objc,
if (!leaveopen) {
/* remove from Expect's memory in anticipation of passing to Tcl */
if (esPtr->pid != EXP_NOPID) {
- Tcl_Pid pid = (Tcl_Pid)esPtr->pid;
+ Tcl_Pid pid = (Tcl_Pid)(long)esPtr->pid;
Tcl_DetachPids(1,&pid);
esPtr->pid = EXP_NOPID;
esPtr->sys_waited = esPtr->user_waited = TRUE;
@@ -3486,7 +3472,7 @@ Exp_OpenObjCmd(clientData, interp, objc,
* Oh, and we're also being rather cavalier with the permissions here,
* but they're likely to be right for the same reasons.
*/
- channel = Tcl_MakeFileChannel((ClientData)newfd,TCL_READABLE|TCL_WRITABLE);
+ channel = Tcl_MakeFileChannel((ClientData)(long)newfd,TCL_READABLE|TCL_WRITABLE);
Tcl_RegisterChannel(interp, channel);
Tcl_AppendResult(interp, Tcl_GetChannelName(channel), (char *) NULL);
return TCL_OK;
@@ -3499,10 +3485,10 @@ Exp_OpenObjCmd(clientData, interp, objc,
/* return 1 if a string is substring of a flag */
/* this version is the code used by the macro that everyone calls */
int
-exp_flageq_code(flag,string,minlen)
- char *flag;
- char *string;
- int minlen; /* at least this many chars must match */
+exp_flageq_code(
+ char *flag,
+ char *string,
+ int minlen) /* at least this many chars must match */
{
for (;*flag;flag++,string++,minlen--) {
if (*string == '\0') break;
@@ -3579,8 +3565,7 @@ static struct exp_cmd_data cmd_data[] =
{0}};
void
-exp_init_most_cmds(interp)
- Tcl_Interp *interp;
+exp_init_most_cmds(Tcl_Interp *interp)
{
exp_create_commands(interp,cmd_data);
Index: exp_pty.h
===================================================================
--- exp_pty.h.orig
+++ exp_pty.h
@@ -8,10 +8,12 @@ would appreciate credit if this program
*/
-int exp_pty_test_start();
-void exp_pty_test_end();
-int exp_pty_test();
-void exp_pty_unlock();
-int exp_pty_lock();
+int exp_pty_test_start(void);
+void exp_pty_test_end(void);
+int exp_pty_test(char *master_name, char *slave_name, char bank, char *num);
+void exp_pty_unlock(void);
+int exp_pty_lock(char bank, char *num);
+int exp_getptymaster(void);
+int exp_getptyslave(int ttycopy, int ttyinit, CONST char *stty_args);
extern char *exp_pty_slave_name;
Index: exp_tty.c
===================================================================
--- exp_tty.c.orig
+++ exp_tty.c
@@ -50,21 +50,20 @@ int exp_stdout_is_tty;
#define tty_cooked exp_tty_cooked
int
-exp_israw()
+exp_israw(void)
{
return is_raw;
}
int
-exp_isecho()
+exp_isecho(void)
{
return !is_noecho;
}
/* if set == 1, set it to raw, else unset it */
void
-exp_tty_raw(set)
-int set;
+exp_tty_raw(int set)
{
if (set == 1) {
is_raw = TRUE;
@@ -95,8 +94,7 @@ int set;
}
void
-exp_tty_echo(set)
-int set;
+exp_tty_echo(int set)
{
if (set == 1) {
is_noecho = FALSE;
@@ -114,8 +112,7 @@ int set;
}
int
-exp_tty_set_simple(tty)
-exp_tty *tty;
+exp_tty_set_simple(exp_tty *tty)
{
#ifdef HAVE_TCSETATTR
return(tcsetattr(exp_dev_tty, TCSADRAIN,tty));
@@ -125,8 +122,7 @@ exp_tty *tty;
}
int
-exp_tty_get_simple(tty)
-exp_tty *tty;
+exp_tty_get_simple(exp_tty *tty)
{
#ifdef HAVE_TCSETATTR
return(tcgetattr(exp_dev_tty, tty));
@@ -138,10 +134,11 @@ exp_tty *tty;
/* returns 0 if nothing changed */
/* if something changed, the out parameters are changed as well */
int
-exp_tty_raw_noecho(interp,tty_old,was_raw,was_echo)
-Tcl_Interp *interp;
-exp_tty *tty_old;
-int *was_raw, *was_echo;
+exp_tty_raw_noecho(
+ Tcl_Interp *interp,
+ exp_tty *tty_old,
+ int *was_raw,
+ int *was_echo)
{
if (exp_disconnected) return(0);
if (is_raw && is_noecho) return(0);
@@ -173,10 +170,11 @@ int *was_raw, *was_echo;
/* returns 0 if nothing changed */
/* if something changed, the out parameters are changed as well */
int
-exp_tty_cooked_echo(interp,tty_old,was_raw,was_echo)
-Tcl_Interp *interp;
-exp_tty *tty_old;
-int *was_raw, *was_echo;
+exp_tty_cooked_echo(
+ Tcl_Interp *interp,
+ exp_tty *tty_old,
+ int *was_raw,
+ int *was_echo)
{
if (exp_disconnected) return(0);
if (!is_raw && !is_noecho) return(0);
@@ -206,11 +204,11 @@ int *was_raw, *was_echo;
}
void
-exp_tty_set(interp,tty,raw,echo)
-Tcl_Interp *interp;
-exp_tty *tty;
-int raw;
-int echo;
+exp_tty_set(
+ Tcl_Interp *interp,
+ exp_tty *tty,
+ int raw,
+ int echo)
{
if (exp_tty_set_simple(tty) == -1) {
expErrorLog("ioctl(set): %s\r\n",Tcl_PosixError(interp));
@@ -258,9 +256,9 @@ exp_init_stdio()
/*ARGSUSED*/
void
-exp_tty_break(interp,fd)
-Tcl_Interp *interp;
-int fd;
+exp_tty_break(
+ Tcl_Interp *interp,
+ int fd)
{
#ifdef POSIX
tcsendbreak(fd,0);
@@ -280,9 +278,9 @@ int fd;
/* If len == 0, use strlen to compute it */
/* NB: if terminal is not in raw mode, nothing is done. */
char *
-exp_cook(s,len)
-char *s;
-int *len; /* current and new length of s */
+exp_cook(
+ char *s,
+ int *len) /* current and new length of s */
{
static int destlen = 0;
static char *dest = 0;
@@ -315,11 +313,11 @@ int *len; /* current and new length of s
}
static int /* returns TCL_whatever */
-exec_stty(interp,argc,argv,devtty)
-Tcl_Interp *interp;
-int argc;
-char **argv;
-int devtty; /* if true, redirect to /dev/tty */
+exec_stty(
+ Tcl_Interp *interp,
+ int argc,
+ char **argv,
+ int devtty) /* if true, redirect to /dev/tty */
{
int i;
int rc;
@@ -368,11 +366,11 @@ int devtty; /* if true, redirect to /de
/*ARGSUSED*/
static int
-Exp_SttyCmd(clientData, interp, argc, argv)
-ClientData clientData;
-Tcl_Interp *interp;
-int argc;
-char **argv;
+Exp_SttyCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int argc,
+ char **argv)
{
/* redirection symbol is not counted as a stty arg in terms */
/* of recognition. */
@@ -567,11 +565,11 @@ char **argv;
/*ARGSUSED*/
static int
-Exp_SystemCmd(clientData, interp, argc, argv)
-ClientData clientData;
-Tcl_Interp *interp;
-int argc;
-char **argv;
+Exp_SystemCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int argc,
+ char **argv)
{
int result = TCL_OK;
RETSIGTYPE (*old)(); /* save old sigalarm handler */
@@ -799,8 +797,7 @@ cmd_data[] = {
{0}};
void
-exp_init_tty_cmds(interp)
-struct Tcl_Interp *interp;
+exp_init_tty_cmds(struct Tcl_Interp *interp)
{
exp_create_commands(interp,cmd_data);
}
Index: exp_tty.h
===================================================================
--- exp_tty.h.orig
+++ exp_tty.h
@@ -15,15 +15,15 @@ extern int exp_ioctled_devtty;
extern int exp_stdin_is_tty;
extern int exp_stdout_is_tty;
-void exp_tty_raw();
-void exp_tty_echo();
-void exp_tty_break();
-int exp_tty_raw_noecho();
-int exp_israw();
-int exp_isecho();
+void exp_tty_raw(int set);
+void exp_tty_echo(int set);
+void exp_tty_break(Tcl_Interp *interp, int fd);
+int exp_tty_raw_noecho(Tcl_Interp *interp, exp_tty *tty_old, int *was_raw, int *was_echo);
+int exp_israw(void);
+int exp_isecho(void);
-void exp_tty_set();
-int exp_tty_set_simple();
-int exp_tty_get_simple();
+void exp_tty_set(Tcl_Interp *interp, exp_tty *tty, int raw, int echo);
+int exp_tty_set_simple(exp_tty *tty);
+int exp_tty_get_simple(exp_tty *tty);
#endif /* __EXP_TTY_H__ */
Index: exp_command.h
===================================================================
--- exp_command.h.orig
+++ exp_command.h
@@ -220,7 +220,7 @@ EXTERN void exp_ecmd_remove_fd_direct_a
EXTERN void exp_trap_on _ANSI_ARGS_((int));
EXTERN int exp_trap_off _ANSI_ARGS_((char *));
-EXTERN void exp_strftime();
+EXTERN void exp_strftime(char *format, const struct tm *timeptr,Tcl_DString *dstring);
#define exp_deleteProc (void (*)())0
#define exp_deleteObjProc (void (*)())0
Index: exp_inter.c
===================================================================
--- exp_inter.c.orig
+++ exp_inter.c
@@ -125,9 +125,9 @@ struct input {
*/
struct input *
-expStateToInput(hash,esPtr)
- ExpState *esPtr;
- Tcl_HashTable *hash;
+expStateToInput(
+ Tcl_HashTable *hash,
+ ExpState *esPtr)
{
Tcl_HashEntry *entry = Tcl_FindHashEntry(hash,(char *)esPtr);
@@ -139,10 +139,10 @@ expStateToInput(hash,esPtr)
}
void
-expCreateStateToInput(hash,esPtr,inp)
- ExpState *esPtr;
- Tcl_HashTable *hash;
- struct input *inp;
+expCreateStateToInput(
+ Tcl_HashTable *hash,
+ ExpState *esPtr,
+ struct input *inp)
{
Tcl_HashEntry *entry;
int newPtr;
@@ -151,12 +151,15 @@ expCreateStateToInput(hash,esPtr,inp)
Tcl_SetHashValue(entry,(ClientData)inp);
}
-static void free_input();
-static void free_keymap();
-static void free_output();
-static void free_action();
-static struct action *new_action();
-static int inter_eval();
+static void free_input(Tcl_Interp *interp, struct input *i);
+static void free_keymap(struct keymap *km);
+static void free_output(Tcl_Interp *interp, struct output *o);
+static void free_action(struct action *a);
+static struct action *new_action(struct action **base);
+static int inter_eval(
+ Tcl_Interp *interp,
+ struct action *action,
+ ExpState *esPtr);
/* intMatch() accepts user keystrokes and returns one of MATCH,
CANMATCH, or CANTMATCH. These describe whether the keystrokes match a
@@ -187,13 +190,13 @@ we're ready). The other is to return ca
*/
static int
-intMatch(esPtr,keymap,km_match,matchLen,skip,info)
- ExpState *esPtr;
- struct keymap *keymap; /* linked list of keymaps */
- struct keymap **km_match; /* keymap that matches or can match */
- int *matchLen; /* # of bytes that matched */
- int *skip; /* # of chars to skip */
- Tcl_RegExpInfo *info;
+intMatch(
+ ExpState *esPtr,
+ struct keymap *keymap, /* linked list of keymaps */
+ struct keymap **km_match, /* keymap that matches or can match */
+ int *matchLen, /* # of bytes that matched */
+ int *skip, /* # of chars to skip */
+ Tcl_RegExpInfo *info)
{
Tcl_UniChar *string;
struct keymap *km;
@@ -344,12 +347,12 @@ intMatch(esPtr,keymap,km_match,matchLen,
/* put regexp result in variables */
static void
-intRegExpMatchProcess(interp,esPtr,km,info,offset)
- Tcl_Interp *interp;
- ExpState *esPtr;
- struct keymap *km; /* ptr for above while parsing */
- Tcl_RegExpInfo *info;
- int offset;
+intRegExpMatchProcess(
+ Tcl_Interp *interp,
+ ExpState *esPtr,
+ struct keymap *km, /* ptr for above while parsing */
+ Tcl_RegExpInfo *info,
+ int offset)
{
char name[20], value[20];
int i;
@@ -390,10 +393,10 @@ intRegExpMatchProcess(interp,esPtr,km,in
* echo chars
*/
static void
-intEcho(esPtr,skipBytes,matchBytes)
- ExpState *esPtr;
- int skipBytes;
- int matchBytes;
+intEcho(
+ ExpState *esPtr,
+ int skipBytes,
+ int matchBytes)
{
int seenBytes; /* either printed or echoed */
int echoBytes;
@@ -421,12 +424,12 @@ intEcho(esPtr,skipBytes,matchBytes)
* Returns # of bytes read or negative number (EXP_XXX) indicating unusual event.
*/
static int
-intRead(interp,esPtr,warnOnBufferFull,interruptible,key)
- Tcl_Interp *interp;
- ExpState *esPtr;
- int warnOnBufferFull;
- int interruptible;
- int key;
+intRead(
+ Tcl_Interp *interp,
+ ExpState *esPtr,
+ int warnOnBufferFull,
+ int interruptible,
+ int key)
{
Tcl_UniChar *eobOld; /* old end of buffer */
int cc;
@@ -549,11 +552,11 @@ sigchld_handler()
* process or the child (surrogate).
*/
static int
-intIRead(channel,obj,size,flags);
-Tcl_Channel channel;
-Tcl_Obj *obj;
-int size;
-int flags;
+intIRead(
+ Tcl_Channel channel,
+ Tcl_Obj *obj,
+ int size,
+ int flags)
{
int cc = EXP_CHILD_EOF;
@@ -578,9 +581,9 @@ int flags;
#define SPAWNED_PROCESS_DIED -3
static void
-clean_up_after_child(interp,esPtr)
-Tcl_Interp *interp;
-ExpState *esPtr;
+clean_up_after_child(
+ Tcl_Interp *interp,
+ ExpState *esPtr)
{
expWaitOnOne(); /* wait for slave */
expWaitOnOne(); /* wait for child */
@@ -593,16 +596,15 @@ ExpState *esPtr;
#endif /*SIMPLE_EVENT*/
static int
-update_interact_fds(interp,esPtrCount,esPtrToInput,esPtrs,input_base,
- do_indirect,config_count,real_tty_caller)
-Tcl_Interp *interp;
-int *esPtrCount;
-Tcl_HashTable **esPtrToInput; /* map from ExpStates to "struct inputs" */
-ExpState ***esPtrs;
-struct input *input_base;
-int do_indirect; /* if true do indirects */
-int *config_count;
-int *real_tty_caller;
+update_interact_fds(
+ Tcl_Interp *interp,
+ int *esPtrCount,
+ Tcl_HashTable **esPtrToInput, /* map from ExpStates to "struct inputs" */
+ ExpState ***esPtrs,
+ struct input *input_base,
+ int do_indirect, /* if true do indirects */
+ int *config_count,
+ int *real_tty_caller)
{
struct input *inp;
struct output *outp;
@@ -686,12 +688,12 @@ int *real_tty_caller;
/*ARGSUSED*/
static char *
-inter_updateproc(clientData, interp, name1, name2, flags)
-ClientData clientData;
-Tcl_Interp *interp; /* Interpreter containing variable. */
-char *name1; /* Name of variable. */
-char *name2; /* Second part of variable name. */
-int flags; /* Information about what happened. */
+inter_updateproc(
+ ClientData clientData,
+ Tcl_Interp *interp, /* Interpreter containing variable. */
+ char *name1, /* Name of variable. */
+ char *name2, /* Second part of variable name. */
+ int flags) /* Information about what happened. */
{
exp_configure_count++;
return 0;
@@ -704,15 +706,16 @@ static char interpreter_cmd[] = "interpr
/*ARGSUSED*/
int
-Exp_InteractObjCmd(clientData, interp, objc, objv)
-ClientData clientData;
-Tcl_Interp *interp;
-int objc;
-Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_InteractObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST initial_objv[]) /* Argument objects. */
{
ThreadSpecificData *tsdPtr = TCL_TSD_INIT(&dataKey);
Tcl_Obj *CONST *objv_copy; /* original, for error messages */
+ Tcl_Obj **objv = (Tcl_Obj **) initial_objv;
char *string;
Tcl_UniChar *ustring;
@@ -2146,10 +2149,10 @@ got_action:
/* version of Tcl_Eval for interact */
static int
-inter_eval(interp,action,esPtr)
-Tcl_Interp *interp;
-struct action *action;
-ExpState *esPtr;
+inter_eval(
+ Tcl_Interp *interp,
+ struct action *action,
+ ExpState *esPtr)
{
int status;
@@ -2168,8 +2171,7 @@ ExpState *esPtr;
}
static void
-free_keymap(km)
-struct keymap *km;
+free_keymap(struct keymap *km)
{
if (km == 0) return;
free_keymap(km->next);
@@ -2178,8 +2180,7 @@ struct keymap *km;
}
static void
-free_action(a)
-struct action *a;
+free_action(struct action *a)
{
struct action *next;
@@ -2191,9 +2192,9 @@ struct action *a;
}
static void
-free_input(interp,i)
-Tcl_Interp *interp;
-struct input *i;
+free_input(
+ Tcl_Interp *interp,
+ struct input *i)
{
if (i == 0) return;
free_input(interp,i->next);
@@ -2205,8 +2206,7 @@ struct input *i;
}
static struct action *
-new_action(base)
-struct action **base;
+new_action(struct action **base)
{
struct action *o = new(struct action);
@@ -2218,9 +2218,9 @@ struct action **base;
}
static void
-free_output(interp,o)
-Tcl_Interp *interp;
-struct output *o;
+free_output(
+ Tcl_Interp *interp,
+ struct output *o)
{
if (o == 0) return;
free_output(interp,o->next);
@@ -2235,8 +2235,7 @@ static struct exp_cmd_data cmd_data[] =
{0}};
void
-exp_init_interact_cmds(interp)
-Tcl_Interp *interp;
+exp_init_interact_cmds(Tcl_Interp *interp)
{
ThreadSpecificData *tsdPtr = TCL_TSD_INIT(&dataKey);
Index: expect.c
===================================================================
--- expect.c.orig
+++ expect.c
@@ -34,7 +34,7 @@ would appreciate credit if this program
#include "exp_command.h"
#include "exp_log.h"
#include "exp_event.h"
-#include "exp_tty.h"
+#include "exp_tty_in.h"
#include "exp_tstamp.h" /* this should disappear when interact */
/* loses ref's to it */
#ifdef TCL_DEBUGGER
@@ -134,10 +134,10 @@ struct exp_cmd_descriptor {
*/
static void
-exp_cmd_init(cmd,cmdtype,duration)
-struct exp_cmd_descriptor *cmd;
-int duration;
-int cmdtype;
+exp_cmd_init(
+ struct exp_cmd_descriptor *cmd,
+ int duration,
+ int cmdtype)
{
cmd->duration = duration;
cmd->cmdtype = cmdtype;
@@ -156,14 +156,21 @@ static int alarm_fired; /* if alarm occu
void exp_background_channelhandlers_run_all();
/* exp_indirect_updateX is called by Tcl when an indirect variable is set */
-static char *exp_indirect_update1(); /* 1-part Tcl variable names */
-static char *exp_indirect_update2(); /* 2-part Tcl variable names */
+static char *exp_indirect_update1( /* 1-part Tcl variable names */
+ Tcl_Interp *interp,
+ struct exp_cmd_descriptor *ecmd,
+ struct exp_i *exp_i);
+static char *exp_indirect_update2( /* 2-part Tcl variable names */
+ ClientData clientData,
+ Tcl_Interp *interp, /* Interpreter containing variable. */
+ char *name1, /* Name of variable. */
+ char *name2, /* Second part of variable name. */
+ int flags); /* Information about what happened. */
#ifdef SIMPLE_EVENT
/*ARGSUSED*/
static RETSIGTYPE
-sigalarm_handler(n)
-int n; /* unused, for compatibility with STDC */
+sigalarm_handler(int n) /* unused, for compatibility with STDC */
{
alarm_fired = TRUE;
}
@@ -171,10 +178,10 @@ int n; /* unused, for compatibi
/* free up everything in ecase */
static void
-free_ecase(interp,ec,free_ilist)
-Tcl_Interp *interp;
-struct ecase *ec;
-int free_ilist; /* if we should free ilist */
+free_ecase(
+ Tcl_Interp *interp,
+ struct ecase *ec,
+ int free_ilist) /* if we should free ilist */
{
if (ec->i_list->duration == EXP_PERMANENT) {
if (ec->pat) { Tcl_DecrRefCount(ec->pat); }
@@ -194,10 +201,10 @@ int free_ilist; /* if we should free il
/* free up any argv structures in the ecases */
static void
-free_ecases(interp,eg,free_ilist)
-Tcl_Interp *interp;
-struct exp_cmd_descriptor *eg;
-int free_ilist; /* if true, free ilists */
+free_ecases(
+ Tcl_Interp *interp,
+ struct exp_cmd_descriptor *eg,
+ int free_ilist) /* if true, free ilists */
{
int i;
@@ -216,8 +223,7 @@ int free_ilist; /* if true, free ilists
#if 0
/* no standard defn for this, and some systems don't even have it, so avoid */
/* the whole quagmire by calling it something else */
-static char *exp_strdup(s)
-char *s;
+static char *exp_strdup(char *s)
{
char *news = ckalloc(strlen(s) + 1);
strcpy(news,s);
@@ -242,8 +248,7 @@ char *s;
Current test is very cheap and almost always right :-)
*/
int
-exp_one_arg_braced(objPtr) /* INTL */
-Tcl_Obj *objPtr;
+exp_one_arg_braced(Tcl_Obj *objPtr) /* INTL */
{
int seen_nl = FALSE;
char *p = Tcl_GetString(objPtr);
@@ -268,10 +273,10 @@ Tcl_Obj *objPtr;
* its current argumnts */
/*ARGSUSED*/
Tcl_Obj*
-exp_eval_with_one_arg(clientData,interp,objv) /* INTL */
-ClientData clientData;
-Tcl_Interp *interp;
-Tcl_Obj *CONST objv[]; /* Argument objects. */
+exp_eval_with_one_arg(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
Tcl_Obj* res = Tcl_NewListObj (1,objv);
@@ -348,8 +353,7 @@ Tcl_Obj *CONST objv[]; /* Argument obje
}
static void
-ecase_clear(ec)
-struct ecase *ec;
+ecase_clear(struct ecase *ec)
{
ec->i_list = 0;
ec->pat = 0;
@@ -365,7 +369,7 @@ struct ecase *ec;
}
static struct ecase *
-ecase_new()
+ecase_new(void)
{
struct ecase *ec = (struct ecase *)ckalloc(sizeof(struct ecase));
@@ -400,12 +404,12 @@ The exp_i chain can be broken by the cal
*/
static int
-parse_expect_args(interp,eg,default_esPtr,objc,objv)
-Tcl_Interp *interp;
-struct exp_cmd_descriptor *eg;
-ExpState *default_esPtr; /* suggested ExpState if called as expect_user or _tty */
-int objc;
-Tcl_Obj *CONST objv[]; /* Argument objects. */
+parse_expect_args(
+ Tcl_Interp *interp,
+ struct exp_cmd_descriptor *eg,
+ ExpState *default_esPtr, /* suggested ExpState if called as expect_user or _tty */
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
int i;
char *string;
@@ -718,9 +722,9 @@ struct eval_out {
*/
Tcl_UniChar *
-string_case_first(string,pattern) /* INTL */
- register Tcl_UniChar *string; /* String (unicode). */
- register char *pattern; /* Pattern, which may contain
+string_case_first( /* INTL */
+ register Tcl_UniChar *string, /* String (unicode). */
+ register char *pattern) /* Pattern, which may contain
* special characters (utf8). */
{
Tcl_UniChar *s;
@@ -748,9 +752,9 @@ string_case_first(string,pattern) /* INT
}
Tcl_UniChar *
-string_first(string,pattern) /* INTL */
- register Tcl_UniChar *string; /* String (unicode). */
- register char *pattern; /* Pattern, which may contain
+string_first( /* INTL */
+ register Tcl_UniChar *string, /* String (unicode). */
+ register char *pattern) /* Pattern, which may contain
* special characters (utf8). */
{
Tcl_UniChar *s;
@@ -778,9 +782,9 @@ string_first(string,pattern) /* INTL */
}
Tcl_UniChar *
-string_first_char(string,pattern) /* INTL */
- register Tcl_UniChar *string; /* String. */
- register Tcl_UniChar pattern;
+string_first_char( /* INTL */
+ register Tcl_UniChar *string, /* String. */
+ register Tcl_UniChar pattern)
{
/* unicode based Tcl_UtfFindFirst */
@@ -803,15 +807,15 @@ string_first_char(string,pattern) /* INT
/* string match */
/* returns EXP_X where X is MATCH, NOMATCH, FULLBUFFER, TCLERRROR */
static int
-eval_case_string(interp,e,esPtr,o,last_esPtr,last_case,suffix)
-Tcl_Interp *interp;
-struct ecase *e;
-ExpState *esPtr;
-struct eval_out *o; /* 'output' - i.e., final case of interest */
+eval_case_string(
+ Tcl_Interp *interp,
+ struct ecase *e,
+ ExpState *esPtr,
+ struct eval_out *o, /* 'output' - i.e., final case of interest */
/* next two args are for debugging, when they change, reprint buffer */
-ExpState **last_esPtr;
-int *last_case;
-char *suffix;
+ ExpState **last_esPtr,
+ int *last_case,
+ char *suffix)
{
Tcl_RegExp re;
Tcl_RegExpInfo info;
@@ -977,18 +981,18 @@ char *suffix;
/* sets o.e if successfully finds a matching pattern, eof, timeout or deflt */
/* returns original status arg or EXP_TCLERROR */
static int
-eval_cases(interp,eg,esPtr,o,last_esPtr,last_case,status,esPtrs,mcount,suffix)
-Tcl_Interp *interp;
-struct exp_cmd_descriptor *eg;
-ExpState *esPtr;
-struct eval_out *o; /* 'output' - i.e., final case of interest */
+eval_cases(
+ Tcl_Interp *interp,
+ struct exp_cmd_descriptor *eg,
+ ExpState *esPtr,
+ struct eval_out *o, /* 'output' - i.e., final case of interest */
/* next two args are for debugging, when they change, reprint buffer */
-ExpState **last_esPtr;
-int *last_case;
-int status;
-ExpState *(esPtrs[]);
-int mcount;
-char *suffix;
+ ExpState **last_esPtr,
+ int *last_case,
+ int status,
+ ExpState *(esPtrs[]),
+ int mcount,
+ char *suffix)
{
int i;
ExpState *em; /* ExpState of ecase */
@@ -1061,10 +1065,10 @@ char *suffix;
}
static void
-ecases_remove_by_expi(interp,ecmd,exp_i)
-Tcl_Interp *interp;
-struct exp_cmd_descriptor *ecmd;
-struct exp_i *exp_i;
+ecases_remove_by_expi(
+ Tcl_Interp *interp,
+ struct exp_cmd_descriptor *ecmd,
+ struct exp_i *exp_i)
{
int i;
@@ -1095,10 +1099,10 @@ struct exp_i *exp_i;
/* remove exp_i from list */
static void
-exp_i_remove(interp,ei,exp_i)
-Tcl_Interp *interp;
-struct exp_i **ei; /* list to remove from */
-struct exp_i *exp_i; /* element to remove */
+exp_i_remove(
+ Tcl_Interp *interp,
+ struct exp_i **ei, /* list to remove from */
+ struct exp_i *exp_i) /* element to remove */
{
/* since it's in middle of list, free exp_i by hand */
for (;*ei; ei = &(*ei)->next) {
@@ -1113,10 +1117,10 @@ struct exp_i *exp_i; /* element to remov
/* remove exp_i from list and remove any dependent ecases */
static void
-exp_i_remove_with_ecases(interp,ecmd,exp_i)
-Tcl_Interp *interp;
-struct exp_cmd_descriptor *ecmd;
-struct exp_i *exp_i;
+exp_i_remove_with_ecases(
+ Tcl_Interp *interp,
+ struct exp_cmd_descriptor *ecmd,
+ struct exp_i *exp_i)
{
ecases_remove_by_expi(interp,ecmd,exp_i);
exp_i_remove(interp,&ecmd->i_list,exp_i);
@@ -1124,11 +1128,11 @@ struct exp_i *exp_i;
/* remove ecases tied to a single direct spawn id */
static void
-ecmd_remove_state(interp,ecmd,esPtr,direct)
-Tcl_Interp *interp;
-struct exp_cmd_descriptor *ecmd;
-ExpState *esPtr;
-int direct;
+ecmd_remove_state(
+ Tcl_Interp *interp,
+ struct exp_cmd_descriptor *ecmd,
+ ExpState *esPtr,
+ int direct)
{
struct exp_i *exp_i, *next;
struct exp_state_list **slPtr;
@@ -1168,9 +1172,9 @@ int direct;
/* this is called from exp_close to clean up the ExpState */
void
-exp_ecmd_remove_state_direct_and_indirect(interp,esPtr)
-Tcl_Interp *interp;
-ExpState *esPtr;
+exp_ecmd_remove_state_direct_and_indirect(
+ Tcl_Interp *interp,
+ ExpState *esPtr)
{
ecmd_remove_state(interp,&exp_cmds[EXP_CMD_BEFORE],esPtr,EXP_DIRECT|EXP_INDIRECT);
ecmd_remove_state(interp,&exp_cmds[EXP_CMD_AFTER],esPtr,EXP_DIRECT|EXP_INDIRECT);
@@ -1182,9 +1186,9 @@ ExpState *esPtr;
/* arm a list of background ExpState's */
static void
-state_list_arm(interp,slPtr)
-Tcl_Interp *interp;
-struct exp_state_list *slPtr;
+state_list_arm(
+ Tcl_Interp *interp,
+ struct exp_state_list *slPtr)
{
/* for each spawn id in list, arm if necessary */
for (;slPtr;slPtr=slPtr->next) {
@@ -1201,9 +1205,9 @@ struct exp_state_list *slPtr;
/* return TRUE if this ecase is used by this fd */
static int
-exp_i_uses_state(exp_i,esPtr)
-struct exp_i *exp_i;
-ExpState *esPtr;
+exp_i_uses_state(
+ struct exp_i *exp_i,
+ ExpState *esPtr)
{
struct exp_state_list *fdp;
@@ -1214,9 +1218,9 @@ ExpState *esPtr;
}
static void
-ecase_append(interp,ec)
-Tcl_Interp *interp;
-struct ecase *ec;
+ecase_append(
+ Tcl_Interp *interp,
+ struct ecase *ec)
{
if (!ec->transfer) Tcl_AppendElement(interp,"-notransfer");
if (ec->indices) Tcl_AppendElement(interp,"-indices");
@@ -1231,10 +1235,10 @@ struct ecase *ec;
/* append all ecases that match this exp_i */
static void
-ecase_by_exp_i_append(interp,ecmd,exp_i)
-Tcl_Interp *interp;
-struct exp_cmd_descriptor *ecmd;
-struct exp_i *exp_i;
+ecase_by_exp_i_append(
+ Tcl_Interp *interp,
+ struct exp_cmd_descriptor *ecmd,
+ struct exp_i *exp_i)
{
int i;
for (i=0;i<ecmd->ecd.count;i++) {
@@ -1245,9 +1249,9 @@ struct exp_i *exp_i;
}
static void
-exp_i_append(interp,exp_i)
-Tcl_Interp *interp;
-struct exp_i *exp_i;
+exp_i_append(
+ Tcl_Interp *interp,
+ struct exp_i *exp_i)
{
Tcl_AppendElement(interp,"-i");
if (exp_i->direct == EXP_INDIRECT) {
@@ -1261,8 +1265,8 @@ struct exp_i *exp_i;
}
for (fdp = exp_i->state_list;fdp;fdp=fdp->next) {
- char buf[10]; /* big enough for a small int */
- sprintf(buf,"%d",fdp->esPtr);
+ char buf[25]; /* big enough for a small int */
+ sprintf(buf,"%ld", (long)fdp->esPtr);
Tcl_AppendElement(interp,buf);
}
@@ -1274,11 +1278,11 @@ struct exp_i *exp_i;
/* return current setting of the permanent expect_before/after/bg */
int
-expect_info(interp,ecmd,objc,objv)
-Tcl_Interp *interp;
-struct exp_cmd_descriptor *ecmd;
-int objc;
-Tcl_Obj *CONST objv[]; /* Argument objects. */
+expect_info(
+ Tcl_Interp *interp,
+ struct exp_cmd_descriptor *ecmd,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
struct exp_i *exp_i;
int i;
@@ -1362,11 +1366,11 @@ Tcl_Obj *CONST objv[]; /* Argument obje
/* Exp_ExpectGlobalObjCmd is invoked to process expect_before/after/background */
/*ARGSUSED*/
int
-Exp_ExpectGlobalObjCmd(clientData, interp, objc, objv)
-ClientData clientData;
-Tcl_Interp *interp;
-int objc;
-Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_ExpectGlobalObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
int result = TCL_OK;
struct exp_i *exp_i, **eip;
@@ -1574,8 +1578,7 @@ Tcl_Obj *CONST objv[]; /* Argument obje
/* adjusts file according to user's size request */
void
-expAdjust(esPtr)
-ExpState *esPtr;
+expAdjust(ExpState *esPtr)
{
int new_msize, excess;
Tcl_UniChar *string;
@@ -1632,9 +1635,9 @@ ExpState *esPtr;
#if OBSOLETE
/* Strip parity */
static void
-expParityStrip(obj,offsetBytes)
- Tcl_Obj *obj;
- int offsetBytes;
+expParityStrip(
+ Tcl_Obj *obj,
+ int offsetBytes)
{
char *p, ch;
@@ -1659,9 +1662,9 @@ expParityStrip(obj,offsetBytes)
be at a UTF boundary.
*/
static void
-expValid(obj,offset)
- Tcl_Obj *obj;
- int offset;
+expValid(
+ Tcl_Obj *obj,
+ int offset)
{
char *s, *end;
int len;
@@ -1709,9 +1712,9 @@ expValid(obj,offset)
/* Strip nulls from object, beginning at offset */
static int
-expNullStrip(buf,offsetChars)
- ExpUniBuf* buf;
- int offsetChars;
+expNullStrip(
+ ExpUniBuf* buf,
+ int offsetChars)
{
Tcl_UniChar *src, *src2, *dest, *end;
int newsize; /* size of obj after all nulls removed */
@@ -1737,11 +1740,11 @@ expNullStrip(buf,offsetChars)
/* the read will complete immediately. */
/*ARGSUSED*/
static int
-expIRead(interp,esPtr,timeout,save_flags) /* INTL */
-Tcl_Interp *interp;
-ExpState *esPtr;
-int timeout;
-int save_flags;
+expIRead( /* INTL */
+ Tcl_Interp *interp,
+ ExpState *esPtr,
+ int timeout,
+ int save_flags)
{
int cc = EXP_TIMEOUT;
int size;
@@ -1812,13 +1815,13 @@ int save_flags;
/* if it returns a non-negative number, it means there is data */
/* (0 means nothing new was actually read, but it should be looked at again) */
int
-expRead(interp,esPtrs,esPtrsMax,esPtrOut,timeout,key)
-Tcl_Interp *interp;
-ExpState *(esPtrs[]); /* If 0, then esPtrOut already known and set */
-int esPtrsMax; /* number of esPtrs */
-ExpState **esPtrOut; /* Out variable to leave new ExpState. */
-int timeout;
-int key;
+expRead(
+ Tcl_Interp *interp,
+ ExpState *(esPtrs[]), /* If 0, then esPtrOut already known and set */
+ int esPtrsMax, /* number of esPtrs */
+ ExpState **esPtrOut, /* Out variable to leave new ExpState. */
+ int timeout,
+ int key)
{
ExpState *esPtr;
@@ -1920,12 +1923,12 @@ int key;
/* when buffer fills, copy second half over first and */
/* continue, so we can do matches over multiple buffers */
void
-exp_buffer_shuffle(interp,esPtr,save_flags,array_name,caller_name) /* INTL */
-Tcl_Interp *interp;
-ExpState *esPtr;
-int save_flags;
-char *array_name;
-char *caller_name;
+exp_buffer_shuffle( /* INTL */
+ Tcl_Interp *interp,
+ ExpState *esPtr,
+ int save_flags,
+ char *array_name,
+ char *caller_name)
{
Tcl_UniChar *str;
Tcl_UniChar *p;
@@ -1989,8 +1992,7 @@ char *caller_name;
/* map EXP_ style return value to TCL_ style return value */
/* not defined to work on TCL_OK */
int
-exp_tcl2_returnvalue(x)
-int x;
+exp_tcl2_returnvalue(int x)
{
switch (x) {
case TCL_ERROR: return EXP_TCLERROR;
@@ -2009,8 +2011,7 @@ int x;
/* map from EXP_ style return value to TCL_ style return values */
int
-exp_2tcl_returnvalue(x)
-int x;
+exp_2tcl_returnvalue(int x)
{
switch (x) {
case EXP_TCLERROR: return TCL_ERROR;
@@ -2033,9 +2034,9 @@ This allows the user to localize them if
avoid having to put "global" in procedure definitions.
*/
char *
-exp_get_var(interp,var)
-Tcl_Interp *interp;
-char *var;
+exp_get_var(
+ Tcl_Interp *interp,
+ char *var)
{
char *val;
@@ -2045,8 +2046,7 @@ char *var;
}
static int
-get_timeout(interp)
-Tcl_Interp *interp;
+get_timeout(Tcl_Interp *interp)
{
ThreadSpecificData *tsdPtr = TCL_TSD_INIT(&dataKey);
CONST char *t;
@@ -2060,9 +2060,9 @@ Tcl_Interp *interp;
/* make a copy of a linked list (1st arg) and attach to end of another (2nd
arg) */
static int
-update_expect_states(i_list,i_union)
-struct exp_i *i_list;
-struct exp_state_list **i_union;
+update_expect_states(
+ struct exp_i *i_list,
+ struct exp_state_list **i_union)
{
struct exp_i *p;
@@ -2092,8 +2092,7 @@ struct exp_state_list **i_union;
}
char *
-exp_cmdtype_printable(cmdtype)
-int cmdtype;
+exp_cmdtype_printable(int cmdtype)
{
switch (cmdtype) {
case EXP_CMD_FG: return("expect");
@@ -2110,12 +2109,12 @@ int cmdtype;
/* an indirect spawn id list is changed */
/*ARGSUSED*/
static char *
-exp_indirect_update2(clientData, interp, name1, name2, flags)
-ClientData clientData;
-Tcl_Interp *interp; /* Interpreter containing variable. */
-char *name1; /* Name of variable. */
-char *name2; /* Second part of variable name. */
-int flags; /* Information about what happened. */
+exp_indirect_update2(
+ ClientData clientData,
+ Tcl_Interp *interp, /* Interpreter containing variable. */
+ char *name1, /* Name of variable. */
+ char *name2, /* Second part of variable name. */
+ int flags) /* Information about what happened. */
{
char *msg;
@@ -2129,10 +2128,10 @@ int flags; /* Information about what ha
}
static char *
-exp_indirect_update1(interp,ecmd,exp_i)
-Tcl_Interp *interp;
-struct exp_cmd_descriptor *ecmd;
-struct exp_i *exp_i;
+exp_indirect_update1(
+ Tcl_Interp *interp,
+ struct exp_cmd_descriptor *ecmd,
+ struct exp_i *exp_i)
{
struct exp_state_list *slPtr; /* temp for interating over state_list */
@@ -2205,13 +2204,13 @@ struct exp_i *exp_i;
}
int
-expMatchProcess(interp, eo, cc, bg, detail)
- Tcl_Interp *interp;
- struct eval_out *eo; /* final case of interest */
- int cc; /* EOF, TIMEOUT, etc... */
- int bg; /* 1 if called from background handler, */
+expMatchProcess(
+ Tcl_Interp *interp,
+ struct eval_out *eo, /* final case of interest */
+ int cc, /* EOF, TIMEOUT, etc... */
+ int bg, /* 1 if called from background handler, */
/* else 0 */
- char *detail;
+ char *detail)
{
ExpState *esPtr = 0;
Tcl_Obj *body = 0;
@@ -2385,9 +2384,9 @@ expMatchProcess(interp, eo, cc, bg, deta
/* this function is called from the background when input arrives */
/*ARGSUSED*/
void
-exp_background_channelhandler(clientData,mask) /* INTL */
-ClientData clientData;
-int mask;
+exp_background_channelhandler( /* INTL */
+ ClientData clientData,
+ int mask)
{
char backup[EXP_CHANNELNAMELEN+1]; /* backup copy of esPtr channel name! */
@@ -2510,11 +2509,11 @@ do_more_data:
/*ARGSUSED*/
int
-Exp_ExpectObjCmd(clientData, interp, objc, objv)
-ClientData clientData;
-Tcl_Interp *interp;
-int objc;
-Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_ExpectObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
int cc; /* number of chars returned in a single read */
/* or negative EXP_whatever */
@@ -2767,11 +2766,11 @@ error:
/*ARGSUSED*/
static int
-Exp_TimestampObjCmd(clientData, interp, objc, objv)
-ClientData clientData;
-Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_TimestampObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
char *format = 0;
time_t seconds = -1;
@@ -2866,14 +2865,14 @@ process_di _ANSI_ARGS_ ((Tcl_Interp* int
CONST char* cmd));
static int
-process_di (interp,objc,objv,at,Default,esOut,cmd)
-Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
- int* at;
- int* Default;
- CONST char* cmd;
- ExpState **esOut;
+process_di (
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[], /* Argument objects. */
+ int* at,
+ int* Default,
+ ExpState **esOut,
+ CONST char* cmd)
{
static char* options[] = {
"-d",
@@ -2947,11 +2946,11 @@ Tcl_Interp *interp;
/*ARGSUSED*/
int
-Exp_MatchMaxObjCmd(clientData,interp,objc,objv)
- ClientData clientData;
- Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_MatchMaxObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
int size = -1;
ExpState *esPtr = 0;
@@ -2993,11 +2992,11 @@ Exp_MatchMaxObjCmd(clientData,interp,obj
/*ARGSUSED*/
int
-Exp_RemoveNullsObjCmd(clientData,interp,objc,objv)
-ClientData clientData;
-Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_RemoveNullsObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
int value = -1;
ExpState *esPtr = 0;
@@ -3037,11 +3036,11 @@ Tcl_Interp *interp;
/*ARGSUSED*/
int
-Exp_ParityObjCmd(clientData,interp,objc,objv)
-ClientData clientData;
-Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_ParityObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
int parity;
ExpState *esPtr = 0;
@@ -3076,11 +3075,11 @@ Tcl_Interp *interp;
/*ARGSUSED*/
int
-Exp_CloseOnEofObjCmd(clientData,interp,objc,objv)
-ClientData clientData;
-Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+Exp_CloseOnEofObjCmd(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
int close_on_eof;
ExpState *esPtr = 0;
@@ -3117,8 +3116,7 @@ Tcl_Interp *interp;
/* This big chunk of code is just for debugging the permanent */
/* expect cases */
void
-exp_fd_print(slPtr)
-struct exp_state_list *slPtr;
+exp_fd_print(struct exp_state_list *slPtr)
{
if (!slPtr) return;
printf("%d ",slPtr->esPtr);
@@ -3126,8 +3124,7 @@ struct exp_state_list *slPtr;
}
void
-exp_i_print(exp_i)
-struct exp_i *exp_i;
+exp_i_print(struct exp_i *exp_i)
{
if (!exp_i) return;
printf("exp_i %x",exp_i);
@@ -3143,16 +3140,14 @@ struct exp_i *exp_i;
}
void
-exp_ecase_print(ecase)
-struct ecase *ecase;
+exp_ecase_print(struct ecase *ecase)
{
printf("pat <%s>\n",ecase->pat);
printf("exp_i = %x\n",ecase->i_list);
}
void
-exp_ecases_print(ecd)
-struct exp_cases_descriptor *ecd;
+exp_ecases_print(struct exp_cases_descriptor *ecd)
{
int i;
@@ -3161,8 +3156,7 @@ struct exp_cases_descriptor *ecd;
}
void
-exp_cmd_print(ecmd)
-struct exp_cmd_descriptor *ecmd;
+exp_cmd_print(struct exp_cmd_descriptor *ecmd)
{
printf("expect cmd type: %17s",exp_cmdtype_printable(ecmd->cmdtype));
printf((ecmd->duration==EXP_PERMANENT)?" perm ": "tmp ");
@@ -3172,7 +3166,7 @@ struct exp_cmd_descriptor *ecmd;
}
void
-exp_cmds_print()
+exp_cmds_print(void)
{
exp_cmd_print(&exp_cmds[EXP_CMD_BEFORE]);
exp_cmd_print(&exp_cmds[EXP_CMD_AFTER]);
@@ -3181,11 +3175,11 @@ exp_cmds_print()
/*ARGSUSED*/
int
-cmdX(clientData, interp, objc, objv)
-ClientData clientData;
-Tcl_Interp *interp;
- int objc;
- Tcl_Obj *CONST objv[]; /* Argument objects. */
+cmdX(
+ ClientData clientData,
+ Tcl_Interp *interp,
+ int objc,
+ Tcl_Obj *CONST objv[]) /* Argument objects. */
{
exp_cmds_print();
return TCL_OK;
@@ -3193,7 +3187,7 @@ Tcl_Interp *interp;
#endif /*DEBUG_PERM_ECASES*/
void
-expExpectVarsInit()
+expExpectVarsInit(void)
{
ThreadSpecificData *tsdPtr = TCL_TSD_INIT(&dataKey);
@@ -3216,8 +3210,7 @@ cmd_data[] = {
{0}};
void
-exp_init_expect_cmds(interp)
-Tcl_Interp *interp;
+exp_init_expect_cmds(Tcl_Interp *interp)
{
exp_create_commands(interp,cmd_data);
@@ -3248,7 +3241,7 @@ Tcl_Interp *interp;
}
void
-exp_init_sig() {
+exp_init_sig(void) {
#if 0
signal(SIGALRM,sigalarm_handler);
signal(SIGINT,sigint_handler);
Index: retoglob.c
===================================================================
--- retoglob.c.orig
+++ retoglob.c
@@ -44,9 +44,9 @@ xxx (Tcl_UniChar* x, int xl)
Tcl_Obj*
-exp_retoglob (str,strlen)
- Tcl_UniChar* str;
- int strlen;
+exp_retoglob (
+ Tcl_UniChar* str,
+ int strlen)
{
/*
* Output: x2 size of input (literal where every character has to be
Index: exp_main_exp.c
===================================================================
--- exp_main_exp.c.orig
+++ exp_main_exp.c
@@ -14,6 +14,7 @@ would appreciate credit if this program
#include <stdio.h>
#include "tcl.h"
#include "expect_tcl.h"
+#include <stdlib.h>
int
main(argc, argv)
Index: exp_win.c
===================================================================
--- exp_win.c.orig
+++ exp_win.c
@@ -51,7 +51,7 @@ conflicts with sys/ioctl.h
# include <sys/ptem.h>
#endif /* HAVE_SYS_PTEM_H */
-#include "exp_tty.h"
+#include "exp_tty_in.h"
#include "exp_win.h"
#ifdef TIOCGWINSZ
Index: pty_termios.c
===================================================================
--- pty_termios.c.orig
+++ pty_termios.c
@@ -627,10 +627,10 @@ int control; /* if 1, enable pty trappin
}
int
-exp_getptyslave(ttycopy,ttyinit,stty_args)
-int ttycopy;
-int ttyinit;
-char *stty_args;
+exp_getptyslave(
+ int ttycopy,
+ int ttyinit,
+ CONST char *stty_args)
{
int slave, slave2;
char buf[10240];
Index: exp_strf.c
===================================================================
--- exp_strf.c.orig
+++ exp_strf.c
@@ -148,7 +148,7 @@ int low, item, hi;
void
/*size_t*/
#ifndef __STDC__
-exp_strftime(/*s,*/ format, timeptr, dstring)
+exp_strftime(
/*char *s;*/
char *format;
const struct tm *timeptr;