ViewVC Help
View File | Revision Log | Show Annotations | Root Listing
root/cvsroot/COMP/CMSDIST/python.spec
(Generate patch)

Comparing COMP/CMSDIST/python.spec (file contents):
Revision 1.58 by elmer, Sat Nov 14 00:04:28 2009 UTC vs.
Revision 1.76 by eulisse, Wed Aug 31 13:07:51 2011 UTC

# Line 1 | Line 1
1   ### RPM external python 2.6.4
2   ## INITENV +PATH PATH %i/bin
3   ## INITENV +PATH LD_LIBRARY_PATH %i/lib
4 + ## INITENV SETV PYTHON_LIB_SITE_PACKAGES lib/python%{python_major_version}/site-packages
5   # OS X patches and build fudging stolen from fink
6 < %define closingbrace )
7 < %define online %(case %cmsplatf in *onl_*_*%closingbrace echo true;; *%closingbrace echo false;; esac)
6 > %{expand:%%define python_major_version %(echo %realversion | cut -d. -f1,2)}
7 > %define online %(case %cmsplatf in (*onl_*_*) echo true;; (*) echo false;; esac)
8  
9   Requires: expat bz2lib db4 gdbm
10  
# Line 15 | Line 16 | Requires: zlib openssl sqlite
16   # FIXME: gmp, panel, tk/tcl, x11
17  
18   Source0: http://www.python.org/ftp/%n/%realversion/Python-%realversion.tgz
19 < Patch0: python-Include-pyport.h
19 < Patch1: python-Lib-plat-mac-applesingle.py
20 < Patch2: python-Lib-site.py
21 < Patch3: python-Mac-OSX-Makefile
22 < Patch4: python-Makefile.pre.in
23 < Patch5: python-configure
24 < Patch6: python-setup.py
25 <
19 > Patch0: python-2.6.4-dont-detect-dbm
20  
21   %prep
22   %setup -n Python-%realversion
23 < #%patch0
24 < #%patch1
25 < #%patch2
26 < #%patch3
27 < #%patch4
34 < #%patch5
35 < #%patch6
36 < perl -p -i -e "s|#!.*/usr/local/bin/python|#!/usr/bin/env python|" Lib/cgi.py
23 > find . -type f | while read f; do
24 >  if head -n1 $f | grep -q /usr/local; then
25 >    perl -p -i -e "s|#!.*/usr/local/bin/python|#!/usr/bin/env python|" $f
26 >  else :; fi
27 > done
28  
29 < %ifos darwin
30 < sed 's|@PREFIX@|%i|g' < %_sourcedir/python-osx | patch -p1
31 < %endif
29 > case %cmsplatf in
30 >  osx*)
31 >        sed 's|@PREFIX@|%i|g' < %_sourcedir/python-osx | patch -p1
32 >  ;;
33 > esac
34 > %patch0 -p1
35  
36   %build
37   # Python is awkward about passing other include or library directories
# Line 62 | Line 56 | mkdir -p %i/include %i/lib %i/bin
56  
57   dirs="$EXPAT_ROOT $BZ2LIB_ROOT $NCURSES_ROOT $DB4_ROOT $GDBM_ROOT %{extradirs}"
58  
59 + # We need to export it because setup.py now uses it to determine the actual
60 + # location of DB4, this was needed to avoid having it picked up from the system.
61 + export DB4_ROOT
62 +
63   echo $dirs
64   for d in $dirs; do
65    for f in $d/include/*; do
# Line 97 | Line 95 | esac
95   make %makeprocesses
96  
97   %install
98 + # We need to export it because setup.py now uses it to determine the actual
99 + # location of DB4, this was needed to avoid having it picked up from the system.
100 + export DB4_ROOT
101   make install
102   %define pythonv %(echo %realversion | cut -d. -f 1,2)
103  
# Line 117 | Line 118 | case %cmsplatf in
118     (cd %i/lib/python%{pythonv}/config
119      perl -p -i -e 's|-fno-common||g' Makefile)
120  
121 <   find %i/lib/python%{pythonv}/config -name 'libpython*' -exec mv {} %i/lib \;
121 >   find %i/lib/python%{pythonv}/config -name 'libpython*' -exec mv -f {} %i/lib \;
122    ;;
123   esac
124  
# Line 131 | Line 132 | perl -p -i -e "s|^#!.*python|#!/usr/bin/
132                      %{i}/lib/python2.6/test/test_bz2.py \
133                      %{i}/lib/python2.6/test/test_largefile.py \
134                      %{i}/lib/python2.6/test/test_optparse.py
134 rm  `find %{i}/lib -maxdepth 1 -mindepth 1 ! -name '*python*'`
135 rm  `find %{i}/include -maxdepth 1 -mindepth 1 ! -name '*python*'`
135  
136 < %if "%online" == "true"
136 > find %{i}/lib -maxdepth 1 -mindepth 1 ! -name '*python*' -exec rm {} \;
137 > find %{i}/include -maxdepth 1 -mindepth 1 ! -name '*python*' -exec rm {} \;
138 >
139 > # remove executable permission anything which is *.py script,
140 > # is executable, but does not start with she-bang so not valid
141 > # executable; this avoids problems with rpm 4.8+ find-requires
142 > find %i -name '*.py' -perm +0111 | while read f; do
143 >  if head -n1 $f | grep -q '"'; then chmod -x $f; else :; fi
144 > done
145 >
146   # remove tkinter that brings dependency on libtk:
147   find %{i}/lib -type f -name "_tkinter.so" -exec rm {} \;
140 %endif
148  
149 < # SCRAM ToolBox toolfile
150 < mkdir -p %i/etc/scram.d
151 < cat << \EOF_TOOLFILE >%i/etc/scram.d/%n
152 < <doc type=BuildSystem::ToolDoc version=1.0>
153 < <Tool name=%n version=%v>
154 < <lib name=python2.6>
155 < <Client>
156 < <Environment name=PYTHON_BASE default="%i"></Environment>
157 < <Environment name=LIBDIR default="$PYTHON_BASE/lib"></Environment>
158 < <Environment name=INCLUDE default="$PYTHON_BASE/include/python2.6"></Environment>
159 < <Environment name=PYTHON_COMPILE default="$PYTHON_BASE/lib/python2.6/compileall.py"></Environment>
160 < </Client>
161 < <use name=sockets>
162 < <Runtime name=PATH value="$PYTHON_BASE/bin" type=path>
163 < </Tool>
164 < EOF_TOOLFILE
165 <
166 < # Makes sure that executables start with /usr/bin/env perl and not with comments.
167 < find %i -type f -perm -555 -name '*.py' -exec perl -p -i -e 'if ($. == 1) {s|^"""|#/usr/bin/env python\n"""|}' {} \;
168 < find %i -type f -perm -555 -name '*.py' -exec perl -p -i -e 'if ($. == 1) {s|^\'\'\'|#/usr/bin/env python\n\'\'\'|}' {} \;
162 < find %i -type f -perm -555 -name '*.py' -exec perl -p -i -e 'if ($. == 1) {s|/usr/local/bin/python|/usr/bin/env python|}' {} \;
163 < rm -f %i/share/doc/python/Demo/rpc/test
149 > # Remove documentation and examples.
150 > rm -rf %i/share
151 >
152 > # No need for test files
153 > rm -rf %{i}/lib/python%{pythonv}/test
154 >
155 > # Remove .pyo files
156 > find %i -name '*.pyo' -exec rm {} \;
157 >
158 > # Generate dependencies-setup.{sh,csh} so init.{sh,csh} picks full environment.
159 > mkdir -p %i/etc/profile.d
160 > : > %i/etc/profile.d/dependencies-setup.sh
161 > : > %i/etc/profile.d/dependencies-setup.csh
162 > for tool in $(echo %{requiredtools} | sed -e's|\s+| |;s|^\s+||'); do
163 >  root=$(echo $tool | tr a-z- A-Z_)_ROOT; eval r=\$$root
164 >  if [ X"$r" != X ] && [ -r "$r/etc/profile.d/init.sh" ]; then
165 >    echo "test X\$$root != X || . $r/etc/profile.d/init.sh" >> %i/etc/profile.d/dependencies-setup.sh
166 >    echo "test X\$$root != X || source $r/etc/profile.d/init.csh" >> %i/etc/profile.d/dependencies-setup.csh
167 >  fi
168 > done
169  
170   %post
171 < find $RPM_INSTALL_PREFIX/%pkgrel/lib -type l | xargs ls -la | sed -e "s|.*[ ]\(/.*\) -> \(.*\)| \2 \1|;s|[ ]/[^ ]*/external| $RPM_INSTALL_PREFIX/%cmsplatf/external|g" | xargs -n2 ln -sf
172 < %{relocateConfig}etc/scram.d/%n
171 > %{relocateConfig}lib/python2.6/config/Makefile
172 > %{relocateConfig}etc/profile.d/dependencies-setup.*sh

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines