X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=config_files%2Fcommon.sh;h=d3c7afaf4bf3bd3d0e8494d7666ef3c6e3176c6b;hb=c4f1343d49c7bd7cd3f23565ccb18330fc595ee1;hp=f8c08cab39794108d112257e480b88e74baa4fa6;hpb=be87403cff97410bf40302b84dbc345a0664519a;p=tools%2Finstall.git diff --git a/config_files/common.sh b/config_files/common.sh index f8c08ca..d3c7afa 100755 --- a/config_files/common.sh +++ b/config_files/common.sh @@ -1,24 +1,44 @@ -#!/bin/sh -# -# This script installs a subset of products necessary for SALOME application -# -# Usage: install [all] -# install ... -# -# Type 'install --help' to get more information -# -# Important note: -# must be an absolute path +#!/bin/bash -noprofile + +#################################################################################### +# File : common.sh +# Created : Thu Dec 18 12:01:00 2002 +# Author : Vadim SANDLER, Open CASCADE SAS (vadim.sandler@opencascade.com) +# Project : SALOME +# Module : Installation Wizard +# Copyright : 2002-2007 CEA # -# The script is the part of the SALOME PRO installation procedure. +# This script is the part of the SALOME installation procedure. # -# Copyright : 2003 CEA/DEN, EDF R&D #################################################################################### export DELIM="------" export SHRC="salome.sh" export CSHRC="salome.csh" -export DEBUG=1 + + +#this function takes several parameters +#first parameter contains path to module source filder +#second parameters is value of $VERSION variables form MODULE.sh file + +check_salome_src_version(){ +root_dir=`printenv $1` +module_version=$2 + +if [ -n "$root_dir" ]; then + cfg_file=configure.ac + if [ ! -f ${root_dir}/${cfg_file} ] ; then + cfg_file=configure.in.base + fi + if [ -f ${root_dir}/${cfg_file} ] ; then + ver=`grep -e "^AC_INIT" ${root_dir}/${cfg_file} | sed -e "s%.*\[\([[:digit:].]*\)\].*%\1%g"` + if [ "$ver" = "${module_version}" ]; then + return 0 + fi + fi +fi +return 1 +} #this function takes several parameters #first parameter contains descriptor of output file @@ -29,19 +49,21 @@ check_job() { out=$1 shift - echo -e "`pwd` -> $* >> $out" - if [ $DEBUG == 0 ] ; then - $* | tee $out + errfile=/tmp/errlog + if [ -n "$INSTALL_WORK" ] ; then errfile=$INSTALL_WORK/errlog; fi + cmd="`pwd` -> $*" + if [ "$out" != "1" ] ; then cmd="$cmd >> $out" ; fi + echo -e $cmd + if [ "$out" != "1" ] ; then + $* >> $out 2>$errfile else - if [ $out == "1" ] ; then $* - else - $* >> $out 2>&1 - fi fi if [ "$?" -ne "0" ] ; then if [ $out != "1" ] ; then cat $out + cat $errfile >&2 + cat $errfile >> $out fi # VSR : 10/11/05: disable answer mode ==> #echo -n " " >&2 @@ -78,6 +100,7 @@ make_env() { install_root=$1; shift install_work=$1; + for i in $SHRC $CSHRC ; do if [ -e ${install_work}/$i ]; then rm ${install_work}/$i @@ -85,8 +108,8 @@ for i in $SHRC $CSHRC ; do touch ${install_work}/$i done -if [ $# -eq 3 ] ; then - product_name=$3; +if [ $# -eq 4 ] ; then + product_name=$4; product_env=${install_work}/env_${product_name}.sh (test -e ${product_env} && rm ${product_env} ) fi @@ -126,10 +149,44 @@ done ### Note, that for performance reasons temporary environment files used during installation procedure itself ### are created without using setenv(a|p) aliases. +# 0. add /usr/lib or /usr/lib64 dir to the LD_LIBRARY_PATH +#if test `uname -m` = "x86_64" ; then +#echo 'export LD_LIBRARY_PATH=/usr/lib64:${LD_LIBRARY_PATH}' >> ${install_work}/$SHRC 2>/dev/null +#echo '' >> ${install_work}/$SHRC 2>/dev/null +#else +#echo 'export LD_LIBRARY_PATH=/usr/lib:${LD_LIBRARY_PATH}' >> ${install_work}/$SHRC 2>/dev/null +#echo '' >> ${install_work}/$SHRC 2>/dev/null +#fi + +# Licence activation + +# Source of license environment file + +echo '#------ License activation ------' >> ${install_work}/$SHRC 2>/dev/null +echo 'export LICENSE_FILE=/product/distene/dlim8.var.sh' >> ${install_work}/$SHRC 2>/dev/null +echo '' >> ${install_work}/$SHRC 2>/dev/null +echo 'if [ -e "${LICENSE_FILE}" ] ; then' >> ${install_work}/$SHRC 2>/dev/null +echo 'export SIMULOGD_LICENSE_FILE=29029@amun' >> ${install_work}/$SHRC 2>/dev/null +echo 'source ${LICENSE_FILE}' >> ${install_work}/$SHRC 2>/dev/null +echo 'fi' >> ${install_work}/$SHRC 2>/dev/null +echo '' >> ${install_work}/$SHRC 2>/dev/null + # 1. first dump all environment files into the $SHRC file product_sequence="$2" +install_products="$3" for i in $product_sequence ; do - cat ${install_work}/env_${i}.sh >> ${install_work}/$SHRC 2>/dev/null + env_file=${install_work}/env_${i}.sh + _env_file=${install_work}/_env_${i}.sh + if [ -e $_env_file ] ; then + cat $_env_file >> ${install_work}/$SHRC 2>/dev/null + elif [ -e $env_file ] ; then + echo $install_products | grep -q "\b${i}\b" + if [ $? -eq 1 ] ; then + cat $env_file | sed 's/^/## /' >> ${install_work}/$SHRC 2>/dev/null + else + cat $env_file >> ${install_work}/$SHRC 2>/dev/null + fi + fi done # 2. writing global functions to _salome.sh file @@ -153,33 +210,45 @@ cat >> ${install_work}/_$SHRC <") nb = split("",b,":"); \\ - else nb = split(\$1,b,":"); \\ - s = "" ; \\ - for(i=1;i<=nb;i++) { \\ - if(!(b[i] in ccc)) { \\ - if(length(s)!=0) \\ - s = sprintf("%s:",s); \\ - s = sprintf("%s%s",s,b[i]); \\ - ccc[b[i]]; \\ - }; \\ - }; \\ - s1 = ""; \\ - for(i=1;i<=na;i++) { \\ - if(!(a[i] in ccc)) { \\ - if(length(s1)!=0) \\ - s1 = sprintf("%s:",s1); \\ - s1 = sprintf("%s%s",s1,a[i]); \\ - ccc[a[i]]; \\ - }; \\ - }; \\ - if(dir) \\ - s = length(s) == 0 ? s1 : sprintf("%s:%s",s1,s); \\ - else \\ - s = length(s1) == 0 ? s : sprintf("%s:%s",s,s1); \\ - printf("%s\n",s); \\ - }'\` + na = split(\$2,a,":"); \\ + k1=0; \\ + bbb[k1++]=""; \\ + ccc[""]; \\ + if(\$1 != "") { \\ + nb = split(\$1,b,":"); \\ + for(i=1;i<=nb;i++) { \\ + if(!(b[i] in ccc) ) { \\ + ccc[b[i]]; \\ + bbb[k1++]=b[i]; \\ + }; \\ + }; \\ + }; \\ + k2=0; \\ + aaa[k2++]=""; \\ + for(i=1;i<=na;i++) { \\ + if(!(a[i] in ccc)) { \\ + ccc[a[i]]; \\ + aaa[k2++]=a[i]; \\ + }; \\ + }; \\ + ORS=":"; \\ + if(dir) { \\ + for(i=1;i> ${install_work}/_$CSHRC <> ${install_work}/_$CSHRC < ${INSTALL_WORK}/_tmp2 2>/dev/null sed -e 's%export\([[:blank:]]*\)PYTHONPATH=\$[{]\?PYTHONPATH[}]\?:\(.*\)%exporta\1PYTHONPATH \2%g' -e 's%export\([[:blank:]]*\)PYTHONPATH=\(.*\):\$[{]\?PYTHONPATH[}]\?%exportp\1PYTHONPATH \2%g' ${INSTALL_WORK}/_tmp2 > ${INSTALL_WORK}/_tmp1 2>/dev/null sed -e 's%export\([[:blank:]]*\)LD_RUN_PATH=\$[{]\?LD_RUN_PATH[}]\?:\(.*\)%exporta\1LD_RUN_PATH \2%g' -e 's%export\([[:blank:]]*\)LD_RUN_PATH=\(.*\):\$[{]\?LD_RUN_PATH[}]\?%exportp\1LD_RUN_PATH \2%g' ${INSTALL_WORK}/_tmp1 > ${INSTALL_WORK}/_tmp2 + +# Setting "/usr/X11R6/lib" path in LD_LIBRARY_PATH for the libGL.so.1 file +#if test `uname -m` = "x86_64" ; then +#echo '# Setting /usr/X11R6/lib64 path in LD_LIBRARY_PATH for the libGL.so.1 file' >> ${INSTALL_WORK}/_tmp2 +#echo 'export LD_LIBRARY_PATH=/usr/X11R6/lib64:${LD_LIBRARY_PATH}' >> ${INSTALL_WORK}/_tmp2 +#else +#echo '# Setting /usr/X11R6/lib path in LD_LIBRARY_PATH for the libGL.so.1 file' >> ${INSTALL_WORK}/_tmp2 +#echo 'export LD_LIBRARY_PATH=/usr/X11R6/lib:${LD_LIBRARY_PATH}' >> ${INSTALL_WORK}/_tmp2 +#fi + cat ${INSTALL_WORK}/_tmp2 >> ${install_work}/_$SHRC # 5. Create a salome.csh file from salome.sh by replacing export by setenv, etc. @@ -287,50 +380,75 @@ cat ${INSTALL_WORK}/_tmp1 >> ${install_work}/$CSHRC sed -e 's%export \([[:alnum:]_[:blank:]]*\)\=%setenv \1 %g' ${INSTALL_WORK}/_tmp2 > ${INSTALL_WORK}/_tmp1 2>/dev/null sed -e 's%exporta \([[:alnum:]_[:blank:]]*\)%setenva \1%g' ${INSTALL_WORK}/_tmp1 > ${INSTALL_WORK}/_tmp2 2>/dev/null sed -e 's%exportp \([[:alnum:]_[:blank:]]*\)%setenvp \1%g' ${INSTALL_WORK}/_tmp2 > ${INSTALL_WORK}/_tmp1 2>/dev/null -sed -e 's%if \[ -n "\${ENV_FOR_LAUNCH}" \] ; then%if ( ${?ENV_FOR_LAUNCH} ) then%g' ${INSTALL_WORK}/_tmp1 > ${INSTALL_WORK}/_tmp2 2>/dev/null -sed -e 's%if \[ "\${ENV_FOR_LAUNCH}" == "1" \] ; then%if ( "\${ENV_FOR_LAUNCH}" == "1" ) then%g' ${INSTALL_WORK}/_tmp2 > ${INSTALL_WORK}/_tmp1 2>/dev/null -sed -e 's%^\([[:blank:]]*\)fi\([[:blank:]]*\)$%\1endif\2%g' ${INSTALL_WORK}/_tmp1 > ${INSTALL_WORK}/_tmp2 2>/dev/null -cat ${INSTALL_WORK}/_tmp2 >> ${install_work}/_$CSHRC 2>/dev/null +sed -e 's%if \[ -n "\${PYTHONPATH}" \] ; then%if ( ${?PYTHONPATH} ) then%g' ${INSTALL_WORK}/_tmp1 > ${INSTALL_WORK}/_tmp2 2>/dev/null +sed -e 's%if \[ -n "\${ENV_FOR_LAUNCH}" \] ; then%if ( ${?ENV_FOR_LAUNCH} ) then%g' ${INSTALL_WORK}/_tmp2 > ${INSTALL_WORK}/_tmp1 2>/dev/null +sed -e 's%if \[ "\${ENV_FOR_LAUNCH}" == "1" \] ; then%if ( "\${ENV_FOR_LAUNCH}" == "1" ) then%g' ${INSTALL_WORK}/_tmp1 > ${INSTALL_WORK}/_tmp2 2>/dev/null +sed -e 's%^\([[:blank:]]*\)fi\([[:blank:]]*\)$%\1endif\2%g' ${INSTALL_WORK}/_tmp2 > ${INSTALL_WORK}/_tmp1 2>/dev/null +sed -e 's%var.sh%var.csh%g' ${INSTALL_WORK}/_tmp1 > ${INSTALL_WORK}/_tmp2 2>/dev/null +sed -e 's%if \[ -e "\${LICENSE_FILE}" \] ; then%if ( -e ${LICENSE_FILE} ) then%g' ${INSTALL_WORK}/_tmp2 > ${INSTALL_WORK}/_tmp1 2>/dev/null + +cat ${INSTALL_WORK}/_tmp1 >> ${install_work}/_$CSHRC 2>/dev/null rm -f ${INSTALL_WORK}/_tmp1 ${INSTALL_WORK}/_tmp2 -if [ $# -eq 4 ] ; then - product_dir=$4 +if [ $# -eq 5 ] ; then + product_dir=$5 if [ -e ${product_dir} ] ; then - cp -f ${install_work}/_$SHRC ${product_dir}/$SHRC - cp -f ${install_work}/_$CSHRC ${product_dir}/$CSHRC + test -e ${product_dir}/$SHRC && mv ${product_dir}/$SHRC ${product_dir}/${SHRC}_`date +%F_%T` + cp ${install_work}/_$SHRC ${product_dir}/$SHRC + test -e ${product_dir}/$CSHRC && mv ${product_dir}/$CSHRC ${product_dir}/${CSHRC}_`date +%F_%T` + cp ${install_work}/_$CSHRC ${product_dir}/$CSHRC fi fi sed -e 's%setenv ENV_FOR_LAUNCH 1%setenv ENV_FOR_LAUNCH 0%' ${install_work}/_$CSHRC > ${install_root}/env_build.csh sed -e 's%export ENV_FOR_LAUNCH=1%export ENV_FOR_LAUNCH=0%' ${install_work}/_$SHRC > ${install_root}/env_build.sh + cp -f ${install_work}/_$CSHRC ${install_root}/env_products.csh cp -f ${install_work}/_$SHRC ${install_root}/env_products.sh + rm -f ${install_work}/_$SHRC ${install_work}/_$CSHRC -### !!! copying build.csh script +### !!! copying build.csh and build.sh scripts if [ -e ./build.csh ]; then cp -f ./build.csh ${install_root} fi +if [ -e ./build.sh ]; then + cp -f ./build.sh ${install_root} +fi +### !!! copying release notes +for p in `ls ../` ; do + export pdf=`echo ${p} | sed s/[.]/" "/g | awk '{print $2}'` + if [ "${pdf}" = "pdf" ]; then + export RN=$p + if [ ! -e ${install_root}/${RN} ]; then + cp -f ../${RN} ${install_root} + fi + fi +done + } #try use already existing product try_existing() { -product_dir=$1; install_root=$2; install_work=$3; product_sequence="$4"; product_type=$5 +product_dir=$1; install_root=$2; install_work=$3; +product_sequence="$4"; installed_products="$5"; product_type=$6 env_file=${product_dir}/env_${product_type}.sh if [ -f ${env_file} ] ; then - cp -f ${env_file} ${install_work} - make_env ${install_root} ${install_work} "${product_sequence}" + cp -f ${env_file} ${install_work}/_env_${product_type}.sh + make_env ${install_root} ${install_work} "${product_sequence}" "${installed_products}" source ${install_work}/$SHRC check_version if [ $? -eq 0 ] ; then - if [ -d ${product_dir} ] && [ -w ${product_dir} ] ; then - #makedir ${product_dir} - print_env - return 0 - fi + return 0 fi fi -return 1; +echo ${product_type} | grep -q '_src$' +if [ $? -eq 1 ] ; then + print_env_bin +else + print_env_src +fi +return 0 } #check existance of lib passed as first parameter @@ -358,7 +476,7 @@ find_in_path(){ file=$1; shift; path=$* for i in `echo ${path} | sed -e"s%:% %g"` ; do - ret=`find $i -name $file 2>/dev/null` + ret=`find $i -name $file -maxdepth 1 2>/dev/null` if [ -n "$ret" ] ; then ret=`echo $ret | sed -e"s%/\$file$%%g"` echo $ret @@ -391,6 +509,38 @@ fi return $to_tail } +where_gcc(){ +maj_ver=`echo $1 | awk -F. '{if(NF>0) print $1; else print 0}'` +min_ver=`echo $1 | awk -F. '{if(NF>1) print $2; else print 0}'` +rel_ver=`echo $1 | awk -F. '{if(NF>2) print $3; else print 0}'` +let ver=$maj_ver*10000+$min_ver*100+$rel_ver +newer="" +newerver=0 +for i in `echo ${PATH}:/usr/bin:/usr/local/bin | sed -e"s%:% %g"` ; do + ret=`find $i -name gcc -maxdepth 1 2>/dev/null` + if [ -n "$ret" ] ; then + maj_ver=`$ret -dumpversion | awk -F. '{if(NF>0) print $1; else print 0}'` + min_ver=`$ret -dumpversion | awk -F. '{if(NF>1) print $2; else print 0}'` + rel_ver=`$ret -dumpversion | awk -F. '{if(NF>2) print $3; else print 0}'` + let ver1=$maj_ver*10000+$min_ver*100+$rel_ver + if [ $ver1 -eq $ver ] ; then + ret=`echo $ret | sed -e"s%/gcc$%%g"` + echo $ret + return 0 + fi + if [ $ver1 -gt $ver ] && [ $ver1 -gt $newerver ] ; then + let newerver=$ver1 + newer=`echo $ret | sed -e"s%/gcc$%%g"` + fi + fi +done +if [ -n "$newer" ] ; then + echo $newer + return 0 +fi +return 1 +} + where_tcl(){ if test -z "${TCLHOME}"; then TCLHOME=/usr @@ -437,80 +587,155 @@ else fi } +where_dps(){ +if test -f /usr/X11R6/include/DPS/dpsconfig.h ; then + echo "/usr/X11R6" + return 0 +fi +if test -f /usr/include/DPS/dpsconfig.h ; then + echo "/usr" + return 0 +fi +echo "" +return 1 +} + +where_gl_includes(){ +for d in /usr/X11R6/include /usr/include ; do + if [ -d ${d}/GL ] && [ -f ${d}/GL/gl.h ] ; then + echo "$d" + return 0 + fi +done +echo "" +return 1 +} + +where_gl_libs(){ +# search libGL.so* file and correct libGL.la in the same directory +for d in /usr/X11R6/lib64 /usr/lib64 /usr/X11R6/lib /usr/lib ; do + if [ "`ls ${d}/libGL.so* 2>/dev/null`" ] && [ -f ${d}/libGL.la ]; then + libdir=`grep "libdir=" ${d}/libGL.la | sed -e "s%libdir='\(.*\)'%\1%" -e "s%/*$%%g"` + if [ "$libdir" == "$d" ] ; then + echo "$d" + return 0 + fi + fi +done +# search libGL.la file and check if this file is correct +for d in /usr/X11R6/lib64 /usr/lib64 /usr/X11R6/lib /usr/lib ; do + if [ -f ${d}/libGL.la ] ; then + libdir=`grep "libdir=" ${d}/libGL.la | sed -e "s%libdir='\(.*\)'%\1%"` + if [ "`ls $libdir/libGL.so* 2>/dev/null`" ] ; then + echo "$d" + return 0 + fi + fi +done +# then search libGL.so* file +for d in /usr/X11R6/lib64 /usr/lib64 /usr/X11R6/lib /usr/lib ; do + if [ "`ls ${d}/libGL.so* 2>/dev/null`" ] ; then + echo "$d" + return 0 + fi +done +echo "" +return 1 +} + modif_la_files(){ ldir=$1 if [ -z "$ldir" ] || [ ! -d "$ldir" ]; then return 1; fi srcdir=`pwd` -SALOME_MODULES="`env | awk -F_ '/[[:alnum:]]*_ROOT_DIR/ { print $1 }'`" +#SALOME_MODULES="`env | awk -F_ '/[[:alnum:]]*_ROOT_DIR/ { print $1 }'`" +SALOME_MODULES="`env | awk -F_ '/[a-zA-Z0-9]*_ROOT_DIR/ { print $1 }'`" cd $ldir -la_files=`find . -name "*.la" -maxdepth 1` +ldir=`pwd` +la_files=`find . -name "*.la"` for l in X ${la_files}; do if [ "$l" != "X" ] ; then + d=`dirname $l` l=`basename $l` + cd $ldir; cd $d # 1. process salome modules dependencies + for mod in $SALOME_MODULES; do moddir=`printenv ${mod}_ROOT_DIR` if [ -n "${moddir}" ] ; then #echo $l $mod $moddir - sed -e "s%-L[^[:space:]]*${mod}[^[:space:]]*/lib/salome%-L${moddir}/lib/salome%g" $l > _$l - mv -f _$l $l +# sed -e "s%[[:space:]]\(-L\)\?[^[:space:]]*${mod}[^[:space:]/]*/\(lib\|lib64\)% \1${moddir}/${myldir}%g" $l > $l"_" +# sed -e "s%[[:space:]]\(-L\)\?[^[:space:]]*${mod}[^[:space:]/]*/lib% \1${moddir}/lib%g" $l > $l"_" + sed -e "s%[[:space:]]\(-L\)\?[^[:space:]]*${mod}[^[:space:]/]*/lib% \1${moddir}/lib%g" \ + -e "s%^libdir='[^[:space:]]*${mod}[^[:space:]]*/\(lib.*\)'%libdir='${moddir}/\1'%g" $l > $l"_" + mv -f $l"_" $l fi done + # 2. process CAS.CADE dependencies casdir=`printenv CASROOT`/lib if [ ! -d ${casdir} ] ; then casdir=`printenv CASROOT`/Linux/lib ; fi if [ ! -d ${casdir} ] ; then casdir=`printenv CASROOT`/lin/lib ; fi if [ -n "${CASROOT}" ] && [ -d "${casdir}" ] ; then # echo $l $CASROOT $casdir - sed -e "s%-L[^[:space:]]*\(OCT\|CAS\)[^[:space:]]*%-L${casdir}%g" $l > _$l - mv -f _$l $l + sed -e "s%[[:space:]]\(-L\)\?[^[:space:]]*\(OCT\|CAS\)[^[:space:]/]*/Linux/lib% \1${casdir}%g" \ + -e "s%[[:space:]]\(-L\)\?[^[:space:]]*\(OCT\|CAS\)[^[:space:]/]*/lin/lib% \1${casdir}%g" \ + -e "s%[[:space:]]\(-L\)\?[^[:space:]]*\(OCT\|CAS\)[^[:space:]/]*/lib% \1${casdir}%g" $l > $l"_" + mv -f $l"_" $l fi # 3. process omniORB dependencies omnidir=`printenv OMNIORBDIR`/lib/i586_linux_2.0_glibc2.1 if [ ! -d ${omnidir} ] ; then omnidir=`printenv OMNIORBDIR`/lib ; fi if [ -n "${OMNIORBDIR}" ] && [ -d "${omnidir}" ] ; then # echo $l $OMNIORBDIR $omnidir - sed -e "s%-L[^[:space:]]*omni[^[:space:]]*%-L${omnidir}%g" $l > _$l - mv -f _$l $l + sed -e "s%-L[^[:space:]]*omni[^[:space:]]*%-L${omnidir}%g" \ + -e "s%-R[^[:space:]]*omni[^[:space:]]*%-R${omnidir}%g" $l > $l"_" + mv -f $l"_" $l fi # 4. process VTK dependencies - vtkdir=`printenv VTKHOME`/lib/vtk - if [ -n "${VTKHOME}" ] && [ -d "${vtkdir}" ] ; then + if test `uname -m` = "x86_64" ; then + vtkdir=`printenv VTKHOME`/lib64/vtk-5.0 + vtkldir=`printenv VTKHOME`/lib64 + else + vtkdir=`printenv VTKHOME`/lib/vtk-5.0 + vtkldir=`printenv VTKHOME`/lib + fi + if [ -n "${VTKHOME}" ] && [ -d "${vtkdir}" ] && [ -d "${vtkldir}" ] ; then # echo $l $VTKHOME $vtkdir - sed -e "s%-L[^[:space:]]*VTK[^[:space:]]*/lib/vtk%-L${vtkdir}%g" $l > _$l - mv -f _$l $l + sed -e "s%-L[^[:space:]]*VTK[^[:space:]]*/\(lib\|lib64\)/vtk\-5\.0%-L${vtkdir}%g" \ + -e "s%-L[^[:space:]]*VTK[^[:space:]]*/\(lib\|lib64\)%-L${vtkldir}%g" $l > $l"_" + mv -f $l"_" $l fi # 5. process HDF dependencies hdfdir=`printenv HDF5HOME`/lib if [ -n "${HDF5HOME}" ] && [ -d "${hdfdir}" ] ; then # echo $l $HDF5HOME $hdfdir - sed -e "s%-L[^[:space:]]*hdf[^[:space:]]*/lib%-L${hdfdir}%g" $l > _$l - mv -f _$l $l + sed -e "s%[[:space:]]\(-L\)\?[^[:space:]]*hdf[^[:space:]/]*/lib% \1${hdfdir}%g" $l > $l"_" + mv -f $l"_" $l fi # 6. process MED dependencies meddir=`printenv MED2HOME`/lib if [ -n "${MED2HOME}" ] && [ -d "${meddir}" ] ; then # echo $l $MED2HOME $meddir - sed -e "s%-L[^[:space:]]*med[^[:space:]]*/lib%-L${meddir}%g" $l > _$l - mv -f _$l $l + sed -e "s%[[:space:]]\(-L\)\?[^[:space:]]*med[^[:space:]/]*/lib% \1${meddir}%g" $l > $l"_" + mv -f $l"_" $l fi # 7. process qwt dependencies - qwtdir=`printenv QWTHOME`/lib - if [ -n "${QWTHOME}" ] && [ -d "${qwtdir}" ] ; then - # echo $l $QWTHOME $qwtdir - sed -e "s%-L[^[:space:]]*qwt[^[:space:]]*/lib%-L${qwtdir}%g" $l > _$l - mv -f _$l $l + qwtdir=`find_in_path libqwt.so ${LD_LIBRARY_PATH}` + if [ -n "${qwtdir}" ] && [ -d "${qwtdir}" ] ; then + # echo $l $qwtdir + sed -e "s%[[:space:]]\(-L\)\?[^[:space:]]*qwt[^[:space:]/]*/lib% \1${qwtdir}%g" $l > $l"_" + mv -f $l"_" $l fi # 8. process qt dependencies qtdir=`printenv QTDIR`/lib if [ -n "${QTDIR}" ] && [ -d "${qtdir}" ] ; then # echo $l $QTDIR $qtdir - sed -e "s%-L[^[:space:]]*qt[^[:space:]]*/lib%-L${qtdir}%g" $l > _$l - mv -f _$l $l + sed -e "s%[[:space:]]\(-L\)\?[^[:space:]]*qt[^[:space:]/]*/lib% \1${qtdir}%g" $l > $l"_" + mv -f $l"_" $l fi # 9. process python dependencies where_python=`which python` # e.g. /usr/bin/python @@ -519,33 +744,74 @@ if [ "$l" != "X" ] ; then where_python=`dirname $where_python` # --> /usr python_version=`python -c "import sys; print sys.version[:3]"` # echo $l $where_python $python_version - sed -e "s%-L[^[:space:]]*python[0-9]\.[0-9]\([^[:space:]]*\)%-L${where_python}/lib/python${python_version}\1%g" $l > _$l - mv -f _$l $l + sed -e "s%-L[^[:space:]]*python[0-9]\.[0-9]\([^[:space:]]*\)%-L${where_python}/lib/python${python_version}\1%g" $l > $l"_" + mv -f $l"_" $l fi # 10. process sip dependencies sipdir=`find_in_path sip.so ${LD_LIBRARY_PATH}` if [ -n "${sipdir}" ] && [ -d "${sipdir}" ] ; then # echo $l $sipdir - sed -e "s%-L[^[:space:]]*sip[^[:space:]]*%-L${sipdir}%g" $l > _$l - mv -f _$l $l + sed -e "s%-L[^[:space:]]*sip[^[:space:]]*%-L${sipdir}%g" $l > $l"_" + mv -f $l"_" $l fi # 11. process PyQt dependencies pyqtdir=`find_in_path qt.so ${LD_LIBRARY_PATH}` if [ -n "${pyqtdir}" ] && [ -d "${pyqtdir}" ] ; then # echo $l $pyqtdir - sed -e "s%-L[^[:space:]]*PyQt[^[:space:]]*%-L${pyqtdir}%g" $l > _$l - mv -f _$l $l + sed -e "s%-L[^[:space:]]*PyQt[^[:space:]]*%-L${pyqtdir}%g" $l > $l"_" + mv -f $l"_" $l fi # 12. process tcl/tk dependencies tcldir=`printenv TCLHOME`/lib if [ -n "${tcldir}" ] && [ -d "${tcldir}" ] ; then # echo $l $TCLHOME $tcldir - sed -e "s%-L[^[:space:]]*tcltk[^[:space:]]*/lib%-L${tcldir}%g" $l > _$l - mv -f _$l $l + sed -e "s%-L[^[:space:]]*tcltk[^[:space:]]*/lib%-L${tcldir}%g" $l > $l"_" + mv -f $l"_" $l + fi + # 13. process boost dependencies + boostdir=`printenv BOOSTDIR`/lib + if [ -n "${boostdir}" ] && [ -d "${boostdir}" ] ; then + # echo $l $BOOSTDIR $boostdir + sed -e "s%-L[^[:space:]]*boost[^[:space:]]*/lib%-L${boostdir}%g" $l > $l"_" + mv -f $l"_" $l fi - # 13. modify libdir - sed -e "s%^libdir='\(.*\)'%libdir='${PRODUCT_DIR}/lib/salome'%g" $l > _$l - mv -f _$l $l + +# # 14. modify libdir +# #sed -e "s%^libdir='\(.*\)'%libdir='${PRODUCT_DIR}/lib/salome'%g" $l > $l"_" +# mod=`basename $ldir | awk -F_ '{print $1}'` +# moddir=`printenv ${mod}_ROOT_DIR` +# sed -e "s%^libdir='[^[:space:]]*${mod}[^[:space:]]*/\(lib.*\)'%libdir='${moddir}/\1'%g" $l > $l"_" +# mv -f $l"_" $l + + # 15. process libxml dependencies + libxmldir=`printenv LIBXML_DIR`/lib + if [ ! -d ${libxmldir} ] ; then libxmldir=`printenv LIBXML_DIR`/lib ; fi + sed -e "s%\(.*\)\([[:space:]].*/lib/libxml2.la[[:space:]]\)\(.*\)%\1 ${libxmldir}/libxml2.la \3%g" \ + -e "s%-L[^[:space:]]*libxml2[^[:space:]]*/lib%-L${libxmldir}%g" $l > $l"_" + mv -f $l"_" $l + + # 16. process metis dependencies + metisdir=`printenv METISDIR` + if [ ! -d ${metisdir} ] ; then metisdir=`printenv METISDIR` ; fi + sed -e "s%-L[^[:space:]]*metis[^[:space:]]*%-L${metisdir}%g" $l > $l"_" + mv -f $l"_" $l + + # 3. process scotch dependencies + scotchdir=`printenv SCOTCHDIR`/bin + if [ ! -d ${scotchdir} ] ; then scotchdir=`printenv SCOTCHDIR`/bin ; fi + sed -e "s%-L[^[:space:]]*scotch[^[:space:]]*/bin%-L${scotchdir}%g" $l > $l"_" + mv -f $l"_" $l + + # 4. process libGL.la dependencies + if test `uname -m` = "x86_64" ; then + libGLpath=/usr/lib64/libGL.la + else + libGLpath=/usr/lib/libGL.la + fi + sed -e "s%$libGLpath%""%g" $l > $l"_" + mv -f $l"_" $l + + fi done