Message204726
This is going to have to wait until Python 3.5, so I'm going to back out the exec_module() aspects of BuiltinImporter and ExtensionFileLoader. As Nick has pointed out previously, we are going to need to change the init function signature of extension modules to accept the module to initialize (or something). This also extends to built-in modules as on Windows all extension modules are compiled in, so there is no real distinction between the two scenarios, so this can't be only partially solved for built-ins but not extension modules.
This is another reason why we will need to go with a soft deprecation of load_module() in Python 3.4 and hopefully get all of this straightened out in Python 3.5 so we can introduce a hard deprecation.
And just in case we end up having to hack our way around the call signature, PyModule_Create() could be tweaked to pull modules from a cache that can be seeded with the module that is to be used for the initialization. That way call signatures don't have to change but what module gets used can be controlled. |
|
Date |
User |
Action |
Args |
2013-11-29 15:18:15 | brett.cannon | set | recipients:
+ brett.cannon, ncoghlan, Arfrever, eric.snow |
2013-11-29 15:18:15 | brett.cannon | set | messageid: <1385738295.57.0.681041140136.issue19698@psf.upfronthosting.co.za> |
2013-11-29 15:18:15 | brett.cannon | link | issue19698 messages |
2013-11-29 15:18:14 | brett.cannon | create | |
|