summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSteve Dower <steve.dower@microsoft.com>2015-08-04 23:02:40 (GMT)
committerSteve Dower <steve.dower@microsoft.com>2015-08-04 23:02:40 (GMT)
commit08b1817fd88317243e143c64009da8f9d5474981 (patch)
treefeb9828971fe9ab9c3b84b85f701c258f91e9071
parentb3ca31f5f1ba51173d4b920ab5f423c63169d830 (diff)
downloadcpython-08b1817fd88317243e143c64009da8f9d5474981.zip
cpython-08b1817fd88317243e143c64009da8f9d5474981.tar.gz
cpython-08b1817fd88317243e143c64009da8f9d5474981.tar.bz2
Puts compiled pyc files into embedded library ZIP file instead of sources.
-rw-r--r--Tools/msi/make_zip.py12
1 files changed, 11 insertions, 1 deletions
diff --git a/Tools/msi/make_zip.py b/Tools/msi/make_zip.py
index 521ba93..bace19a 100644
--- a/Tools/msi/make_zip.py
+++ b/Tools/msi/make_zip.py
@@ -1,4 +1,5 @@
import argparse
+import py_compile
import re
import sys
import shutil
@@ -82,7 +83,16 @@ def copy_to_layout(target, rel_sources):
with ZipFile(str(target), 'w', ZIP_DEFLATED) as f:
for s, rel in rel_sources:
- f.write(str(s), str(rel))
+ if rel.suffix.lower() == '.py':
+ pyc = Path(tempfile.gettempdir()) / rel.with_suffix('.pyc').name
+ try:
+ py_compile.compile(str(s), str(pyc), str(rel), doraise=True, optimize=2)
+ except py_compile.PyCompileError:
+ f.write(str(s), str(rel))
+ else:
+ f.write(str(pyc), str(rel.with_suffix('.pyc')))
+ else:
+ f.write(str(s), str(rel))
count += 1
else: