From d6d4bb969fa1616d93e6a3f125308a6c386af51e Mon Sep 17 00:00:00 2001 From: dkf Date: Wed, 25 Aug 2004 21:28:26 +0000 Subject: Fixes to ensemble -unknown handler processing to stop [namespace import] from disrupting things horribly. Problem found by Don Porter when investigating [Bug 1016167]. --- ChangeLog | 8 ++++++++ generic/tclNamesp.c | 20 +++++--------------- tests/namespace.test | 28 +++++++++++++++++++++++++++- 3 files changed, 40 insertions(+), 16 deletions(-) diff --git a/ChangeLog b/ChangeLog index 31bdb1d..c4bf470 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,11 @@ +2004-08-25 Donal K. Fellows + + * generic/tclNamesp.c (NsEnsembleImplementationCmd): Use the + ensemble command token to get the name of the ensemble for passing + to the -unknown handler instead of relying on objv[0], which may + contain useless info in the presence of [namespace import]. + Problem found by Don Porter when investigating [Bug 1016167]. + 2004-08-24 Don Porter * generic/tclProc.c: The routine TclProcInterpProc was a specific diff --git a/generic/tclNamesp.c b/generic/tclNamesp.c index e38f2da..d1da5ae 100644 --- a/generic/tclNamesp.c +++ b/generic/tclNamesp.c @@ -21,7 +21,7 @@ * See the file "license.terms" for information on usage and redistribution * of this file, and for a DISCLAIMER OF ALL WARRANTIES. * - * RCS: @(#) $Id: tclNamesp.c,v 1.44 2004/08/03 21:46:55 dkf Exp $ + * RCS: @(#) $Id: tclNamesp.c,v 1.45 2004/08/25 21:28:26 dkf Exp $ */ #include "tclInt.h" @@ -4933,22 +4933,12 @@ NsEnsembleImplementationCmd(clientData, interp, objc, objv) if (ensemblePtr->unknownHandler != NULL && reparseCount++ < 1) { int paramc, i; - Tcl_Obj **paramv, *unknownCmd; - char *ensName = TclGetString(objv[0]); + Tcl_Obj **paramv, *unknownCmd, *ensObj; unknownCmd = Tcl_DuplicateObj(ensemblePtr->unknownHandler); - if (ensName[0] == ':') { - Tcl_ListObjAppendElement(NULL, unknownCmd, objv[0]); - } else { - Tcl_Obj *qualEnsembleObj = - Tcl_NewStringObj(Tcl_GetCurrentNamespace(interp)->fullName,-1); - if (Tcl_GetCurrentNamespace(interp)->parentPtr) { - Tcl_AppendStringsToObj(qualEnsembleObj, "::", ensName, NULL); - } else { - Tcl_AppendStringsToObj(qualEnsembleObj, ensName, NULL); - } - Tcl_ListObjAppendElement(NULL, unknownCmd, qualEnsembleObj); - } + TclNewObj(ensObj); + Tcl_GetCommandFullName(interp, ensemblePtr->token, ensObj); + Tcl_ListObjAppendElement(NULL, unknownCmd, ensObj); for (i=1 ; i