diff options
author | Steve Bennett <steveb@workware.net.au> | 2011-11-14 08:49:33 +1000 |
---|---|---|
committer | Steve Bennett <steveb@workware.net.au> | 2011-11-18 07:59:40 +1000 |
commit | 2999556ded2042c03403b5bc97d64f5257572e4f (patch) | |
tree | 1ff1c599314a6fe90ab3793075122463af7885b3 /jim.c | |
parent | c7f5c1516468bc44bd61e556adebbdf4e5f39e13 (diff) | |
download | jimtcl-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.c | 8 |
1 files changed, 8 insertions, 0 deletions
@@ -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; |