diff options
author | dgp <dgp@users.sourceforge.net> | 2007-02-06 21:08:05 (GMT) |
---|---|---|
committer | dgp <dgp@users.sourceforge.net> | 2007-02-06 21:08:05 (GMT) |
commit | 11d70a65e6f7578f2d0e486b978142e3bcdcc304 (patch) | |
tree | 7ad5524122d1e3696248043277e03193466d2d73 | |
parent | 88cd3810ef18b4e05cae8aebda92c41155ce7f1a (diff) | |
download | tcl-11d70a65e6f7578f2d0e486b978142e3bcdcc304.zip tcl-11d70a65e6f7578f2d0e486b978142e3bcdcc304.tar.gz tcl-11d70a65e6f7578f2d0e486b978142e3bcdcc304.tar.bz2 |
* generic/tclNamesp.c: Corrected broken implementation of the
* tests/namespace.test: TclMatchIsTrivial optimization on
[namespace children $namespace $pattern].
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | generic/tclNamesp.c | 8 | ||||
-rw-r--r-- | tests/namespace.test | 7 |
3 files changed, 18 insertions, 3 deletions
@@ -1,3 +1,9 @@ +2007-02-06 Don Porter <dgp@users.sourceforge.net> + + * generic/tclNamesp.c: Corrected broken implementation of the + * tests/namespace.test: TclMatchIsTrivial optimization on + [namespace children $namespace $pattern]. + 2007-02-04 Daniel Steffen <das@users.sourceforge.net> * unix/tcl.m4: use gcc4's __attribute__((__visibility__("hidden"))) if diff --git a/generic/tclNamesp.c b/generic/tclNamesp.c index d641eef..f5f3da1 100644 --- a/generic/tclNamesp.c +++ b/generic/tclNamesp.c @@ -22,7 +22,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.121 2006/12/08 13:50:42 dkf Exp $ + * RCS: @(#) $Id: tclNamesp.c,v 1.122 2007/02/06 21:08:06 dgp Exp $ */ #include "tclInt.h" @@ -3113,7 +3113,11 @@ NamespaceChildrenCmd( listPtr = Tcl_NewListObj(0, NULL); if ((pattern != NULL) && TclMatchIsTrivial(pattern)) { - if (Tcl_FindHashEntry(&nsPtr->childTable, pattern) != NULL) { + int length = strlen(nsPtr->fullName); + if (strncmp(pattern, nsPtr->fullName, length) != 0) { + goto searchDone; + } + if (Tcl_FindHashEntry(&nsPtr->childTable, pattern+length) != NULL) { Tcl_ListObjAppendElement(interp, listPtr, Tcl_NewStringObj(pattern, -1)); } diff --git a/tests/namespace.test b/tests/namespace.test index 3f1f5dc..b712f01 100644 --- a/tests/namespace.test +++ b/tests/namespace.test @@ -11,7 +11,7 @@ # See the file "license.terms" for information on usage and redistribution # of this file, and for a DISCLAIMER OF ALL WARRANTIES. # -# RCS: @(#) $Id: namespace.test,v 1.63 2006/11/23 15:35:31 dkf Exp $ +# RCS: @(#) $Id: namespace.test,v 1.64 2007/02/06 21:08:07 dgp Exp $ if {[lsearch [namespace children] ::tcltest] == -1} { package require tcltest 2 @@ -914,6 +914,11 @@ test namespace-21.7 {NamespaceChildrenCmd, glob-style pattern given} { namespace eval test_ns_1::test_ns_foo {} lsort [namespace children test_ns_1 test*] } [lsort {::test_ns_1::test_ns_2 ::test_ns_1::test_ns_foo}] +test namespace-21.8 {NamespaceChildrenCmd, trivial pattern starting with ::} { + namespace eval test_ns_1 {} + namespace children [namespace current] \ + [string trimright [namespace current] :]::test_ns_1 +} [string trimright [namespace current] :]::test_ns_1 test namespace-22.1 {NamespaceCodeCmd, bad args} { catch {namespace delete {*}[namespace children :: test_ns_*]} |