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.51 by muzaffar, Fri Jun 19 12:59:52 2009 UTC vs.
Revision 1.64 by elmer, Mon Apr 19 16:13:00 2010 UTC

# Line 1 | Line 1
1 < ### RPM external python 2.4.2-CMS19
1 > ### RPM external python 2.6.4
2   ## INITENV +PATH PATH %i/bin
3   ## INITENV +PATH LD_LIBRARY_PATH %i/lib
4   # OS X patches and build fudging stolen from fink
5   %define closingbrace )
6 < %define online %(case %cmsplatf in *onl_*_*%closingbrace echo true;; *%closingbrace echo flase;; esac)
6 > %define online %(case %cmsplatf in *onl_*_*%closingbrace echo true;; *%closingbrace echo false;; esac)
7  
8   Requires: expat bz2lib db4 gdbm
9  
10   %if "%online" != "true"
11 < Requires: zlib openssl
11 > Requires: zlib openssl sqlite
12   %endif
13  
14   # FIXME: readline, crypt
15   # FIXME: gmp, panel, tk/tcl, x11
16  
17   Source0: http://www.python.org/ftp/%n/%realversion/Python-%realversion.tgz
18 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
18  
19   %prep
20   %setup -n Python-%realversion
29 #%patch0
30 #%patch1
31 #%patch2
32 #%patch3
33 #%patch4
34 #%patch5
35 #%patch6
21   perl -p -i -e "s|#!.*/usr/local/bin/python|#!/usr/bin/env python|" Lib/cgi.py
22  
23   %ifos darwin
# Line 51 | Line 36 | perl -p -i -e "s|#!.*/usr/local/bin/pyth
36   # see above for the commented-out list of packages that could be
37   # linked specifically, or could be built by ourselves, depending on
38   # whether we like to pick up system libraries or want total control.
39 < mkdir -p %i/include %i/lib
39 > #mkdir -p %i/include %i/lib
40 > mkdir -p %i/include %i/lib %i/bin
41  
42   %if "%online" != "true"
43 < %define extradirs $ZLIB_ROOT $OPENSSL_ROOT
43 > %define extradirs $ZLIB_ROOT $OPENSSL_ROOT $SQLITE_ROOT
44   %else
45   %define extradirs %{nil}
46   %endif
# Line 87 | Line 73 | esac
73  
74   # The following is a kludge around the fact that the /usr/lib/libreadline.so
75   # symlink (for 32-bit lib) is missing on the 64bit machines
76 < %if "%cmsplatf" == "slc4_ia32_gcc345"
77 <  mkdir -p %{i}/lib
78 <  ln -s /usr/lib/libreadline.so.4.3 %{i}/lib/libreadline.so
79 < %endif
80 < %if "%cmsplatf" == "slc4_ia32_gcc412"
81 <  mkdir -p %{i}/lib
96 <  ln -s /usr/lib/libreadline.so.4.3 %{i}/lib/libreadline.so
97 < %endif
76 > case %cmsplatf in
77 >  slc4_ia32* )
78 >    mkdir -p %{i}/lib
79 >    ln -s /usr/lib/libreadline.so.4.3 %{i}/lib/libreadline.so
80 >  ;;
81 > esac
82   make %makeprocesses
83  
84   %install
85   make install
86   %define pythonv %(echo %realversion | cut -d. -f 1,2)
87  
88 < #if [ $(uname) = Darwin ]; then
89 <  # make install prefix=%i
90 <  # (cd Misc; /bin/rm -rf RPM)
91 <  # mkdir -p %i/share/doc/%n
92 <  # cp -R Demo Doc %i/share/doc/%n
93 <  # cp -R Misc Tools %i/lib/python%{pythonv}
94 < #  gcc -dynamiclib -all_load -single_module \
95 < #    -framework System -framework CoreServices -framework Foundation \
96 < #    %i/lib/python%{pythonv}/config/libpython%{pythonv}.a \
97 < #    -undefined dynamic_lookup \
98 < #    -o %i/lib/python%{pythonv}/config/libpython%{pythonv}.dylib \
99 < #    -install_name %i/lib/python%{pythonv}/config/libpython%{pythonv}.dylib \
100 < #    -current_version %{pythonv} -compatibility_version %{pythonv} -ldl
101 < #  ln -s libpython%{pythonv}.dylib %i/lib/python%{pythonv}/config/libpython%{pythonv}.dylib # for boost
102 <  # (cd %i/lib/python%{pythonv}/config; mv Makefile Makefile.orig;
103 <  #  sed 's|-fno-common||g' < Makefile.orig > Makefile; /bin/rm -f Makefile.orig)
104 < #fi
88 > case %cmsplatf in
89 >  osx*)
90 >   make install prefix=%i
91 >   (cd Misc; /bin/rm -rf RPM)
92 >   mkdir -p %i/share/doc/%n
93 >   cp -R Demo Doc %i/share/doc/%n
94 >   cp -R Misc Tools %i/lib/python%{pythonv}
95 >   gcc -dynamiclib -all_load -single_module \
96 >    -framework System -framework CoreServices -framework Foundation \
97 >    %i/lib/python%{pythonv}/config/libpython%{pythonv}.a \
98 >    -undefined dynamic_lookup \
99 >    -o %i/lib/python%{pythonv}/config/libpython%{pythonv}.dylib \
100 >    -install_name %i/lib/python%{pythonv}/config/libpython%{pythonv}.dylib \
101 >    -current_version %{pythonv} -compatibility_version %{pythonv} -ldl
102 >   (cd %i/lib/python%{pythonv}/config
103 >    perl -p -i -e 's|-fno-common||g' Makefile)
104 >
105 >   find %i/lib/python%{pythonv}/config -name 'libpython*' -exec mv -f {} %i/lib \;
106 >  ;;
107 > esac
108  
109   perl -p -i -e "s|^#!.*python|#!/usr/bin/env python|" %{i}/bin/idle \
110                      %{i}/bin/pydoc \
111 +                    %{i}/bin/python-config \
112 +                    %{i}/bin/2to3 \
113 +                    %{i}/bin/python2.6-config \
114                      %{i}/bin/smtpd.py \
115 <                    %{i}/lib/python2.4/bsddb/dbshelve.py \
116 <                    %{i}/lib/python2.4/test/test_bz2.py \
117 <                    %{i}/lib/python2.4/test/test_largefile.py \
118 <                    %{i}/lib/python2.4/test/test_optparse.py
129 < # boost.spec rfio.spec
130 < #
131 < #
115 >                    %{i}/lib/python2.6/bsddb/dbshelve.py \
116 >                    %{i}/lib/python2.6/test/test_bz2.py \
117 >                    %{i}/lib/python2.6/test/test_largefile.py \
118 >                    %{i}/lib/python2.6/test/test_optparse.py
119   rm  `find %{i}/lib -maxdepth 1 -mindepth 1 ! -name '*python*'`
120   rm  `find %{i}/include -maxdepth 1 -mindepth 1 ! -name '*python*'`
121  
135 %if "%online" == "true"
122   # remove tkinter that brings dependency on libtk:
123 < rm  `find %{i}/lib -type f -name "_tkinter.so"`
138 < %endif
123 > find %{i}/lib -type f -name "_tkinter.so" -exec rm {} \;
124  
125   # SCRAM ToolBox toolfile
126   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.4>
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.4"></Environment>
135 < <Environment name=PYTHON_COMPILE default="$PYTHON_BASE/lib/python2.4/compileall.py"></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
147 +
148 + # Setups dependencies environment
149 + rm -rf %i/etc/profile.d
150 + mkdir -p %i/etc/profile.d
151 + for x in %pkgreqs; do
152 +  case $x in /* ) continue ;; esac
153 +  p=%{instroot}/%{cmsplatf}/$(echo $x | sed 's/\([^+]*\)+\(.*\)+\([A-Z0-9].*\)/\1 \2 \3/' | tr ' ' '/')
154 +  echo ". $p/etc/profile.d/init.sh" >> %i/etc/profile.d/dependencies-setup.sh
155 +  echo "source $p/etc/profile.d/init.csh" >> %i/etc/profile.d/dependencies-setup.csh
156 + done
157 +
158   %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
161 + %{relocateConfig}lib/python2.6/config/Makefile
162 +
163 + # Relocation for dependencies
164 + %{relocateConfig}etc/profile.d/dependencies-setup.sh
165 + %{relocateConfig}etc/profile.d/dependencies-setup.csh
166 +

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines