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.20 by eulisse, Sat Aug 26 16:24:04 2006 UTC vs.
Revision 1.70 by eulisse, Fri Sep 24 09:37:16 2010 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   # OS X patches and build fudging stolen from fink
5 < Requires: zlib expat openssl bz2lib db4 gdbm openssl
5 > %define closingbrace )
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 sqlite
12 > %endif
13 >
14   # FIXME: readline, crypt
15   # FIXME: gmp, panel, tk/tcl, x11
16  
17 < Source0: http://www.python.org/ftp/%n/%v/Python-%v.tgz
18 < Patch0: python-Include-pyport.h
11 < Patch1: python-Lib-plat-mac-applesingle.py
12 < Patch2: python-Lib-site.py
13 < Patch3: python-Mac-OSX-Makefile
14 < Patch4: python-Makefile.pre.in
15 < Patch5: python-configure
16 < Patch6: python-setup.py
17 <
17 > Source0: http://www.python.org/ftp/%n/%realversion/Python-%realversion.tgz
18 > Patch0: python-2.6.4-dont-detect-dbm
19  
20   %prep
21 < %setup -n Python-%v
21 < #%patch0
22 < #%patch1
23 < #%patch2
24 < #%patch3
25 < #%patch4
26 < #%patch5
27 < #%patch6
21 > %setup -n Python-%realversion
22   perl -p -i -e "s|#!.*/usr/local/bin/python|#!/usr/bin/env python|" Lib/cgi.py
23  
24 < %ifos darwin
25 < sed 's|@PREFIX@|%i|g' < %_sourcedir/python-osx | patch -p1
26 < %endif
24 > case %cmsplatf in
25 >  osx*)
26 >        sed 's|@PREFIX@|%i|g' < %_sourcedir/python-osx | patch -p1
27 >  ;;
28 > esac
29 > %patch0 -p1
30  
31   %build
32   # Python is awkward about passing other include or library directories
# Line 43 | Line 40 | perl -p -i -e "s|#!.*/usr/local/bin/pyth
40   # see above for the commented-out list of packages that could be
41   # linked specifically, or could be built by ourselves, depending on
42   # whether we like to pick up system libraries or want total control.
43 < mkdir -p %i/include %i/lib
44 < dirs="$ZLIB_ROOT $EXPAT_ROOT $OPENSSL_ROOT $BZ2LIB_ROOT $NCURSES_ROOT $DB4_ROOT $GDBM_ROOT"
43 > #mkdir -p %i/include %i/lib
44 > mkdir -p %i/include %i/lib %i/bin
45 >
46 > %if "%online" != "true"
47 > %define extradirs $ZLIB_ROOT $OPENSSL_ROOT $SQLITE_ROOT
48 > %else
49 > %define extradirs %{nil}
50 > %endif
51 >
52 > dirs="$EXPAT_ROOT $BZ2LIB_ROOT $NCURSES_ROOT $DB4_ROOT $GDBM_ROOT %{extradirs}"
53 >
54 > # We need to export it because setup.py now uses it to determine the actual
55 > # location of DB4, this was needed to avoid having it picked up from the system.
56 > export DB4_ROOT
57 >
58   echo $dirs
59   for d in $dirs; do
60    for f in $d/include/*; do
61 <    [ -f $f ] || continue
61 >    [ -e $f ] || continue
62      rm -f %i/include/$(basename $f)
63      ln -s $f %i/include
64    done
65    for f in $d/lib/*; do
66 <    [ -f $f ] || continue
66 >    [ -e $f ] || continue
67      rm -f %i/lib/$(basename $f)
68      ln -s $f %i/lib
69    done
70   done
71  
72 < ./configure --prefix=%i --enable-shared --without-tkinter --disable-tkinter --without-readline
72 > additionalConfigureOptions=""
73 > case %cmsplatf in
74 >    osx105* )
75 >    additionalConfigureOptions="--disable-readline"
76 >    ;;
77 > esac
78 >
79 > ./configure --prefix=%i $additionalConfigureOptions --enable-shared \
80 >            --without-tkinter --disable-tkinter
81 >
82 > # The following is a kludge around the fact that the /usr/lib/libreadline.so
83 > # symlink (for 32-bit lib) is missing on the 64bit machines
84 > case %cmsplatf in
85 >  slc4_ia32* )
86 >    mkdir -p %{i}/lib
87 >    ln -s /usr/lib/libreadline.so.4.3 %{i}/lib/libreadline.so
88 >  ;;
89 > esac
90   make %makeprocesses
91  
92   %install
93   make install
94 < %define pythonv %(echo %v | cut -d. -f 1,2)
94 > %define pythonv %(echo %realversion | cut -d. -f 1,2)
95  
96 < #if [ $(uname) = Darwin ]; then
97 <  # make install prefix=%i
98 <  # (cd Misc; /bin/rm -rf RPM)
99 <  # mkdir -p %i/share/doc/%n
100 <  # cp -R Demo Doc %i/share/doc/%n
101 <  # cp -R Misc Tools %i/lib/python%{pythonv}
102 < #  gcc -dynamiclib -all_load -single_module \
103 < #    -framework System -framework CoreServices -framework Foundation \
104 < #    %i/lib/python%{pythonv}/config/libpython%{pythonv}.a \
105 < #    -undefined dynamic_lookup \
106 < #    -o %i/lib/python%{pythonv}/config/libpython%{pythonv}.dylib \
107 < #    -install_name %i/lib/python%{pythonv}/config/libpython%{pythonv}.dylib \
108 < #    -current_version %{pythonv} -compatibility_version %{pythonv} -ldl
109 < #  ln -s libpython%{pythonv}.dylib %i/lib/python%{pythonv}/config/libpython%{pythonv}.dylib # for boost
110 <  # (cd %i/lib/python%{pythonv}/config; mv Makefile Makefile.orig;
111 <  #  sed 's|-fno-common||g' < Makefile.orig > Makefile; /bin/rm -f Makefile.orig)
112 < #fi
96 > case %cmsplatf in
97 >  osx*)
98 >   make install prefix=%i
99 >   (cd Misc; /bin/rm -rf RPM)
100 >   mkdir -p %i/share/doc/%n
101 >   cp -R Demo Doc %i/share/doc/%n
102 >   cp -R Misc Tools %i/lib/python%{pythonv}
103 >   gcc -dynamiclib -all_load -single_module \
104 >    -framework System -framework CoreServices -framework Foundation \
105 >    %i/lib/python%{pythonv}/config/libpython%{pythonv}.a \
106 >    -undefined dynamic_lookup \
107 >    -o %i/lib/python%{pythonv}/config/libpython%{pythonv}.dylib \
108 >    -install_name %i/lib/python%{pythonv}/config/libpython%{pythonv}.dylib \
109 >    -current_version %{pythonv} -compatibility_version %{pythonv} -ldl
110 >   (cd %i/lib/python%{pythonv}/config
111 >    perl -p -i -e 's|-fno-common||g' Makefile)
112 >
113 >   find %i/lib/python%{pythonv}/config -name 'libpython*' -exec mv -f {} %i/lib \;
114 >  ;;
115 > esac
116  
117   perl -p -i -e "s|^#!.*python|#!/usr/bin/env python|" %{i}/bin/idle \
118                      %{i}/bin/pydoc \
119 +                    %{i}/bin/python-config \
120 +                    %{i}/bin/2to3 \
121 +                    %{i}/bin/python2.6-config \
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*'`
123 >                    %{i}/lib/python2.6/bsddb/dbshelve.py \
124 >                    %{i}/lib/python2.6/test/test_bz2.py \
125 >                    %{i}/lib/python2.6/test/test_largefile.py \
126 >                    %{i}/lib/python2.6/test/test_optparse.py
127 >
128 > find %{i}/lib -maxdepth 1 -mindepth 1 ! -name '*python*' -exec rm {} \;
129 > find %{i}/include -maxdepth 1 -mindepth 1 ! -name '*python*' -exec rm {} \;
130 >
131 > # remove tkinter that brings dependency on libtk:
132 > find %{i}/lib -type f -name "_tkinter.so" -exec rm {} \;
133 >
134 > # Makes sure that executables start with /usr/bin/env perl and not with comments.
135 > find %i -type f -perm -555 -name '*.py' -exec perl -p -i -e 'if ($. == 1) {s|^"""|#/usr/bin/env python\n"""|}' {} \;
136 > find %i -type f -perm -555 -name '*.py' -exec perl -p -i -e 'if ($. == 1) {s|^\'\'\'|#/usr/bin/env python\n\'\'\'|}' {} \;
137 > find %i -type f -perm -555 -name '*.py' -exec perl -p -i -e 'if ($. == 1) {s|/usr/local/bin/python|/usr/bin/env python|}' {} \;
138 > rm -f %i/share/doc/python/Demo/rpc/test
139 >
140 > # Generate dependencies-setup.{sh,csh} so init.{sh,csh} picks full environment.
141 > mkdir -p %i/etc/profile.d
142 > : > %i/etc/profile.d/dependencies-setup.sh
143 > : > %i/etc/profile.d/dependencies-setup.csh
144 > for tool in $(echo %{requiredtools} | sed -e's|\s+| |;s|^\s+||'); do
145 >  root=$(echo $tool | tr a-z- A-Z_)_ROOT; eval r=\$$root
146 >  if [ X"$r" != X ] && [ -r "$r/etc/profile.d/init.sh" ]; then
147 >    echo "test X\$$root != X || . $r/etc/profile.d/init.sh" >> %i/etc/profile.d/dependencies-setup.sh
148 >    echo "test X\$$root != X || source $r/etc/profile.d/init.csh" >> %i/etc/profile.d/dependencies-setup.csh
149 >  fi
150 > done
151 >
152   %post
153 < 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
153 > %{relocateConfig}lib/python2.6/config/Makefile
154 > %{relocateConfig}etc/profile.d/dependencies-setup.*sh

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines