summaryrefslogtreecommitdiffstats
path: root/generic/tclBasic.c
diff options
context:
space:
mode:
authorjan.nijtmans <nijtmans@users.sourceforge.net>2022-09-02 12:58:27 (GMT)
committerjan.nijtmans <nijtmans@users.sourceforge.net>2022-09-02 12:58:27 (GMT)
commit585d7c7548a1715348b0a9bd270044a399b1f14d (patch)
tree533d62504706414acc050bdfc769b4e489cdad99 /generic/tclBasic.c
parent5573c07b32a8f1b33c937bf2adea3af5089aa1d2 (diff)
parentead37ca168eb29e8afc501d242116547534d619b (diff)
downloadtcl-585d7c7548a1715348b0a9bd270044a399b1f14d.zip
tcl-585d7c7548a1715348b0a9bd270044a399b1f14d.tar.gz
tcl-585d7c7548a1715348b0a9bd270044a399b1f14d.tar.bz2
Merge 8.7
Diffstat (limited to 'generic/tclBasic.c')
-rw-r--r--generic/tclBasic.c24
1 files changed, 15 insertions, 9 deletions
diff --git a/generic/tclBasic.c b/generic/tclBasic.c
index eb3889d..54df6ff 100644
--- a/generic/tclBasic.c
+++ b/generic/tclBasic.c
@@ -2631,26 +2631,30 @@ Tcl_CreateCommand(
*/
typedef struct {
- void *clientData; /* Arbitrary value to pass to object function. */
Tcl_ObjCmdProc2 *proc;
- Tcl_ObjCmdProc2 *nreProc;
+ void *clientData; /* Arbitrary value to pass to proc function. */
Tcl_CmdDeleteProc *deleteProc;
+ void *deleteData; /* Arbitrary value to pass to deleteProc function. */
+ Tcl_ObjCmdProc2 *nreProc;
} CmdWrapperInfo;
static int cmdWrapperProc(void *clientData,
- Tcl_Interp *interp,
- int objc,
+ Tcl_Interp *interp,
+ int objc,
Tcl_Obj * const *objv)
{
CmdWrapperInfo *info = (CmdWrapperInfo *)clientData;
+ if (objc < 0) {
+ objc = -1;
+ }
return info->proc(info->clientData, interp, objc, objv);
}
static void cmdWrapperDeleteProc(void *clientData) {
CmdWrapperInfo *info = (CmdWrapperInfo *)clientData;
- clientData = info->clientData;
+ clientData = info->deleteData;
Tcl_CmdDeleteProc *deleteProc = info->deleteProc;
Tcl_Free(info);
if (deleteProc != NULL) {
@@ -2677,8 +2681,9 @@ Tcl_CreateObjCommand2(
{
CmdWrapperInfo *info = (CmdWrapperInfo *)Tcl_Alloc(sizeof(CmdWrapperInfo));
info->proc = proc;
- info->deleteProc = deleteProc;
info->clientData = clientData;
+ info->deleteProc = deleteProc;
+ info->deleteData = clientData;
return Tcl_CreateObjCommand(interp, cmdName,
(proc ? cmdWrapperProc : NULL),
@@ -3297,7 +3302,7 @@ Tcl_SetCommandInfoFromToken(
if (cmdPtr->deleteProc == cmdWrapperDeleteProc) {
CmdWrapperInfo *info = (CmdWrapperInfo *)cmdPtr->deleteData;
info->deleteProc = infoPtr->deleteProc;
- info->clientData = infoPtr->deleteData;
+ info->deleteData = infoPtr->deleteData;
} else {
cmdPtr->deleteProc = infoPtr->deleteProc;
cmdPtr->deleteData = infoPtr->deleteData;
@@ -3381,7 +3386,7 @@ Tcl_GetCommandInfoFromToken(
if (cmdPtr->deleteProc == cmdWrapperDeleteProc) {
CmdWrapperInfo *info = (CmdWrapperInfo *)cmdPtr->deleteData;
infoPtr->deleteProc = info->deleteProc;
- infoPtr->deleteData = info->clientData;
+ infoPtr->deleteData = info->deleteData;
} else {
infoPtr->deleteProc = cmdPtr->deleteProc;
infoPtr->deleteData = cmdPtr->deleteData;
@@ -8491,9 +8496,10 @@ Tcl_NRCreateCommand2(
{
CmdWrapperInfo *info = (CmdWrapperInfo *)Tcl_Alloc(sizeof(CmdWrapperInfo));
info->proc = proc;
+ info->clientData = clientData;
info->nreProc = nreProc;
info->deleteProc = deleteProc;
- info->clientData = clientData;
+ info->deleteData = clientData;
return Tcl_NRCreateCommand(interp, cmdName,
(proc ? cmdWrapperProc : NULL),
(nreProc ? cmdWrapperNreProc : NULL),