Salome HOME
Provide sip 4.2.1 support (native, sources, binaries) for Mandriva 2006.0
authorvsr <vsr@opencascade.com>
Fri, 19 May 2006 10:13:17 +0000 (10:13 +0000)
committervsr <vsr@opencascade.com>
Fri, 19 May 2006 10:13:17 +0000 (10:13 +0000)
config_Mandriva_2006.0.xml
config_files/sip-4.1.sh
config_files/sip-4.2.1.sh [new file with mode: 0755]
src/SALOME_InstallWizard.cxx

index 7095cf2759b0ef0409e98681585ccbaf6ccc6fe1..a23fd5c0e708b0b53323d5f72d73ca52dab254ac 100755 (executable)
           temporarydiskspace="48"
           script="msg2qm.sh"/>
   <product name="Sip"
-           version="4.1" 
+           version="4.2.1" 
            description="C++ to Python bindings generation tool"
            install="use native"
-          supported="use native"
+          supported="use native,install sources,install binaries"
           disable="false"
           dependancies="gcc,Python,Qt"
-          installdiskspace="352"
-          temporarydiskspace="2168"
-          script="sip-4.1.sh"/>
+          installdiskspace="295"
+          temporarydiskspace="2057"
+          script="sip-4.2.1.sh"/>
   <product name="PyQt"
            version="3.13" 
            description="Python bindings for Qt library"
           supported="use native,install sources,install binaries"
           disable="false"
           dependancies="gcc"
-          installdiskspace="4229"
-          temporarydiskspace="47460"
+          installdiskspace="4425"
+          temporarydiskspace="51085"
           script="hdf5-1.6.4.sh"/>
   <product name="Med"
            version="2.2.3" 
index 05aa4da4629111749f23c9e4fdb68b40f6fdd289..f6f57ef62fbe82e093666b41aed9d927516bd367 100755 (executable)
@@ -3,8 +3,12 @@
 check_version()
 {
 if [ -n "${SIPDIR}" ]; then
-    sip_ver=`${SIPDIR}/sip -V | awk '{print $1}'`
-    if [ "$sip_ver" == "4.1" ]; then
+    ver=`${SIPDIR}/sip -V | awk '{print $1}'`
+    maj_ver=`echo $ver | awk -F. '{if(NF>0) print $1; else print 0}' | sed -e 's/^\([0-9]*\).*$/\1/'`
+    min_ver=`echo $ver | awk -F. '{if(NF>1) print $2; else print 0}' | sed -e 's/^\([0-9]*\).*$/\1/'`
+    rel_ver=`echo $ver | awk -F. '{if(NF>2) print $3; else print 0}' | sed -e 's/^\([0-9]*\).*$/\1/'`
+    let ver=$maj_ver*10000+$min_ver*100+$rel_ver
+    if [ $ver -eq 40100 ] ; then
        return 0
     fi
 fi
@@ -26,33 +30,36 @@ make_env ${INSTALL_ROOT} ${INSTALL_WORK} "${PRODUCT_SEQUENCE}"
 }
 
 # looks for the native product and collects it's environment (used by make_env())
