Issue 11254: distutils doesn't byte-compile .py files to pycache during installation (original) (raw)

Created on 2011-02-20 09:54 by scoder, last changed 2022-04-11 14:57 by admin. This issue is now closed.

Files
File name Uploaded Description Edit
issue11254.patch scoder,2011-02-20 10:21 proposed patch, hopefully minimally invasive review
issue11254.patch jramnani,2011-03-14 21:49 Update #1 to patch. Add fix for failing unit tests review
bug-11254.diff eric.araujo,2011-03-20 21:32 review
Messages (19)
msg128897 - (view) Author: Stefan Behnel (scoder) * (Python committer) Date: 2011-02-20 09:54
During installation of Python packages (setup.py install or bdist), distutils puts .pyc files into the installed source directory, instead of moving them into __pycache__. This may mean that they are not getting used after installation (with potentially no way of getting updated due to lack of write access by users), and that source files that get imported during installation may end up with .pyc files in both the source directory and the __pycache__ directory in the installed package. The relevant python-dev thread is here: http://thread.gmane.org/gmane.comp.python.devel/121248/
msg128899 - (view) Author: Stefan Behnel (scoder) * (Python committer) Date: 2011-02-20 10:21
Here's a patch. I basically copied over the way py_compile determines the .pyc file name. It works for me for a "normal" installation. However, I couldn't test it with "-O", as 2to3 crashes for me when I enable it during installation. I guess that's a separate issue.
msg128903 - (view) Author: Éric Araujo (eric.araujo) * (Python committer) Date: 2011-02-20 12:47
Patch looks good. Regarding the problem with 2to3 and -O, maybe you can run 2to3 manually, copy the setup.py and run python3.2 -0. disutils.util.byte_compile is not tested, so this patch requires at least careful manual testing, and if possible a unit test. In distutils2, it may be possible to replace this function with a compileall call.
msg130912 - (view) Author: Jeff Ramnani (jramnani) * Date: 2011-03-14 21:49
This patch applies cleanly as of rev 89af3880ca57 on branch default. After applying the patch, I had two unit test failures when running, "/python.exe -m test -v test_distutils", on OS X 10.6. The tests were failing because they were not looking in the __pycache__ directory for byte-compiled or optimized files. Attaching an updated patch that fixes the unit tests that were breaking.
msg130963 - (view) Author: Éric Araujo (eric.araujo) * (Python committer) Date: 2011-03-15 11:21
Thanks for the test. The patch is minimal and makes distutils work correctly with the new pyc handling in 3.2+, so I will apply it in a few days unless Tarek disagrees.
msg131546 - (view) Author: Éric Araujo (eric.araujo) * (Python committer) Date: 2011-03-20 21:32
I cleaned up the patch a bit. In particular, I removed the dance around imp.cache_from_source that seemed unnecessary. I tested with regular Python, with PYTHONOPTIMIZE and with PYTHONDONTWRITEBYTECODE. Can you review and test too?
msg131837 - (view) Author: Éric Araujo (eric.araujo) * (Python committer) Date: 2011-03-23 01:57
The dance around imp.cache_from_source looks necessary, judging by Georg’s http://hg.python.org/cpython/rev/713c6b6ca5ce/#l8.53
msg132460 - (view) Author: Jeff Ramnani (jramnani) * Date: 2011-03-29 03:31
I've reviewed your patch and it looks good. I appreciate the review and cleanup. The tests succeed for me after applying your patch. I also tested with PYTHONOPTIMIZE and PYTHONDONTWRITEBYTECODE and got the output I expected.
msg137212 - (view) Author: Ned Deily (ned.deily) * (Python committer) Date: 2011-05-29 18:49
Should this be a release blocker for 3.2.1?
msg137253 - (view) Author: Tarek Ziadé (tarek) * (Python committer) Date: 2011-05-30 10:14
to be backported in packaging -- in a way that will make it work with previous python versions for the incoming 2.x backport
msg140448 - (view) Author: Dave Malcolm (dmalcolm) (Python committer) Date: 2011-07-15 18:01
FWIW, I've filed a bug about this issue for Fedora 15's python3 package here: https://bugzilla.redhat.com/show_bug.cgi?id=722578 Looks like this has led to an extra .pyc in the old location for every Python 3 .py file in Fedora 15's various python3-* rpm packages (as generated by distutils). rpm's post-processing has been generating .pyc files in the (correct) __pycache__ location (via rpmbuild's brp-python-bytecompile script, which uses "compileall"). For examples, see that Fedora bug report; so far it's affected every built rpm I've looked at. I believe the impact of the extra .pyc files is merely wasted disk space within our rpm-packaged Python 3.2 stack. I'm thinking of applying the patch to our downstream python3.src.rpm
msg145098 - (view) Author: Éric Araujo (eric.araujo) * (Python committer) Date: 2011-10-07 16:21
I will commit this today or tomorrow.
msg145220 - (view) Author: Roundup Robot (python-dev) (Python triager) Date: 2011-10-09 06:59
New changeset 27a36b05caed by Éric Araujo in branch '3.2': Fix distutils byte-compilation to comply with PEP 3147 (#11254). http://hg.python.org/cpython/rev/27a36b05caed New changeset 651e84363001 by Éric Araujo in branch '3.2': Fix docstring of distutils.util.byte_compile (followup for #11254) http://hg.python.org/cpython/rev/651e84363001 New changeset 439f47fadffa by Éric Araujo in branch 'default': Fix packaging byte-compilation to comply with PEP 3147 (#11254). http://hg.python.org/cpython/rev/439f47fadffa
msg145228 - (view) Author: Éric Araujo (eric.araujo) * (Python committer) Date: 2011-10-09 07:19
Finally fixed. I fail at boolean logic; removing the “dance around imp.cache_from_source that seemed unnecessary” as I called it was a mistake, we have to do it, so I restored that part of your original patch. I’m sorry I took so long to fix this, it was straightforward.
msg145942 - (view) Author: Roundup Robot (python-dev) (Python triager) Date: 2011-10-19 19:32
New changeset 1cc4d822123b by Éric Araujo in branch 'default': More fixes for PEP 3147 compliance in packaging (#11254) http://hg.python.org/cpython/rev/1cc4d822123b
msg145943 - (view) Author: Éric Araujo (eric.araujo) * (Python committer) Date: 2011-10-19 19:38
Installation was not completely fixed. Distutils delegates to each command’s get_outputs method to make the list of all files to install or package in an sdist, and the previous patch missed edits to these get_outputs methods. I should have fixed it in packaging, I’ll port to distutils soon.
msg146939 - (view) Author: Roundup Robot (python-dev) (Python triager) Date: 2011-11-03 15:45
New changeset ea926dff958f by Éric Araujo in branch '3.2': More fixes for PEP 3147 compliance in distutils (#11254) http://hg.python.org/cpython/rev/ea926dff958f New changeset 60ede940089f by Éric Araujo in branch 'default': Merge follow-up for #11254 and other changes from 3.2 http://hg.python.org/cpython/rev/60ede940089f
msg147681 - (view) Author: Roundup Robot (python-dev) (Python triager) Date: 2011-11-15 15:14
New changeset c10946a17420 by Éric Araujo in branch 'default': Clean up byte-compilation code in packaging (#11254 followup). http://hg.python.org/cpython/rev/c10946a17420
msg153091 - (view) Author: Éric Araujo (eric.araujo) * (Python committer) Date: 2012-02-11 04:47
See also #13123 for the same bug in bdist_wininst.
History
Date User Action Args
2022-04-11 14:57:13 admin set github: 55463
2012-02-11 04:47:06 eric.araujo set messages: +
2011-11-15 15:14:00 python-dev set messages: +
2011-11-03 16:07:04 eric.araujo set status: open -> closedresolution: fixedstage: commit review -> resolved
2011-11-03 15:45:54 python-dev set messages: +
2011-11-03 01:52:08 pitrou unlink issue13307 dependencies
2011-11-02 16:54:11 eric.araujo link issue13307 dependencies
2011-10-21 13:27:14 eric.araujo link issue13181 superseder
2011-10-19 19:38:18 eric.araujo set status: closed -> openresolution: fixed -> (no value)messages: + stage: resolved -> commit review
2011-10-19 19:32:55 python-dev set messages: +
2011-10-09 07:19:54 eric.araujo set status: open -> closedresolution: fixedmessages: + stage: commit review -> resolved
2011-10-09 06:59:49 python-dev set nosy: + python-devmessages: +
2011-10-07 16:21:52 eric.araujo set messages: +
2011-07-15 18:01:24 dmalcolm set nosy: + dmalcolmmessages: +
2011-05-30 10:14:40 tarek set messages: +
2011-05-29 18:49:29 ned.deily set nosy: + ned.deilymessages: +
2011-03-29 03:31:25 jramnani set messages: +
2011-03-23 01:57:57 eric.araujo set nosy: + georg.brandlmessages: +
2011-03-20 21:32:06 eric.araujo set files: + bug-11254.diffnosy:barry, scoder, tarek, eric.araujo, alexis, jramnanimessages: +
2011-03-15 11:21:40 eric.araujo set assignee: tarek -> eric.araujomessages: + nosy:barry, scoder, tarek, eric.araujo, alexis, jramnanistage: patch review -> commit review
2011-03-14 21:49:22 jramnani set files: + issue11254.patchnosy: + jramnanimessages: +
2011-02-20 14:00:36 pitrou set priority: normal -> criticalnosy:barry, scoder, tarek, eric.araujo, alexis
2011-02-20 12:47:22 eric.araujo set versions: + 3rd party, Python 3.3nosy: + alexis, barrymessages: + components: + Distutils2stage: patch review
2011-02-20 10:21:24 scoder set files: + issue11254.patchmessages: + keywords: + patchnosy:scoder, tarek, eric.araujo
2011-02-20 09:54:53 scoder create