|
Panu Matilainen |
2e4024 |
commit 5463570061a7ca9ed947885b516c2551778b636f
|
|
Panu Matilainen |
2e4024 |
Author: Panu Matilainen <pmatilai@redhat.com>
|
|
Panu Matilainen |
2e4024 |
Date: Tue Oct 27 16:07:43 2009 +0200
|
|
Panu Matilainen |
2e4024 |
|
|
Panu Matilainen |
2e4024 |
Support multiple python versions in brp-python-bytecompile (RhBug:53117)
|
|
Panu Matilainen |
2e4024 |
- For *.py files in python library path, use matching python interpreter
|
|
Panu Matilainen |
2e4024 |
version for compiling, this is especially needed for Python 3 which
|
|
Panu Matilainen |
2e4024 |
is very different from Python 2 code. And even if the code compiled
|
|
Panu Matilainen |
2e4024 |
with a wrong version, it would be recompiled at run-time when invoked
|
|
Panu Matilainen |
2e4024 |
with the intended python version, causing verification errors etc.
|
|
Panu Matilainen |
2e4024 |
- For *.py files outside the library path, use "system python" which
|
|
Panu Matilainen |
2e4024 |
might not be always correct but we dont really know any better.
|
|
Panu Matilainen |
2e4024 |
- Patch from David Malcolm
|
|
Panu Matilainen |
2e4024 |
|
|
Panu Matilainen |
2e4024 |
diff --git a/scripts/brp-python-bytecompile b/scripts/brp-python-bytecompile
|
|
Panu Matilainen |
2e4024 |
index 6405c5e..1faa6db 100644
|
|
Panu Matilainen |
2e4024 |
--- a/scripts/brp-python-bytecompile
|
|
Panu Matilainen |
2e4024 |
+++ b/scripts/brp-python-bytecompile
|
|
Panu Matilainen |
2e4024 |
@@ -6,8 +6,8 @@ if [ -z "$RPM_BUILD_ROOT" -o "$RPM_BUILD_ROOT" = "/" ]; then
|
|
Panu Matilainen |
2e4024 |
fi
|
|
Panu Matilainen |
2e4024 |
|
|
Panu Matilainen |
2e4024 |
# If we don't have a python interpreter, avoid changing anything.
|
|
Panu Matilainen |
2e4024 |
-python=${1:-/usr/bin/python}
|
|
Panu Matilainen |
2e4024 |
-if [ ! -x "$python" ]; then
|
|
Panu Matilainen |
2e4024 |
+default_python=${1:-/usr/bin/python}
|
|
Panu Matilainen |
2e4024 |
+if [ ! -x "$default_python" ]; then
|
|
Panu Matilainen |
2e4024 |
exit 0
|
|
Panu Matilainen |
2e4024 |
fi
|
|
Panu Matilainen |
2e4024 |
|
|
Panu Matilainen |
2e4024 |
@@ -19,8 +19,37 @@ if [ -z "$depth" -o "$depth" -le "1" ]; then
|
|
Panu Matilainen |
2e4024 |
exit 0
|
|
Panu Matilainen |
2e4024 |
fi
|
|
Panu Matilainen |
2e4024 |
|
|
Panu Matilainen |
2e4024 |
+# .pyc/.pyo files embed a "magic" value, identifying the ABI version of Python
|
|
Panu Matilainen |
2e4024 |
+# bytecode that they are for.
|
|
Panu Matilainen |
2e4024 |
+#
|
|
Panu Matilainen |
2e4024 |
+# The files below RPM_BUILD_ROOT could be targetting multiple versions of
|
|
Panu Matilainen |
2e4024 |
+# python (e.g. a single build that emits several subpackages e.g. a
|
|
Panu Matilainen |
2e4024 |
+# python26-foo subpackage, a python31-foo subpackage etc)
|
|
Panu Matilainen |
2e4024 |
+#
|
|
Panu Matilainen |
2e4024 |
+# Support this by assuming that below each /usr/lib/python$VERSION/, all
|
|
Panu Matilainen |
2e4024 |
+# .pyc/.pyo files are to be compiled for /usr/bin/python$VERSION.
|
|
Panu Matilainen |
2e4024 |
+#
|
|
Panu Matilainen |
2e4024 |
+# For example, below /usr/lib/python2.6/, we're targetting /usr/bin/python2.6
|
|
Panu Matilainen |
2e4024 |
+# and below /usr/lib/python3.1/, we're targetting /usr/bin/python3.1
|
|
Panu Matilainen |
2e4024 |
+
|
|
Panu Matilainen |
2e4024 |
+for python_libdir in $RPM_BUILD_ROOT/usr/lib*/python*/ ;
|
|
Panu Matilainen |
2e4024 |
+do
|
|
Panu Matilainen |
2e4024 |
+ python_binary=/usr/bin/$(basename $python_libdir)
|
|
Panu Matilainen |
2e4024 |
+ echo "Bytecompiling .py files below $python_libdir using $python_binary"
|
|
Panu Matilainen |
2e4024 |
+
|
|
Panu Matilainen |
2e4024 |
+ # Generate normal (.pyc) byte-compiled files.
|
|
Panu Matilainen |
2e4024 |
+ $python_binary -c 'import compileall; compileall.compile_dir("'"$python_libdir"'", '"$depth"', "/", force=1, quiet=1)'
|
|
Panu Matilainen |
2e4024 |
+
|
|
Panu Matilainen |
2e4024 |
+ # Generate optimized (.pyo) byte-compiled files.
|
|
Panu Matilainen |
2e4024 |
+ $python_binary -O -c 'import compileall; compileall.compile_dir("'"$python_libdir"'", '"$depth"', "/", force=1, quiet=1)'
|
|
Panu Matilainen |
2e4024 |
+done
|
|
Panu Matilainen |
2e4024 |
+
|
|
Panu Matilainen |
2e4024 |
+
|
|
Panu Matilainen |
2e4024 |
+# Handle other locations in the filesystem using the default python
|
|
Panu Matilainen |
2e4024 |
+# implementation:
|
|
Panu Matilainen |
2e4024 |
+
|
|
Panu Matilainen |
2e4024 |
# Generate normal (.pyc) byte-compiled files.
|
|
Panu Matilainen |
2e4024 |
-$python -c 'import compileall, re, sys; sys.exit (not compileall.compile_dir("'"$RPM_BUILD_ROOT"'", '"$depth"', "/", 1, re.compile(r"'"/bin/|/sbin/"'"), quiet=1))'
|
|
Panu Matilainen |
2e4024 |
+$default_python -c 'import compileall, re, sys; sys.exit (not compileall.compile_dir("'"$RPM_BUILD_ROOT"'", '"$depth"', "/", 1, re.compile(r"'"/bin/|/sbin/|/usr/lib.*/python.+/"'"), quiet=1))'
|
|
Panu Matilainen |
2e4024 |
if [ $? != 0 ]; then
|
|
Panu Matilainen |
2e4024 |
# One or more of the files had a syntax error
|
|
Panu Matilainen |
2e4024 |
# XXX TODO: parametrize the exit code, only warn for now
|
|
Panu Matilainen |
2e4024 |
@@ -28,4 +57,4 @@ if [ $? != 0 ]; then
|
|
Panu Matilainen |
2e4024 |
fi
|
|
Panu Matilainen |
2e4024 |
|
|
Panu Matilainen |
2e4024 |
# Generate optimized (.pyo) byte-compiled files.
|
|
Panu Matilainen |
2e4024 |
-$python -O -c 'import compileall, re; compileall.compile_dir("'"$RPM_BUILD_ROOT"'", '"$depth"', "/", 1, re.compile(r"'"/bin/|/sbin/"'"))' > /dev/null
|
|
Panu Matilainen |
2e4024 |
+$default_python -O -c 'import compileall, re; compileall.compile_dir("'"$RPM_BUILD_ROOT"'", '"$depth"', "/", 1, re.compile(r"'"/bin/|/sbin/|/usr/lib.*/python.+/"'"))' > /dev/null
|