[Python-Dev] importlib is now bootstrapped (and what that means)

Georg Brandl g.brandl at gmx.net
Tue Apr 17 01:11:14 CEST 2012


On 16.04.2012 18:15, R. David Murray wrote:
> On Mon, 16 Apr 2012 11:21:34 -0400, Brett Cannon<brett at python.org>  wrote:
>>  On Mon, Apr 16, 2012 at 10:07, "Martin v. Löwis"<martin at v.loewis.de>  wrote:
>>
>>  >  >  We have other instances of this (e.g. the Objects/typeslots.inc file
>>  >  >  is generated and checked in), but in the case of importlib, we have
>>  >  >  to use the ./python binary for freezing to avoid bytecode
>>  >  >  incompatibilities, which obviously is a problem if ./python isn't
>>  >  >  built yet.
>>  >
>>  >  As for dependencies on byte code: we could consider using Cython instead
>>  >  of freeze (not sure whether Cython would build the bootstrap correctly;
>>  >  it may need to be fixed first). With that, we would get semi-readable
>>  >  source code, which should also play more nicely with hg diffs. On the
>>  >  down side, we would depend on Cython for evolving .

That is an interesting idea.  We already depend on external tools, e.g.
autotools, for updating checked-in files, so why not Cython.

>>  We could also just store the raw source code and use that if we are all
>>  willing to pay the performance cost of parsing and compiling the code at
>>  every startup.
>
> I don't see how depending on Cython is better than depending on having
> an existing Python.

No, it's not just an existing Python, it is (at least currently) the same
version of Python being built.  Therefore I wrote about the bootstrapping
problems when bytecode changes.

Depending on Cython is better in that it breaks the bootstrapping cycle,
but on the other hand the C code may need to be regenerated when the C API
changes in an incompatible way.

>  If the only benefit is semi-readable code, surely
> we do have source code for the pre-frozen module, and it is just a matter
> of convincing hg that the bytecode is binary, not text?

The benefit is also (presumably) better performance.

Georg



More information about the Python-Dev mailing list