Nick Coghlan added the comment:

As a high level overview of the general idea: we'd like it to be almost 
entirely transparent to the end user as to whether a particular module is 
implemented as normal Python source code, a precompiled bytecode/wordcode file, 
or a precompiled Cython extension module (or equivalent).

At the moment, this is pretty close to being true for source code vs 
precompiled bytecode/wordcode when it comes to both imports and execution as a 
script. The main missing piece there is to implement source code maps for 
generating more informative tracebacks given only the precompiled form (perhaps 
by borrowing JavaScript's "source map" concept)

For extension modules, the original multi-phase initialisation PEP got this 
pretty close to being true for the import case - things like reload() can now 
work much the same way they do for pure Python and pyc files if a module author 
(or module generation tool) cares to make it so.

However, we don't yet support the use of extension modules as scripts, neither 
for direct execution, nor via the `-m` switch, so it's impossible for a tool 
like Cython to handle that transparently - if a module exposes functionality 
via -m, then migrating it directly to Cython will break than behaviour.

----------

_______________________________________
Python tracker <rep...@bugs.python.org>
<http://bugs.python.org/issue30403>
_______________________________________
_______________________________________________
Python-bugs-list mailing list
Unsubscribe: 
https://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com

Reply via email to