aboutsummaryrefslogtreecommitdiff
path: root/jim.c
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 /jim.c
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>
Diffstat (limited to 'jim.c')
-rw-r--r--jim.c8
1 files changed, 8 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;