aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSteve Bennett <steveb@workware.net.au>2011-11-14 08:49:33 +1000
committerSteve Bennett <steveb@workware.net.au>2011-11-18 07:59:40 +1000
commit2999556ded2042c03403b5bc97d64f5257572e4f (patch)
tree1ff1c599314a6fe90ab3793075122463af7885b3
parentc7f5c1516468bc44bd61e556adebbdf4e5f39e13 (diff)
downloadjimtcl-2999556ded2042c03403b5bc97d64f5257572e4f.zip
jimtcl-2999556ded2042c03403b5bc97d64f5257572e4f.tar.gz
jimtcl-2999556ded2042c03403b5bc97d64f5257572e4f.tar.bz2
Don't allow upvar to a higher level
i.e. upvar of a global var to a proc var Signed-off-by: Steve Bennett <steveb@workware.net.au>
-rw-r--r--jim.c8
-rw-r--r--regtest.tcl13
-rw-r--r--tests/upvar.test5
3 files changed, 26 insertions, 0 deletions
diff --git a/jim.c b/jim.c
index ebc3dae..a204328 100644
--- a/jim.c
+++ b/jim.c
@@ -4066,6 +4066,14 @@ int Jim_SetVariableLink(Jim_Interp *interp, Jim_Obj *nameObjPtr,
}
Jim_IncrRefCount(targetNameObjPtr);
+ if (framePtr->level < targetCallFrame->level) {
+ Jim_SetResultFormatted(interp,
+ "bad variable name \"%#s\": upvar won't create namespace variable that refers to procedure variable",
+ nameObjPtr);
+ Jim_DecrRefCount(interp, targetNameObjPtr);
+ return JIM_ERR;
+ }
+
/* Check for cycles. */
if (framePtr == targetCallFrame) {
Jim_Obj *objPtr = targetNameObjPtr;
diff --git a/regtest.tcl b/regtest.tcl
index 999d4b0..0f2e5b6 100644
--- a/regtest.tcl
+++ b/regtest.tcl
@@ -165,6 +165,19 @@ set t 6
catch a
puts "TEST 24 PASSED"
+# REGTEST 25
+# 14 Nov 2011 - link global var to proc var
+proc a {} {
+ set x 3
+ upvar 0 x ::globx
+}
+set globx 0
+catch {
+ a
+}
+incr globx
+puts "TEST 25 PASSED"
+
# TAKE THE FOLLOWING puts AS LAST LINE
puts "--- ALL TESTS PASSED ---"
diff --git a/tests/upvar.test b/tests/upvar.test
index 4b919a2..8d95c1d 100644
--- a/tests/upvar.test
+++ b/tests/upvar.test
@@ -340,6 +340,11 @@ test upvar-9.6 {upvar via global namespace} {
list [catch p1 msg] $msg
} {1 {can't upvar from variable to itself}}
+test upvar-9.7 {upvar to higher level} {
+ proc p1 {} { upvar 0 x ::globx }
+ list [catch p1 msg] $msg
+} {1 {bad variable name "::globx": upvar won't create namespace variable that refers to procedure variable}}
+
catch {unset a}
testreport