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.6 by eulisse, Mon Apr 24 22:58:37 2006 UTC vs.
Revision 1.78 by eulisse, Wed Nov 2 14:15:50 2011 UTC

# Line 1 | Line 1
1 < ### RPM external python 2.4.2
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 < Requires: zlib expat openssl bz2lib
7 < # FIXME: readline, ncurses, crypt, various [ng]dbm, db-*, db[1-3],
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 >
11 > %if "%online" != "true"
12 > Requires: zlib openssl sqlite
13 > %endif
14 >
15 > # FIXME: readline, crypt
16   # FIXME: gmp, panel, tk/tcl, x11
17  
18 < Source0: http://www.python.org/ftp/%n/%v/Python-%v.tgz
19 < #Patch0: python-osx
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  
22   %prep
23 < %setup -n Python-%v
24 < perl -p -i -e "s|#!.*/usr/local/bin/python|#!/usr/bin/env python|" Lib/cgi.py
23 > %setup -n Python-%realversion
24 > find . -type f | while read f; do
25 >  if head -n1 $f | grep -q /usr/local; then
26 >    perl -p -i -e "s|#!.*/usr/local/bin/python|#!/usr/bin/env python|" $f
27 >  else :; fi
28 > done
29  
30 < %ifos darwin
31 < sed 's|@PREFIX@|%i|g' < %_sourcedir/python-osx | patch -p1
32 < %endif
30 > case %cmsplatf in
31 >  osx*)
32 >        sed 's|@PREFIX@|%i|g' < %_sourcedir/python-osx | patch -p1
33 >  ;;
34 > esac
35 > %patch0 -p1
36 > %patch1 -p1
37  
38   %build
39   # Python is awkward about passing other include or library directories
# Line 29 | Line 47 | perl -p -i -e "s|#!.*/usr/local/bin/pyth
47   # see above for the commented-out list of packages that could be
48   # linked specifically, or could be built by ourselves, depending on
49   # whether we like to pick up system libraries or want total control.
50 < mkdir -p %i/include %i/lib
51 < dirs="$ZLIB_ROOT $EXPAT_ROOT $OPENSSL_ROOT $BZ2LIB_ROOT $NCURSES_ROOT"
50 > #mkdir -p %i/include %i/lib
51 > mkdir -p %i/include %i/lib %i/bin
52 >
53 > %if "%online" != "true"
54 > %define extradirs $ZLIB_ROOT $OPENSSL_ROOT $SQLITE_ROOT
55 > %else
56 > %define extradirs %{nil}
57 > %endif
58 >
59 > dirs="$EXPAT_ROOT $BZ2LIB_ROOT $NCURSES_ROOT $DB4_ROOT $GDBM_ROOT %{extradirs}"
60 >
61 > # We need to export it because setup.py now uses it to determine the actual
62 > # location of DB4, this was needed to avoid having it picked up from the system.
63 > export DB4_ROOT
64 >
65 > echo $dirs
66   for d in $dirs; do
67    for f in $d/include/*; do
68 <    [ -f $f ] || continue
68 >    [ -e $f ] || continue
69      rm -f %i/include/$(basename $f)
70      ln -s $f %i/include
71    done
72    for f in $d/lib/*; do
73 <    [ -f $f ] || continue
73 >    [ -e $f ] || continue
74      rm -f %i/lib/$(basename $f)
75      ln -s $f %i/lib
76    done
77   done
78  
79 < ./configure --prefix=%i --enable-shared --without-tkinter --disable-tkinter --without-readline
79 > additionalConfigureOptions=""
80 > case %cmsplatf in
81 >    osx105* )
82 >    additionalConfigureOptions="--disable-readline"
83 >    ;;
84 > esac
85 >
86 > ./configure --prefix=%i $additionalConfigureOptions --enable-shared \
87 >            --without-tkinter --disable-tkinter
88 >
89 > # The following is a kludge around the fact that the /usr/lib/libreadline.so
90 > # symlink (for 32-bit lib) is missing on the 64bit machines
91 > case %cmsplatf in
92 >  slc4_ia32* )
93 >    mkdir -p %{i}/lib
94 >    ln -s /usr/lib/libreadline.so.4.3 %{i}/lib/libreadline.so
95 >  ;;
96 > esac
97   make %makeprocesses
98  
99   %install
100 + # We need to export it because setup.py now uses it to determine the actual
101 + # location of DB4, this was needed to avoid having it picked up from the system.
102 + export DB4_ROOT
103   make install
104 < if [ $(uname) = Darwin ]; then
105 <  # make install prefix=%i
106 <  # (cd Misc; /bin/rm -rf RPM)
107 <  # mkdir -p %i/share/doc/%n
108 <  # cp -R Demo Doc %i/share/doc/%n
109 <  # cp -R Misc Tools %i/lib/python2.3
110 <  cc -dynamiclib -all_load -single_module \
104 > %define pythonv %(echo %realversion | cut -d. -f 1,2)
105 >
106 > case %cmsplatf in
107 >  osx*)
108 >   make install prefix=%i
109 >   (cd Misc; /bin/rm -rf RPM)
110 >   mkdir -p %i/share/doc/%n
111 >   cp -R Demo Doc %i/share/doc/%n
112 >   cp -R Misc Tools %i/lib/python%{pythonv}
113 >   gcc -dynamiclib -all_load -single_module \
114      -framework System -framework CoreServices -framework Foundation \
115 <    %i/lib/python2.3/config/libpython2.3.a \
116 <    -o %i/lib/python2.3/config/libpython2.3.dylib \
117 <    -install_name %i/lib/python2.3/config/libpython2.3.dylib \
118 <    -current_version 2.3 -compatibility_version 2.3 -ldl
119 <  ln -s libpython2.3.dylib %i/lib/python2.3/config/libpython23.dylib # for boost
120 <  # (cd %i/lib/python2.3/config; mv Makefile Makefile.orig;
121 <  #  sed 's|-fno-common||g' < Makefile.orig > Makefile; /bin/rm -f Makefile.orig)
122 < fi
115 >    %i/lib/python%{pythonv}/config/libpython%{pythonv}.a \
116 >    -undefined dynamic_lookup \
117 >    -o %i/lib/python%{pythonv}/config/libpython%{pythonv}.dylib \
118 >    -install_name %i/lib/python%{pythonv}/config/libpython%{pythonv}.dylib \
119 >    -current_version %{pythonv} -compatibility_version %{pythonv} -ldl
120 >   (cd %i/lib/python%{pythonv}/config
121 >    perl -p -i -e 's|-fno-common||g' Makefile)
122 >
123 >   find %i/lib/python%{pythonv}/config -name 'libpython*' -exec mv -f {} %i/lib \;
124 >  ;;
125 > esac
126 >
127 > perl -p -i -e "s|^#!.*python|#!/usr/bin/env python|" %{i}/bin/idle \
128 >                    %{i}/bin/pydoc \
129 >                    %{i}/bin/python-config \
130 >                    %{i}/bin/2to3 \
131 >                    %{i}/bin/python2.6-config \
132 >                    %{i}/bin/smtpd.py \
133 >                    %{i}/lib/python2.6/bsddb/dbshelve.py \
134 >                    %{i}/lib/python2.6/test/test_bz2.py \
135 >                    %{i}/lib/python2.6/test/test_largefile.py \
136 >                    %{i}/lib/python2.6/test/test_optparse.py
137 >
138 > find %{i}/lib -maxdepth 1 -mindepth 1 ! -name '*python*' -exec rm {} \;
139 > find %{i}/include -maxdepth 1 -mindepth 1 ! -name '*python*' -exec rm {} \;
140 >
141 > # remove executable permission anything which is *.py script,
142 > # is executable, but does not start with she-bang so not valid
143 > # executable; this avoids problems with rpm 4.8+ find-requires
144 > find %i -name '*.py' -perm +0111 | while read f; do
145 >  if head -n1 $f | grep -q '"'; then chmod -x $f; else :; fi
146 > done
147 >
148 > # remove tkinter that brings dependency on libtk:
149 > find %{i}/lib -type f -name "_tkinter.so" -exec rm {} \;
150 >
151 > # Remove documentation, examples and test files.
152 > %define drop_files %i/share %{i}/lib/python%{pythonv}/test
153 >
154 > # Remove .pyo files
155 > find %i -name '*.pyo' -exec rm {} \;
156 >
157 > # Generate dependencies-setup.{sh,csh} so init.{sh,csh} picks full environment.
158 > mkdir -p %i/etc/profile.d
159 > : > %i/etc/profile.d/dependencies-setup.sh
160 > : > %i/etc/profile.d/dependencies-setup.csh
161 > for tool in $(echo %{requiredtools} | sed -e's|\s+| |;s|^\s+||'); do
162 >  root=$(echo $tool | tr a-z- A-Z_)_ROOT; eval r=\$$root
163 >  if [ X"$r" != X ] && [ -r "$r/etc/profile.d/init.sh" ]; then
164 >    echo "test X\$$root != X || . $r/etc/profile.d/init.sh" >> %i/etc/profile.d/dependencies-setup.sh
165 >    echo "test X\$$root != X || source $r/etc/profile.d/init.csh" >> %i/etc/profile.d/dependencies-setup.csh
166 >  fi
167 > done
168 >
169 > %post
170 > %{relocateConfig}lib/python2.6/config/Makefile
171 > %{relocateConfig}etc/profile.d/dependencies-setup.*sh

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines