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.41 by ratnik, Tue May 13 17:29:46 2008 UTC vs.
Revision 1.96 by fwyzard, Fri Aug 31 14:31:11 2012 UTC

# Line 1 | Line 1
1 < ### RPM external python 2.4.2-CMS19
1 > ### RPM external python 2.7.3
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 + ## INITENV SETV PYTHONHASHSEED random
6   # OS X patches and build fudging stolen from fink
7 + %{expand:%%define python_major_version %(echo %realversion | cut -d. -f1,2)}
8 + %define online %(case %cmsplatf in (*onl_*_*) echo true;; (*) echo false;; esac)
9  
10 < Requires: expat bz2lib db4 gdbm
10 > Requires: expat bz2lib db4 gdbm openssl
11  
12 < %if "%cmsplatf" != "slc4onl_ia32_gcc346"
13 < Requires: zlib openssl
12 > %if "%online" != "true"
13 > Requires: zlib sqlite
14   %endif
15  
16   # FIXME: readline, crypt
17   # FIXME: gmp, panel, tk/tcl, x11
18  
19   Source0: http://www.python.org/ftp/%n/%realversion/Python-%realversion.tgz
20 < Patch0: python-Include-pyport.h
21 < Patch1: python-Lib-plat-mac-applesingle.py
22 < Patch2: python-Lib-site.py
19 < Patch3: python-Mac-OSX-Makefile
20 < Patch4: python-Makefile.pre.in
21 < Patch5: python-configure
22 < Patch6: python-setup.py
23 <
20 > Patch1: python-fix-macosx-relocation
21 > Patch2: python-2.7.3-fix-pyport
22 > Patch3: python-2.7.3-ssl-fragment
23  
24   %prep
25   %setup -n Python-%realversion
26 < #%patch0
27 < #%patch1
28 < #%patch2
29 < #%patch3
30 < #%patch4
31 < #%patch5
33 < #%patch6
34 < perl -p -i -e "s|#!.*/usr/local/bin/python|#!/usr/bin/env python|" Lib/cgi.py
26 > find . -type f | while read f; do
27 >  if head -n1 $f | grep -q /usr/local; then
28 >    perl -p -i -e "s|#!.*/usr/local/bin/python|#!/usr/bin/env python|" $f
29 >  else :; fi
30 > done
31 > %patch1 -p0
32  
33   %ifos darwin
34 < sed 's|@PREFIX@|%i|g' < %_sourcedir/python-osx | patch -p1
34 > %patch2 -p1
35   %endif
36  
37 + %patch3 -p1
38 +
39   %build
40   # Python is awkward about passing other include or library directories
41   # to it.  Basically there is no way to pass anything from configure to
# Line 49 | Line 48 | perl -p -i -e "s|#!.*/usr/local/bin/pyth
48   # see above for the commented-out list of packages that could be
49   # linked specifically, or could be built by ourselves, depending on
50   # whether we like to pick up system libraries or want total control.
51 < mkdir -p %i/include %i/lib
51 > #mkdir -p %i/include %i/lib
52 > mkdir -p %i/include %i/lib %i/bin
53  
54 < %if "%cmsplatf" != "slc4onl_ia32_gcc346"
55 < %define extradirs $ZLIB_ROOT $OPENSSL_ROOT
54 > %if "%online" != "true"
55 > %define extradirs $ZLIB_ROOT $SQLITE_ROOT
56   %else
57   %define extradirs %{nil}
58   %endif
59  
60   dirs="$EXPAT_ROOT $BZ2LIB_ROOT $NCURSES_ROOT $DB4_ROOT $GDBM_ROOT %{extradirs}"
61  
62 + # We need to export it because setup.py now uses it to determine the actual
63 + # location of DB4, this was needed to avoid having it picked up from the system.
64 + export DB4_ROOT
65 +
66 + # Python's configure parses LDFLAGS and CPPFLAGS to look for aditional library and include directories
67   echo $dirs
68 + LDFLAGS=""
69 + CPPFLAGS=""
70   for d in $dirs; do
71 <  for f in $d/include/*; do
72 <    [ -e $f ] || continue
66 <    rm -f %i/include/$(basename $f)
67 <    ln -s $f %i/include
68 <  done
69 <  for f in $d/lib/*; do
70 <    [ -e $f ] || continue
71 <    rm -f %i/lib/$(basename $f)
72 <    ln -s $f %i/lib
73 <  done
71 >  LDFLAGS="$LDFLAGS -L $d/lib"
72 >  CPPFLAGS="$CPPFLAGS -I $d/include"
73   done
74 + export LDFLAGS
75 + export CPPFLAGS
76  
77   additionalConfigureOptions=""
78   case %cmsplatf in
# Line 80 | Line 81 | case %cmsplatf in
81      ;;
82   esac
83  
84 < ./configure --prefix=%i $additionalConfigureOptions --enable-shared \
85 <            --without-tkinter --disable-tkinter
84 > # Bugfix for dbm package. Use ndbm.h header and gdbm compatibility layer.
85 > sed -ibak "s/ndbm_libs = \[\]/ndbm_libs = ['gdbm', 'gdbm_compat']/" setup.py
86 >
87 > ./configure --prefix=%i $additionalConfigureOptions --enable-shared
88 >
89 > # Modify pyconfig.h to match macros from GLIBC features.h on Linux machines.
90 > # _POSIX_C_SOURCE and _XOPEN_SOURCE macros are not identical anymore
91 > # starting GLIBC 2.10.1. Python.h is not included before standard headers
92 > # in CMSSW and pyconfig.h is not smart enough to detect already defined
93 > # macros on Linux. The following problem does not exists on BSD machines as
94 > # cdefs.h does not define these macros.
95 > case %cmsplatf in
96 >  slc6*)
97 >    rm -f cms_configtest.cpp
98 >    cat <<CMS_EOF > cms_configtest.cpp
99 > #include <features.h>
100 >
101 > int main() {
102 >  return 0;
103 > }
104 > CMS_EOF
105 >
106 >    FEATURES=$(g++ -dM -E -DGNU_GCC=1 -D_GNU_SOURCE=1 -D_DARWIN_SOURCE=1 cms_configtest.cpp \
107 >      | grep -E '_POSIX_C_SOURCE |_XOPEN_SOURCE ')
108 >    rm -f cms_configtest.cpp a.out
109 >
110 >    POSIX_C_SOURCE=$(echo "${FEATURES}" | grep _POSIX_C_SOURCE | cut -d ' ' -f 3)
111 >    XOPEN_SOURCE=$(echo "${FEATURES}" | grep _XOPEN_SOURCE | cut -d ' ' -f 3)
112 >
113 >    sed -ibak "s/\(#define _POSIX_C_SOURCE \)\(.*\)/\1${POSIX_C_SOURCE}/g" pyconfig.h
114 >    sed -ibak "s/\(#define _XOPEN_SOURCE \)\(.*\)/\1${XOPEN_SOURCE}/g" pyconfig.h
115 >  ;;
116 > esac
117  
118   # The following is a kludge around the fact that the /usr/lib/libreadline.so
119   # symlink (for 32-bit lib) is missing on the 64bit machines
120 < %if "%cmsplatf" == "slc4_ia32_gcc345"
121 <  mkdir -p %{i}/lib
122 <  ln -s /usr/lib/libreadline.so.4.3 %{i}/lib/libreadline.so
123 < %endif
124 < %if "%cmsplatf" == "slc4_ia32_gcc412"
125 <  mkdir -p %{i}/lib
126 <  ln -s /usr/lib/libreadline.so.4.3 %{i}/lib/libreadline.so
95 < %endif
120 > case %cmsplatf in
121 >  slc4_ia32* )
122 >    mkdir -p %{i}/lib
123 >    ln -s /usr/lib/libreadline.so.4.3 %{i}/lib/libreadline.so
124 >  ;;
125 > esac
126 >
127   make %makeprocesses
128  
129   %install
130 + # We need to export it because setup.py now uses it to determine the actual
131 + # location of DB4, this was needed to avoid having it picked up from the system.
132 + export DB4_ROOT
133   make install
134   %define pythonv %(echo %realversion | cut -d. -f 1,2)
135  
136 < #if [ $(uname) = Darwin ]; then
137 <  # make install prefix=%i
138 <  # (cd Misc; /bin/rm -rf RPM)
139 <  # mkdir -p %i/share/doc/%n
140 <  # cp -R Demo Doc %i/share/doc/%n
141 <  # cp -R Misc Tools %i/lib/python%{pythonv}
142 < #  gcc -dynamiclib -all_load -single_module \
143 < #    -framework System -framework CoreServices -framework Foundation \
144 < #    %i/lib/python%{pythonv}/config/libpython%{pythonv}.a \
145 < #    -undefined dynamic_lookup \
146 < #    -o %i/lib/python%{pythonv}/config/libpython%{pythonv}.dylib \
147 < #    -install_name %i/lib/python%{pythonv}/config/libpython%{pythonv}.dylib \
148 < #    -current_version %{pythonv} -compatibility_version %{pythonv} -ldl
149 < #  ln -s libpython%{pythonv}.dylib %i/lib/python%{pythonv}/config/libpython%{pythonv}.dylib # for boost
150 <  # (cd %i/lib/python%{pythonv}/config; mv Makefile Makefile.orig;
151 <  #  sed 's|-fno-common||g' < Makefile.orig > Makefile; /bin/rm -f Makefile.orig)
118 < #fi
119 <
120 < perl -p -i -e "s|^#!.*python|#!/usr/bin/env python|" %{i}/bin/idle \
121 <                    %{i}/bin/pydoc \
122 <                    %{i}/bin/smtpd.py \
123 <                    %{i}/lib/python2.4/bsddb/dbshelve.py \
124 <                    %{i}/lib/python2.4/test/test_bz2.py \
125 <                    %{i}/lib/python2.4/test/test_largefile.py \
126 <                    %{i}/lib/python2.4/test/test_optparse.py
127 < # boost.spec rfio.spec
128 < #
129 < #
130 < rm  `find %{i}/lib -maxdepth 1 -mindepth 1 ! -name '*python*'`
131 < rm  `find %{i}/include -maxdepth 1 -mindepth 1 ! -name '*python*'`
136 > case %cmsplatf in
137 >  osx*)
138 >   make install prefix=%i
139 >   (cd Misc; /bin/rm -rf RPM)
140 >   mkdir -p %i/share/doc/%n
141 >   cp -R Demo Doc %i/share/doc/%n
142 >   cp -R Misc Tools %i/lib/python%{pythonv}
143 >   gcc -dynamiclib -all_load -single_module \
144 >    -framework System -framework CoreServices -framework Foundation \
145 >    %i/lib/python%{pythonv}/config/libpython%{pythonv}.a \
146 >    -undefined dynamic_lookup \
147 >    -o %i/lib/python%{pythonv}/config/libpython%{pythonv}.dylib \
148 >    -install_name %i/lib/python%{pythonv}/config/libpython%{pythonv}.dylib \
149 >    -current_version %{pythonv} -compatibility_version %{pythonv} -ldl
150 >   (cd %i/lib/python%{pythonv}/config
151 >    perl -p -i -e 's|-fno-common||g' Makefile)
152  
153 < # SCRAM ToolBox toolfile
154 < mkdir -p %i/etc/scram.d
155 < cat << \EOF_TOOLFILE >%i/etc/scram.d/%n
156 < <doc type=BuildSystem::ToolDoc version=1.0>
157 < <Tool name=%n version=%v>
158 < <lib name=python2.4>
159 < <Client>
160 < <Environment name=PYTHON_BASE default="%i"></Environment>
161 < <Environment name=LIBDIR default="$PYTHON_BASE/lib"></Environment>
162 < <Environment name=INCLUDE default="$PYTHON_BASE/include/python2.4"></Environment>
163 < <Environment name=PYTHON_COMPILE default="$PYTHON_BASE/lib/python2.4/compileall.py"></Environment>
164 < </Client>
165 < <use name=sockets>
166 < <Runtime name=PATH value="$PYTHON_BASE/bin" type=path>
167 < </Tool>
168 < EOF_TOOLFILE
153 >   find %i/lib/python%{pythonv}/config -name 'libpython*' -exec mv -f {} %i/lib \;
154 >  ;;
155 > esac
156 >
157 > perl -p -i -e "s|^#!.*python|#!/usr/bin/env python|" %{i}/bin/idle \
158 >                     %{i}/bin/pydoc \
159 >                     %{i}/bin/python-config \
160 >                     %{i}/bin/2to3 \
161 >                     %{i}/bin/python2.7-config \
162 >                     %{i}/bin/smtpd.py
163 >
164 > find %{i}/lib -maxdepth 1 -mindepth 1 ! -name '*python*' -exec rm {} \;
165 > find %{i}/include -maxdepth 1 -mindepth 1 ! -name '*python*' -exec rm {} \;
166 >
167 > # remove executable permission anything which is *.py script,
168 > # is executable, but does not start with she-bang so not valid
169 > # executable; this avoids problems with rpm 4.8+ find-requires
170 > find %i -name '*.py' -perm +0111 | while read f; do
171 >  if head -n1 $f | grep -q '"'; then chmod -x $f; else :; fi
172 > done
173 >
174 > # remove tkinter that brings dependency on libtk:
175 > find %{i}/lib -type f -name "_tkinter.so" -exec rm {} \;
176 >
177 > # Remove documentation, examples and test files.
178 > %define drop_files { %i/share %{i}/lib/python%{pythonv}/test \
179 >                   %{i}/lib/python%{pythonv}/distutils/tests \
180 >                   %{i}/lib/python%{pythonv}/json/tests \
181 >                   %{i}/lib/python%{pythonv}/ctypes/test \
182 >                   %{i}/lib/python%{pythonv}/sqlite3/test \
183 >                   %{i}/lib/python%{pythonv}/bsddb/test \
184 >                   %{i}/lib/python%{pythonv}/email/test \
185 >                   %{i}/lib/python%{pythonv}/lib2to3/tests }
186 >
187 > # Remove .pyo files
188 > find %i -name '*.pyo' -exec rm {} \;
189 >
190 > # Generate dependencies-setup.{sh,csh} so init.{sh,csh} picks full environment.
191 > mkdir -p %i/etc/profile.d
192 > : > %i/etc/profile.d/dependencies-setup.sh
193 > : > %i/etc/profile.d/dependencies-setup.csh
194 > for tool in $(echo %{requiredtools} | sed -e's|\s+| |;s|^\s+||'); do
195 >  root=$(echo $tool | tr a-z- A-Z_)_ROOT; eval r=\$$root
196 >  if [ X"$r" != X ] && [ -r "$r/etc/profile.d/init.sh" ]; then
197 >    echo "test X\$$root != X || . $r/etc/profile.d/init.sh" >> %i/etc/profile.d/dependencies-setup.sh
198 >    echo "test X\$$root != X || source $r/etc/profile.d/init.csh" >> %i/etc/profile.d/dependencies-setup.csh
199 >  fi
200 > done
201  
202   %post
203 < 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
204 < %{relocateConfig}etc/scram.d/%n
203 > %{relocateConfig}lib/python2.7/config/Makefile
204 > %{relocateConfig}etc/profile.d/dependencies-setup.*sh

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines