ViewVC Help
View File | Revision Log | Show Annotations | Root Listing
root/cvsroot/COMP/CMSDIST/boost.spec
(Generate patch)

Comparing COMP/CMSDIST/boost.spec (file contents):
Revision 1.41 by eulisse, Thu Feb 12 13:14:59 2009 UTC vs.
Revision 1.51 by dsr, Wed Jan 13 21:16:47 2010 UTC

# Line 1 | Line 1
1 < ### RPM external boost 1.38.0
1 > ### RPM external boost 1.40.0
2   %define boostver _%(echo %realversion | tr . _)
3   Source: http://internap.dl.sourceforge.net/sourceforge/%{n}/%{n}%{boostver}.tar.gz
4 + %define closingbrace )
5 + %define online %(case %cmsplatf in *onl_*_*%closingbrace echo true;; *%closingbrace echo false;; esac)
6  
7   Requires: boost-build python bz2lib
8 < %if "%cmsplatf" != "slc4onl_ia32_gcc346"
8 > %if "%online" != "true"
9   Requires: zlib
10   %endif
11  
# Line 11 | Line 13 | Requires: zlib
13   %setup -n %{n}%{boostver}
14  
15   %build
14 # Note that some targets will fail to build (the test programs have
15 # missing symbols), causing darwin to fail to link and bjam to return
16 # an error.  So ignore the exit code from bjam on darwin to avoid
17 # RPM falsely detecting a problem.
16   PV="PYTHON_VERSION=$(echo $PYTHON_VERSION | sed 's/\.[0-9]*-.*$//')"
17   PR="PYTHON_ROOT=$PYTHON_ROOT"
18  
# Line 23 | Line 21 | PR="PYTHON_ROOT=$PYTHON_ROOT"
21   BZ2LIBR="BZIP2_LIBPATH=$BZ2LIB_ROOT/lib"
22   BZ2LIBI="BZIP2_INCLUDE=$BZ2LIB_ROOT/include"
23  
24 < %if "%cmsplatf" != "slc4onl_ia32_gcc346"
24 > %if "%online" != "true"
25   ZLIBR="ZLIB_LIBPATH=$ZLIB_ROOT/lib"
26   ZLIBI="ZLIB_INCLUDE=$ZLIB_ROOT/include"
27  
28   case $(uname) in
29 <  Darwin )  bjam %makeprocesses -s$PR -s$PV -s$BZ2LIBR -s$ZLIBR -sTOOLS=darwin --toolset=darwin || true ;;
30 <  * )       bjam %makeprocesses -s$PR -s$PV -s$BZ2LIBR -s$ZLIBR -sTOOLS=gcc ;;
29 >  Darwin )  bjam %makeprocesses -s$PR -s$PV -s$BZ2LIBR -s$ZLIBR toolset=darwin stage;;
30 >  * )       bjam %makeprocesses -s$PR -s$PV -s$BZ2LIBR -s$ZLIBR toolset=gcc stage;;
31   esac
32   %else
33 < bjam %makeprocesses -s$PR -s$PV -s$BZ2LIBR -s$BZ2LIBI -sTOOLS=gcc
33 > bjam %makeprocesses -s$PR -s$PV -s$BZ2LIBR -s$BZ2LIBI toolset=gcc stage
34   %endif
35  
36   %install
39
40 linkgccver=%(echo %gccver | tr -d . | perl -pe 's/^(\d\d).*/$1/')
41
42 boost_abi=$(echo %boostver | sed 's/^_//; s/_0$//')
37   case $(uname) in Darwin ) so=dylib ;; * ) so=so ;; esac
38   #no debug libs...
39   #mkdir -p %i/lib/debug
40   mkdir %i/lib
41   #(cd bin/boost; find libs -path "libs/*/debug/*.$so" -exec cp {} %i/lib/debug \;)
42 < # Perhaps the following could be done with a wildcard for the darwin/gcc dir
43 < case $(uname) in
50 <  Darwin )
51 <    (cd bin.v2; find libs -path "libs/*/build/darwin*/release/*.$so*" -exec cp  {} %i/lib/. \;)
52 <    ;;
53 <   * )
54 <    (cd bin.v2; find libs -path "libs/*/build/gcc*/release/*.$so*" -exec cp  {} %i/lib/. \;)
55 <    ;;
56 < esac
42 > (cd stage; find lib -path "lib/*.$so*" -type f -exec cp  {} %i/lib/. \;)
43 >
44   find boost -name '*.[hi]*' -print |
45    while read f; do
46      mkdir -p %i/include/$(dirname $f)
# Line 64 | Line 51 | find libs -name '*.py' -print |
51      mkdir -p %i/lib/$(dirname $f)
52      install -c $f %i/lib/$f
53    done
67 [ $(uname) = Darwin ] &&
68  for f in %i/lib/*.$so %i/lib/*.$so; do
69    install_name_tool -id $f $f
70  done
54  
55   # Do all manipulation with files before creating symbolic links:
56   perl -p -i -e "s|^#!.*python|/usr/bin/env python|" $(find %{i}/lib %{i}/bin)
57   #strip %i/lib/*.$so
58  
59 + for l in `find %i/lib -name "*.$so.*"`
60 + do
61 +  ln -s `basename $l` `echo $l | sed -e "s|[.]$so[.].*|.$so|"`
62 + done
63  
77 #(cd %i/lib; for f in lib*-$boost_abi.$so; do ln -s $f $(echo $f | sed "s/-$boost_abi//"); done)
78 #(cd %i/lib; for f in lib*-$boost_abi.$so; do ln -s $f $f.%realversion ; done)
79 (cd %i/lib; for f in lib*-$boost_abi.$so.%{realversion}; do ln -s $f $(echo $f | sed "s/.%{realversion}$//"); done)
80 (cd %i/lib; for f in lib*-$boost_abi.$so.%{realversion}; do ln -s $f $(echo $f | sed "s/-$boost_abi//" | sed "s/.%{realversion}$//"); done)
81 (cd %i/lib; for f in lib*-$boost_abi.$so.%{realversion}; do ln -s $f $(echo $f | sed "s/-$boost_abi//" | sed "s/.%{realversion}$//" | sed "s/gcc$linkgccver/gcc/"); done)
82 #(cd %i/lib/debug; for f in lib*-d-$boost_abi.$so; do ln -s $f $(echo $f | sed "s/-d-$boost_abi//"); done)
83 #(cd %i/lib/debug; for f in lib*-d-$boost_abi.$so; do ln -s $f $f.%realversion; done)
64   (cd %i/lib/libs/python/pyste/install; python setup.py install --prefix=%i)
65  
66   getLibName()
67   {
68 <  libname=`find %i/lib -name "libboost_$1*mt*" -exec basename {} \;`
68 >  libname=`find %i/lib -name "libboost_$1.$so" -exec basename {} \;`
69    echo $libname | sed -e 's|[.][^-]*$||;s|^lib||'
70   }
71  
72   export BOOST_THREAD_LIB=`getLibName thread`
73   export BOOST_SIGNALS_LIB=`getLibName signals`
74   export BOOST_FILESYSTEM_LIB=`getLibName filesystem`
75 + export BOOST_SYSTEM_LIB=`getLibName system`
76   export BOOST_PROGRAM_OPTIONS_LIB=`getLibName program_options`
77   export BOOST_PYTHON_LIB=`getLibName python`
78   export BOOST_REGEX_LIB=`getLibName regex`
79 + export PYTHONV=$(echo $PYTHON_VERSION | cut -f1,2 -d.)
80  
81   # SCRAM ToolBox toolfile
82   mkdir -p %i/etc/scram.d
# Line 122 | Line 104 | cat << \EOF_TOOLFILE >%i/etc/scram.d/boo
104   <Tool name=boost_filesystem version=%v>
105   <info url="http://www.boost.org"></info>
106   <lib name="@BOOST_FILESYSTEM_LIB@">
107 + <use name=boost_system>
108 + <use name=boost>
109 + </Tool>
110 + EOF_TOOLFILE
111 +
112 + # boost_system toolfile
113 + cat << \EOF_TOOLFILE >%i/etc/scram.d/boost_system
114 + <doc type=BuildSystem::ToolDoc version=1.0>
115 + <Tool name=boost_system version=%v>
116 + <info url="http://www.boost.org"></info>
117 + <lib name="@BOOST_SYSTEM_LIB@">
118   <use name=boost>
119   </Tool>
120   EOF_TOOLFILE
# Line 144 | Line 137 | cat << \EOF_TOOLFILE >%i/etc/scram.d/boo
137   <lib name="@BOOST_PYTHON_LIB@">
138   <Client>
139   <Environment name=BOOST_PYTHON_BASE default="%i"></Environment>
140 < <Environment name=PYSTE_EXEC default="$BOOST_PYTHON_BASE/lib/python2.4/site-packages/Pyste/pyste.py"></Environment>
140 > <Environment name=PYSTE_EXEC default="$BOOST_PYTHON_BASE/lib/python@PYTHONV@/site-packages/Pyste/pyste.py"></Environment>
141   <Environment name=LIBDIR default="$BOOST_PYTHON_BASE/lib"></Environment>
142   <Environment name=INCLUDE default="$BOOST_PYTHON_BASE/include"></Environment>
143   </Client>
# Line 174 | Line 167 | cat << \EOF_TOOLFILE >%i/etc/scram.d/boo
167   </Tool>
168   EOF_TOOLFILE
169  
170 + # boost_header toolfile
171 + cat << \EOF_TOOLFILE >%i/etc/scram.d/boost_header
172 + <doc type=BuildSystem::ToolDoc version=1.0>
173 + <Tool name=boost_header version=%v>
174 + <info url="http://www.boost.org"></info>
175 + <Client>
176 + <Environment name=BOOSTHEADER_BASE default="%i"></Environment>
177 + <Environment name=INCLUDE default="$BOOSTHEADER_BASE/include"></Environment>
178 + </Client>
179 + </Tool>
180 + EOF_TOOLFILE
181 +
182 +
183   perl -p -i -e 's|\@([^@]*)\@|$ENV{$1}|g' %i/etc/scram.d/*
184  
185   %post
# Line 183 | Line 189 | perl -p -i -e 's|\@([^@]*)\@|$ENV{$1}|g'
189   %{relocateConfig}etc/scram.d/boost_python
190   %{relocateConfig}etc/scram.d/boost_regex
191   %{relocateConfig}etc/scram.d/boost_signals
192 + %{relocateConfig}etc/scram.d/boost_header

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines