summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--generic/tclCmdIL.c16
-rw-r--r--tests/info.test8
2 files changed, 14 insertions, 10 deletions
diff --git a/generic/tclCmdIL.c b/generic/tclCmdIL.c
index 0d88044..3742ba9 100644
--- a/generic/tclCmdIL.c
+++ b/generic/tclCmdIL.c
@@ -1201,9 +1201,6 @@ InfoFrameCmd(
}
framePtr = iPtr->cmdFramePtr;
- if (!framePtr) {
- goto levelError;
- }
while (++level <= 0) {
framePtr = framePtr->nextPtr;
if (!framePtr) {
@@ -1272,9 +1269,14 @@ TclInfoFrame(
static const char *const typeString[TCL_LOCATION_LAST] = {
"eval", "eval", "eval", "precompiled", "source", "proc"
};
- Proc *procPtr = framePtr->framePtr ? framePtr->framePtr->procPtr : NULL;
+ Proc *procPtr = NULL;
int needsFree = -1;
+ if (!framePtr) {
+ goto precompiled;
+ }
+ procPtr = framePtr->framePtr ? framePtr->framePtr->procPtr : NULL;
+
/*
* Pull the information and construct the dictionary to return, as list.
* Regarding use of the CmdFrame fields see tclInt.h, and its definition.
@@ -1302,11 +1304,11 @@ TclInfoFrame(
break;
case TCL_LOCATION_PREBC:
+ precompiled:
/*
* Precompiled. Result contains the type as signal, nothing else.
*/
-
- ADD_PAIR("type", Tcl_NewStringObj(typeString[framePtr->type], -1));
+ ADD_PAIR("type", Tcl_NewStringObj(typeString[TCL_LOCATION_PREBC], -1));
break;
case TCL_LOCATION_BC: {
@@ -1421,7 +1423,7 @@ TclInfoFrame(
* _visible_ CallFrame.
*/
- if ((framePtr->framePtr != NULL) && (iPtr->varFramePtr != NULL)) {
+ if (framePtr && (framePtr->framePtr != NULL) && (iPtr->varFramePtr != NULL)) {
CallFrame *current = framePtr->framePtr;
CallFrame *top = iPtr->varFramePtr;
CallFrame *idx;
diff --git a/tests/info.test b/tests/info.test
index e4d9c89..38fa5f2 100644
--- a/tests/info.test
+++ b/tests/info.test
@@ -2597,12 +2597,14 @@ test info-40.0 {Bug 0de6c1d79c crash} -setup {
child hide info
} -body {
list [child invokehidden info frame] \
- [catch {child invokehidden info frame 0} msg] $msg \
- [catch {child invokehidden info frame 1} msg] $msg
+ [child invokehidden info frame 0] \
+ [child invokehidden info frame 1] \
+ [catch {child invokehidden info frame -1} msg] $msg \
+ [catch {child invokehidden info frame 2} msg] $msg
} -cleanup {
interp delete child
unset -nocomplain msg
-} -result {1 1 {bad level "0"} 1 {bad level "1"}}
+} -result {1 {type precompiled} {type precompiled} 1 {bad level "-1"} 1 {bad level "2"}}
# cleanup
catch {namespace delete test_ns_info1 test_ns_info2}