Bugs item #1177811, was opened at 2005-04-06 16:30
Message generated for change (Comment added) made by effbot
You can respond by visiting: 
https://sourceforge.net/tracker/?func=detail&atid=105470&aid=1177811&group_id=5470

Please note that this message will contain a full copy of the comment thread,
including the initial issue submission, for this request,
not just the latest update.
Category: Python Interpreter Core
Group: Python 2.4
Status: Open
Resolution: None
Priority: 5
Submitted By: Andrew Wilkinson (andrew_j_w)
Assigned to: Nobody/Anonymous (nobody)
Summary: Exec Inside A Function

Initial Comment:
When 'exec'ing code that creates a function inside a function the 
defined function (fact in the example below) is created with the 
module level namespace as it's parent scope. 
 
The following should return 2 however it raises a NameError as fact 
is not defined. 
 
def f(): 
    exec """ 
def fact(x): 
    if x==1: 
        return 1 
    else: 
        return x*fact(x-1) 
""" 
    return fact 
 
f()(2) 
 
If you run following code... 
 
def f(): 
    exec """ 
def fact(x): 
    if x==1: 
        return 1 
    else: 
        return x*fact(x-1) 
""" in locals() 
    return fact 
 
... it works as expected. 
 
The documentation states that "In all cases, if the optional parts 
are omitted, the code is executed in the current scope." That is 
clearly not the case here as the 'fact' function is set with the 
module level scope as it's parent scope. 
 
It would appear to me that either this a documentation bug or a 
flaw in exec. I sincerely hope this a bug in exec and not the 
desired behaviour as it doesn't make any sense to me... 
 

----------------------------------------------------------------------

>Comment By: Fredrik Lundh (effbot)
Date: 2005-11-12 17:59

Message:
Logged In: YES 
user_id=38376

As described in the language reference, scope analysis is
done statically, during compilation. If the compiler cannot
see your innermost function (because you've hidden it inside
a string literal), it obviously cannot take any variables in
there into account when generating code for the outer scopes.

(I sincerely hope that this is a contrived example, and that
you're not trying to use exec in this way in real code.
Python might be a highly dynamic language, but it's not this
dynamic.)

----------------------------------------------------------------------

You can respond by visiting: 
https://sourceforge.net/tracker/?func=detail&atid=105470&aid=1177811&group_id=5470
_______________________________________________
Python-bugs-list mailing list 
Unsubscribe: 
http://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com

Reply via email to