+# we need version 4.1 or newer
 try_native(){
-sipdir="`find_in_path sip ${PATH}`"
-if [ -z "${sipdir}" ] ; then
-    sipdir="`find_in_path sip /usr/bin`"
-fi
+sipdir="`find_in_path sip ${PATH}:/usr/bin`"
 if [ -n "${sipdir}" ] ; then
     python_version="`python -c 'import sys; print sys.version[:3]'`"
-    sippython="`find_in_path sip.so ${PYTHONPATH}`"
-    if [ -z "${sippython}" ] ; then
-        sippython="`find_in_path sip.so /usr/lib/python${python_version}/site-packages`"
-    fi
+    sippython="`find_in_path sip.so ${PYTHONPATH}:/usr/lib/python${python_version}/site-packages`"
     if [ -n "${sippython}" ]; then
-        tmp="${sipdir} ${sipdir} \${PATH} ${PATH}";
-        path=`sort_path ${tmp}`
-        tmp="${sippython} ${sippython} \${LD_LIBRARY_PATH} ${LD_LIBRARY_PATH}";
-        ld_library_path=`sort_path ${tmp}`
-        tmp="${sippython} ${sippython} \${PYTHONPATH} ${PYTHONPATH}";
-        pythonpath=`sort_path ${tmp}`
-        cat > ${INSTALL_WORK}/env_${PRODUCT_TYPE}.sh <<EOF
+       ver=`${sipdir}/sip -V | awk '{print $1}'`
+       maj_ver=`echo $ver | awk -F. '{if(NF>0) print $1; else print 0}' | sed -e 's/^\([0-9]*\).*$/\1/'`
+       min_ver=`echo $ver | awk -F. '{if(NF>1) print $2; else print 0}' | sed -e 's/^\([0-9]*\).*$/\1/'`
+       rel_ver=`echo $ver | awk -F. '{if(NF>2) print $3; else print 0}' | sed -e 's/^\([0-9]*\).*$/\1/'`
+       let ver=$maj_ver*10000+$min_ver*100+$rel_ver
+       # minimal required version is 4.1
+       if [ $ver -ge 40100 ] ; then
+           tmp="${sipdir} ${sipdir} \${PATH} ${PATH}";
+           path=`sort_path ${tmp}`
+           tmp="${sippython} ${sippython} \${LD_LIBRARY_PATH} ${LD_LIBRARY_PATH}";
+           ld_library_path=`sort_path ${tmp}`
+           tmp="${sippython} ${sippython} \${PYTHONPATH} ${PYTHONPATH}";
+           pythonpath=`sort_path ${tmp}`
+           cat > ${INSTALL_WORK}/env_${PRODUCT_TYPE}.sh <<EOF
 #$DELIM ${PRODUCT_TYPE} $DELIM
 export PATH=${path}
 export PYTHONPATH=${pythonpath}
 export LD_LIBRARY_PATH=${ld_library_path}
 ##
 EOF
-        make_env ${INSTALL_ROOT} ${INSTALL_WORK} "${PRODUCT_SEQUENCE}"
-        return 0
+           make_env ${INSTALL_ROOT} ${INSTALL_WORK} "${PRODUCT_SEQUENCE}"
+           return 0
+       fi
     fi
 fi
 return 1
diff --git a/config_files/sip-4.2.1.sh b/config_files/sip-4.2.1.sh
new file mode 100755 (executable)
index 0000000..f315d73
--- /dev/null
@@ -0,0 +1,135 @@
+#!/bin/sh
+
+check_version()
+{
+if [ -n "${SIPDIR}" ]; then
+    ver=`${SIPDIR}/sip -V | awk '{print $1}'`
+    maj_ver=`echo $ver | awk -F. '{if(NF>0) print $1; else print 0}' | sed -e 's/^\([0-9]*\).*$/\1/'`
+    min_ver=`echo $ver | awk -F. '{if(NF>1) print $2; else print 0}' | sed -e 's/^\([0-9]*\).*$/\1/'`
+    rel_ver=`echo $ver | awk -F. '{if(NF>2) print $3; else print 0}' | sed -e 's/^\([0-9]*\).*$/\1/'`
+    let ver=$maj_ver*10000+$min_ver*100+$rel_ver
+    if [ $ver -eq 40201 ] ; then
+       return 0
+    fi
+fi
+return 1
+}
+
+print_env()
+{
+cat > ${INSTALL_WORK}/env_${PRODUCT_TYPE}.sh <<EOF 
+#$DELIM ${PRODUCT_TYPE} $DELIM
+export SIPDIR=\${INSTALL_ROOT}/${PRODUCT}
+export PATH=\${SIPDIR}:\${PATH}
+export PYTHONPATH=\${SIPDIR}:\${PYTHONPATH}
+export LD_LIBRARY_PATH=\${SIPDIR}:\${LD_LIBRARY_PATH}
+##
+EOF
+(test -w ${PRODUCT_DIR} && cp ${INSTALL_WORK}/env_${PRODUCT_TYPE}.sh ${PRODUCT_DIR})
+make_env ${INSTALL_ROOT} ${INSTALL_WORK} "${PRODUCT_SEQUENCE}"
+}
+
+# looks for the native product and collects it's environment (used by make_env())
+# we need version 4.1 or newer
+try_native(){
+sipdir="`find_in_path sip ${PATH}:/usr/bin`"
+if [ -n "${sipdir}" ] ; then
+    python_version="`python -c 'import sys; print sys.version[:3]'`"
+    sippython="`find_in_path sip.so ${PYTHONPATH}:/usr/lib/python${python_version}/site-packages`"
+    if [ -n "${sippython}" ]; then
+       ver=`${sipdir}/sip -V | awk '{print $1}'`
+       maj_ver=`echo $ver | awk -F. '{if(NF>0) print $1; else print 0}' | sed -e 's/^\([0-9]*\).*$/\1/'`
+       min_ver=`echo $ver | awk -F. '{if(NF>1) print $2; else print 0}' | sed -e 's/^\([0-9]*\).*$/\1/'`
+       rel_ver=`echo $ver | awk -F. '{if(NF>2) print $3; else print 0}' | sed -e 's/^\([0-9]*\).*$/\1/'`
+       let ver=$maj_ver*10000+$min_ver*100+$rel_ver
+       # minimal required version is 4.1
+       if [ $ver -ge 40100 ] ; then
+           tmp="${sipdir} ${sipdir} \${PATH} ${PATH}";
+           path=`sort_path ${tmp}`
+           tmp="${sippython} ${sippython} \${LD_LIBRARY_PATH} ${LD_LIBRARY_PATH}";
+           ld_library_path=`sort_path ${tmp}`
+           tmp="${sippython} ${sippython} \${PYTHONPATH} ${PYTHONPATH}";
+           pythonpath=`sort_path ${tmp}`
+           cat > ${INSTALL_WORK}/env_${PRODUCT_TYPE}.sh <<EOF
+#$DELIM ${PRODUCT_TYPE} $DELIM
+export PATH=${path}
+export PYTHONPATH=${pythonpath}
+export LD_LIBRARY_PATH=${ld_library_path}
+##
+EOF
+           make_env ${INSTALL_ROOT} ${INSTALL_WORK} "${PRODUCT_SEQUENCE}"
+           return 0
+       fi
+    fi
+fi
+return 1
+}
+
+try_preinstalled(){
+try_existing ${PRODUCT_DIR} ${INSTALL_ROOT} ${INSTALL_WORK} "${PRODUCT_SEQUENCE}" ${PRODUCT_TYPE}
+return $?
+}
+
+install_source()
+{
+make_env ${INSTALL_ROOT} ${INSTALL_WORK} "${PRODUCT_SEQUENCE}" ${PRODUCT_TYPE}
+source ${INSTALL_WORK}/$SHRC
+
+makedir ${PRODUCT_DIR}
+
+check_jb tar xfz ${SOURCE_DIR}/sip-4.2.1.tar.gz -C ${INSTALL_WORK}
+cd ${PRODUCT_WORK}
+
+check_job ${PRODUCT_DIR}/CONFIGURE.LOG \
+    python configure.py -b ${PRODUCT_DIR} -d ${PRODUCT_DIR} -e ${PRODUCT_DIR} -v ${PRODUCT_DIR} -l qt-mt 
+GCC=`which gcc`
+cat >> ${PRODUCT_DIR}/MAKE.LOG <<EOF
+used gcc=$GCC
+EOF
+check_job ${PRODUCT_DIR}/MAKE.LOG make
+check_job ${PRODUCT_DIR}/INSTALL.LOG make install
+
+#du -sk ${PRODUCT_WORK} > ${PRODUCT_DIR}/size.log
+cd ${PRODUCT_DIR}; rm -fr ${PRODUCT_WORK}
+print_env
+}
+
+install_binary()
+{
+make_env ${INSTALL_ROOT} ${INSTALL_WORK} "${PRODUCT_SEQUENCE}" ${PRODUCT_TYPE}
+source ${INSTALL_WORK}/$SHRC
+
+check_jb tar xfz ${SOURCE_DIR}/sip-4.2.1.tar.gz -C ${INSTALL_ROOT}
+
+# modify sipconfig.py file
+cd ${PRODUCT_DIR}
+python_version=`python -V 2>&1 | awk '{print $2}' | awk -F. '{printf("0x%02d%02d%02d",$1,$2,$3)}'`
+sed -e "s%\('default_sip_dir':[[:space:]]*\).*%\1'${PRODUCT_DIR}',%g" sipconfig.py > sipconfig.py.1
+sed -e "s%\('sip_bin':[[:space:]]*\).*%\1'${PRODUCT_DIR}/sip',%g" sipconfig.py.1 > sipconfig.py
+sed -e "s%\('sip_inc_dir':[[:space:]]*\).*%\1'${PRODUCT_DIR}',%g" sipconfig.py > sipconfig.py.1
+sed -e "s%\('sip_mod_dir':[[:space:]]*\).*%\1'${PRODUCT_DIR}',%g" sipconfig.py.1 > sipconfig.py
+sed -e "s%\('qt_dir':[[:space:]]*\).*%\1'${QTDIR}',%g" sipconfig.py > sipconfig.py.1
+sed -e "s%\('qt_inc_dir':[[:space:]]*\).*%\1'${QTDIR}/include',%g" sipconfig.py.1 > sipconfig.py
+sed -e "s%\('qt_lib_dir':[[:space:]]*\).*%\1'${QTDIR}/lib',%g" sipconfig.py > sipconfig.py.1
+sed -e "s%\('INCDIR_QT':[[:space:]]*\).*%\1'${QTDIR}/include',%g" sipconfig.py.1 > sipconfig.py
+sed -e "s%\('LIBDIR_QT':[[:space:]]*\).*%\1'${QTDIR}/lib',%g" sipconfig.py > sipconfig.py.1
+sed -e "s%\('MOC':[[:space:]]*\).*%\1'${QTDIR}/bin/moc',%g" sipconfig.py.1 > sipconfig.py
+sed -e "s%\('py_inc_dir':[[:space:]]*\).*%\1'${PYTHONHOME}/include/python${PYTHON_VERSION}',%g" sipconfig.py > sipconfig.py.1
+sed -e "s%\('py_lib_dir':[[:space:]]*\).*%\1'${PYTHONHOME}/lib/python${PYTHON_VERSION}/config',%g" sipconfig.py.1 > sipconfig.py
+sed -e "s%\('py_version':[[:space:]]*\).*%\1${python_version},%g" sipconfig.py > sipconfig.py.1
+mv sipconfig.py.1 sipconfig.py
+
+print_env
+}
+
+export PROCEDURE=$1;
+export INSTALL_WORK=$2;
+export SOURCE_DIR=$3;
+export INSTALL_ROOT=$4;
+export PRODUCT_SEQUENCE=$5;
+if [ $# == 6 ] ; then export PRODUCT_TYPE=$6 ; else export PRODUCT_TYPE="sip" ; fi
+export PRODUCT="sip-4.2.1"
+export PRODUCT_DIR=${INSTALL_ROOT}/${PRODUCT}
+export PRODUCT_WORK=${INSTALL_WORK}/${PRODUCT}
+source ./common.sh
+$PROCEDURE 
index 657acd66f952bc8d8849b9735533930bc1ae4c5b..6551b4720c7c25de9a9e8cd6ec688d77b599f6ee 100644 (file)
@@ -1513,7 +1513,7 @@ void SALOME_InstallWizard::launchScript()
     QCheckListItem* item = mapIter.key();
     Dependancies dep = mapIter.data();
     QString depproducts = QUOTE( DefineDependeces(productsMap) ); 
-    if ( dep.pickUpEnvironment() ) {
+    if ( !productsView->iSNone( item ) && dep.pickUpEnvironment() ) {
       ___MESSAGE___( "... for " << dep.getName() );
       QString script;
       script += "cd " + QUOTE( QFileInfo( QDir::cleanDirPath( "./config_files/" ) ).absFilePath() ) + "; ";