[ python-Bugs-1539847 ] Identifiers begining with __ renamed
SourceForge.net
noreply at sourceforge.net
Wed Aug 16 08:34:23 CEST 2006
Bugs item #1539847, was opened at 2006-08-14 07:47
Message generated for change (Comment added) made by gbrandl
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=105470&aid=1539847&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: Closed
Resolution: Invalid
Priority: 5
Submitted By: W Barnes (w_barnes)
Assigned to: Nobody/Anonymous (nobody)
Summary: Identifiers begining with __ renamed
Initial Comment:
Identifiers used in a class function that start with
__ are renamed to _classname__identifer even if the
identifier is owned by some other object.
Code snippet:
size = len(Data.__entry_dates)
Here I'm trying to access the identifier
__entry_dates in the module Data from the function
DataTestCase.testEntryDates() but I get the following:
Traceback (most recent call last):
File "DataTest.py", line 247, in testEntryDates
size = len(Data.__entry_dates)
AttributeError: 'module' object has no
attribute '_DataTestCase__entry_dates'
I'm using Python 2.4.3 on Windows XP sp2
Thanks,
Walter
----------------------------------------------------------------------
>Comment By: Georg Brandl (gbrandl)
Date: 2006-08-16 06:34
Message:
Logged In: YES
user_id=849994
> The error message is a bit misleading though. If I define
> __widget in foo then access it from bar as foo.__widget
> why does it rename it as _bar__widget if it was not
> defined there? If it needs to do this internally why not
> use the unmangled name for the error message?
This is how name mangling works. All __x attribute access in
a class is mangled with *this* class's name -- it happens in
the compiling stage, where the compiler doesn't know
anything but this name (this also rules out changing the
error message). In case of other classes' attributes this is
fine since the attribute is *supposed* to be private to this
other class.
With global __x variables, the advice is "don't do that".
Still, I have no problem accessing them through the module's
__dict__, unmangled of course.
----------------------------------------------------------------------
Comment By: W Barnes (w_barnes)
Date: 2006-08-16 04:29
Message:
Logged In: YES
user_id=1541460
I just noticed some more weirdness in regards to name
mangling...
Apparently there is no way for a class to access global
attributes that are declared private. That is if a
module 'foo' has a global attribute '__widget' a
class 'bar' also defined in foo will get the following
error if it attempts to access __widget:
NameError: global name '_bar__widget' is not defined
Using either _foo__widget directly or __dict__ doesn't
work.
For now, I can get around this by using a non-private
global helper function as a middle man.
I'm a Python newbie but, for what it's worth, here are
some suggestions:
First, if an attribute is accessed as a child of some
object other than 'self' or the name of the enclosing
class no name mangling should be done. It seems that name
mangling isn't necessary here as an attribute error will
all ways be raised whether or not the object has that
attribute.
Second, when searching for a global attribute that begins
with __ it should be renamed to reflect the name of the
module not the enclosing class. In the example above, if
_bar__widget cannot be found in bar then it should look
for _foo__widget in the global namespace.
Finally, as I mentioned before, for clarity if no match is
found the error message should include the unmangled name.
----------------------------------------------------------------------
Comment By: W Barnes (w_barnes)
Date: 2006-08-16 02:10
Message:
Logged In: YES
user_id=1541460
Thanks!
I was unaware that name mangling applied to global
attributes as well as class attributes.
The error message is a bit misleading though. If I define
__widget in foo then access it from bar as foo.__widget
why does it rename it as _bar__widget if it was not
defined there? If it needs to do this internally why not
use the unmangled name for the error message?
----------------------------------------------------------------------
Comment By: Georg Brandl (gbrandl)
Date: 2006-08-14 08:07
Message:
Logged In: YES
user_id=849994
This is exactly how __ name mangling is supposed to work.
These are meant to be private, and thus shouldn't be
accessed from another class.
If the attribute was in another class, you could do the
mangling (with the correct class name!) yourself, as it's on
a module in this case, use __dict__:
size = len(Data.__dict__['__entry_dates'])
----------------------------------------------------------------------
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=105470&aid=1539847&group_id=5470
More information about the Python-bugs-list
mailing list