Set the line number correctly for a nested function with an exec or
authorJeremy Hylton <jeremy@alum.mit.edu>
Thu, 22 Mar 2001 03:57:58 +0000 (03:57 +0000)
committerJeremy Hylton <jeremy@alum.mit.edu>
Thu, 22 Mar 2001 03:57:58 +0000 (03:57 +0000)
import *.  Mark the offending stmt rather than the function def line.

Include/symtable.h
Python/compile.c

index 6c4f2844654d66f4637108ac167a3d4f1f78f0af..315ce1fe5a4062fcfd1b3d5470e13b3795d28cbd 100644 (file)
@@ -46,6 +46,7 @@ typedef struct _symtable_entry {
        int ste_nested;          /* true if scope is nested */
        int ste_child_free;      /* true if a child scope has free variables,
                                    including free refs to globals */
+       int ste_opt_lineno;      /* lineno of last exec or import * */
        struct symtable *ste_table;
 } PySymtableEntryObject;
 
index fe84921433d074c41cb7f8272e75fc7aece87a82..3e638ca62be5f874cb1f038003be556b51453ab7 100644 (file)
@@ -4241,7 +4241,7 @@ symtable_check_unoptimized(struct compiling *c,
        if (c->c_symtable->st_nested_scopes) {
                PyErr_SetString(PyExc_SyntaxError, buf);
                PyErr_SyntaxLocation(c->c_symtable->st_filename,
-                                    ste->ste_lineno);
+                                    ste->ste_opt_lineno);
                return -1;
        }
        else {
@@ -4820,8 +4820,10 @@ symtable_node(struct symtable *st, node *n)
                symtable_node(st, CHILD(n, 1));
                if (NCH(n) > 2)
                        symtable_node(st, CHILD(n, 3));
-               else
+               else {
                        st->st_cur->ste_optimized |= OPT_BARE_EXEC;
+                       st->st_cur->ste_opt_lineno = n->n_lineno;
+               }
                if (NCH(n) > 4)
                        symtable_node(st, CHILD(n, 5));
                break;
@@ -5106,6 +5108,7 @@ symtable_import(struct symtable *st, node *n)
                }
                if (TYPE(CHILD(n, 3)) == STAR) {
                        st->st_cur->ste_optimized |= OPT_IMPORT_STAR;
+                       st->st_cur->ste_opt_lineno = n->n_lineno;
                } else {
                        for (i = 3; i < NCH(n); i += 2) {
                                node *c = CHILD(n, i);