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.64 by elmer, Mon Apr 19 16:13:00 2010 UTC vs.
Revision 1.84 by lat, Mon Mar 12 09:46:28 2012 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-2.6.4-dont-detect-dbm
20 + Patch1: python-2.6.4-fix-macosx-relocation
21 + Patch2: python-2.6.4-macosx-64bit
22  
23   %prep
24   %setup -n Python-%realversion
25 < perl -p -i -e "s|#!.*/usr/local/bin/python|#!/usr/bin/env python|" Lib/cgi.py
25 > find . -type f | while read f; do
26 >  if head -n1 $f | grep -q /usr/local; then
27 >    perl -p -i -e "s|#!.*/usr/local/bin/python|#!/usr/bin/env python|" $f
28 >  else :; fi
29 > done
30  
31 < %ifos darwin
32 < sed 's|@PREFIX@|%i|g' < %_sourcedir/python-osx | patch -p1
33 < %endif
31 > case %cmsplatf in
32 >  osx*)
33 >        sed 's|@PREFIX@|%i|g' < %_sourcedir/python-osx | patch -p1
34 >  ;;
35 > esac
36 > %patch0 -p1
37 > %patch1 -p1
38 > %patch2 -p1
39  
40   %build
41   # Python is awkward about passing other include or library directories
# Line 47 | Line 60 | mkdir -p %i/include %i/lib %i/bin
60  
61   dirs="$EXPAT_ROOT $BZ2LIB_ROOT $NCURSES_ROOT $DB4_ROOT $GDBM_ROOT %{extradirs}"
62  
63 + # We need to export it because setup.py now uses it to determine the actual
64 + # location of DB4, this was needed to avoid having it picked up from the system.
65 + export DB4_ROOT
66 +
67 + # Python's configure parses LDFLAGS and CPPFLAGS to look for aditional library and include directories
68   echo $dirs
69 + LDFLAGS=""
70 + CPPFLAGS=""
71   for d in $dirs; do
72 <  for f in $d/include/*; do
73 <    [ -e $f ] || continue
54 <    rm -f %i/include/$(basename $f)
55 <    ln -s $f %i/include
56 <  done
57 <  for f in $d/lib/*; do
58 <    [ -e $f ] || continue
59 <    rm -f %i/lib/$(basename $f)
60 <    ln -s $f %i/lib
61 <  done
72 >  LDFLAGS="$LDFLAGS -L $d/lib"
73 >  CPPFLAGS="$CPPFLAGS -I $d/include"
74   done
75 + export LDFLAGS
76 + export CPPFLAGS
77  
78   additionalConfigureOptions=""
79   case %cmsplatf in
# Line 82 | Line 96 | esac
96   make %makeprocesses
97  
98   %install
99 + # We need to export it because setup.py now uses it to determine the actual
100 + # location of DB4, this was needed to avoid having it picked up from the system.
101 + export DB4_ROOT
102   make install
103   %define pythonv %(echo %realversion | cut -d. -f 1,2)
104  
# Line 116 | Line 133 | perl -p -i -e "s|^#!.*python|#!/usr/bin/
133                      %{i}/lib/python2.6/test/test_bz2.py \
134                      %{i}/lib/python2.6/test/test_largefile.py \
135                      %{i}/lib/python2.6/test/test_optparse.py
136 < rm  `find %{i}/lib -maxdepth 1 -mindepth 1 ! -name '*python*'`
137 < rm  `find %{i}/include -maxdepth 1 -mindepth 1 ! -name '*python*'`
136 >
137 > find %{i}/lib -maxdepth 1 -mindepth 1 ! -name '*python*' -exec rm {} \;
138 > find %{i}/include -maxdepth 1 -mindepth 1 ! -name '*python*' -exec rm {} \;
139 >
140 > # remove executable permission anything which is *.py script,
141 > # is executable, but does not start with she-bang so not valid
142 > # executable; this avoids problems with rpm 4.8+ find-requires
143 > find %i -name '*.py' -perm +0111 | while read f; do
144 >  if head -n1 $f | grep -q '"'; then chmod -x $f; else :; fi
145 > done
146  
147   # remove tkinter that brings dependency on libtk:
148   find %{i}/lib -type f -name "_tkinter.so" -exec rm {} \;
149  
150 < # SCRAM ToolBox toolfile
151 < mkdir -p %i/etc/scram.d
127 < cat << \EOF_TOOLFILE >%i/etc/scram.d/%n
128 < <doc type=BuildSystem::ToolDoc version=1.0>
129 < <Tool name=%n version=%v>
130 < <lib name=python2.6>
131 < <Client>
132 < <Environment name=PYTHON_BASE default="%i"></Environment>
133 < <Environment name=LIBDIR default="$PYTHON_BASE/lib"></Environment>
134 < <Environment name=INCLUDE default="$PYTHON_BASE/include/python2.6"></Environment>
135 < <Environment name=PYTHON_COMPILE default="$PYTHON_BASE/lib/python2.6/compileall.py"></Environment>
136 < </Client>
137 < <use name=sockets>
138 < <Runtime name=PATH value="$PYTHON_BASE/bin" type=path>
139 < </Tool>
140 < EOF_TOOLFILE
141 <
142 < # Makes sure that executables start with /usr/bin/env perl and not with comments.
143 < find %i -type f -perm -555 -name '*.py' -exec perl -p -i -e 'if ($. == 1) {s|^"""|#/usr/bin/env python\n"""|}' {} \;
144 < find %i -type f -perm -555 -name '*.py' -exec perl -p -i -e 'if ($. == 1) {s|^\'\'\'|#/usr/bin/env python\n\'\'\'|}' {} \;
145 < find %i -type f -perm -555 -name '*.py' -exec perl -p -i -e 'if ($. == 1) {s|/usr/local/bin/python|/usr/bin/env python|}' {} \;
146 < rm -f %i/share/doc/python/Demo/rpc/test
150 > # Remove documentation, examples and test files.
151 > %define drop_files %i/share %{i}/lib/python%{pythonv}/test
152  
153 < # Setups dependencies environment
154 < rm -rf %i/etc/profile.d
153 > # Remove .pyo files
154 > find %i -name '*.pyo' -exec rm {} \;
155 >
156 > # Generate dependencies-setup.{sh,csh} so init.{sh,csh} picks full environment.
157   mkdir -p %i/etc/profile.d
158 < for x in %pkgreqs; do
159 <  case $x in /* ) continue ;; esac
160 <  p=%{instroot}/%{cmsplatf}/$(echo $x | sed 's/\([^+]*\)+\(.*\)+\([A-Z0-9].*\)/\1 \2 \3/' | tr ' ' '/')
161 <  echo ". $p/etc/profile.d/init.sh" >> %i/etc/profile.d/dependencies-setup.sh
162 <  echo "source $p/etc/profile.d/init.csh" >> %i/etc/profile.d/dependencies-setup.csh
158 > : > %i/etc/profile.d/dependencies-setup.sh
159 > : > %i/etc/profile.d/dependencies-setup.csh
160 > for tool in $(echo %{requiredtools} | sed -e's|\s+| |;s|^\s+||'); do
161 >  root=$(echo $tool | tr a-z- A-Z_)_ROOT; eval r=\$$root
162 >  if [ X"$r" != X ] && [ -r "$r/etc/profile.d/init.sh" ]; then
163 >    echo "test X\$$root != X || . $r/etc/profile.d/init.sh" >> %i/etc/profile.d/dependencies-setup.sh
164 >    echo "test X\$$root != X || source $r/etc/profile.d/init.csh" >> %i/etc/profile.d/dependencies-setup.csh
165 >  fi
166   done
167  
168   %post
159 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
160 %{relocateConfig}etc/scram.d/%n
169   %{relocateConfig}lib/python2.6/config/Makefile
170 <
163 < # Relocation for dependencies
164 < %{relocateConfig}etc/profile.d/dependencies-setup.sh
165 < %{relocateConfig}etc/profile.d/dependencies-setup.csh
166 <
170 > %{relocateConfig}etc/profile.d/dependencies-setup.*sh

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines