> On Nov 24, 2014, at 6:12 AM, Ian Kelly <ian.g.ke...@gmail.com> wrote:
> 
> 
> On Nov 24, 2014 1:27 AM, "Patrick Stinson" <patrickk...@gmail.com 
> <mailto:patrickk...@gmail.com>> wrote:
> >
> > How does the __del__ method have a reference to the module’s globals dict? 
> > because it references the print function?
> 
> The module's dict becomes the __globals__ dict used by the function for 
> looking up globals and builtins.
> 
Wow, that’s very helpful and good to know. Funny I never ran into that when 
doing this via an extensive CPython embedding project. Or maybe I ignored it.
> > Crazy. Is there any other way to comfort when a module is being deleted 
> > beside defining a class object with a printing dtor?
> 
> Modules don't strictly have to be ModuleType. You could substitute a class 
> with a __del__ method for the module itself for testing this. Be careful with 
> leaving this in your production code though, as the presence of __del__ 
> methods can interfere with garbage collection and are not advisable prior to 
> 3.4.
> 
> You can also test whether an object is still in memory by looking for it in 
> gc.get_objects() although be warned that is an expensive call.
> 
Interesting concept. One thing I am doing is allowing one script to import 
another by name. So in my gui I’ll have a panel for each script with a line 
edit to set the name, which then generates an appropriate slug. Is it still 
possible to import non-module objects? I guess this question is just for fun 
now :)


> -- 
> https://mail.python.org/mailman/listinfo/python-list

-- 
https://mail.python.org/mailman/listinfo/python-list

Reply via email to