# Author : Vadim SANDLER, Open CASCADE SAS (vadim.sandler@opencascade.com)
# Project : SALOME
# Module : Installation Wizard
-# Copyright : 2002-2013 CEA
+# Copyright : 2002-2015 CEA
#
# This script is the part of the SALOME installation procedure.
#
#
# Open CASCADE Technology version
#
-OCCT_VERSION=6.5.5
+VERSION_OCCT=6.8.0
check_version()
{
-if [ -z "$CASROOT" ]; then
+if [ -z "${CAS_ROOT_DIR}" ]; then
return 1
fi
-check_lib_version ${CASROOT}/inc/Standard_Version.hxx
+check_lib_version ${CAS_ROOT_DIR}/inc/Standard_Version.hxx
if [ "$?" -ne "0" ] ; then
return 1
fi
-ver_major=`grep "#define OCC_VERSION_MAJOR" ${CASROOT}/inc/Standard_Version.hxx | awk '{print $3}'`
-ver_minor=`grep "#define OCC_VERSION_MINOR" ${CASROOT}/inc/Standard_Version.hxx | awk '{print $3}'`
-ver_maint=`grep "#define OCC_VERSION_MAINTENANCE" ${CASROOT}/inc/Standard_Version.hxx | awk '{print $3}'`
-ver="$ver_major.$ver_minor.$ver_maint"
-if [ "$ver" == "${OCCT_VERSION}" ] ; then
+ver_major=`grep "#define OCC_VERSION_MAJOR" ${CAS_ROOT_DIR}/inc/Standard_Version.hxx | awk '{print $3}'`
+ver_minor=`grep "#define OCC_VERSION_MINOR" ${CAS_ROOT_DIR}/inc/Standard_Version.hxx | awk '{print $3}'`
+ver_maint=`grep "#define OCC_VERSION_MAINTENANCE" ${CAS_ROOT_DIR}/inc/Standard_Version.hxx | awk '{print $3}'`
+ver="${ver_major}.${ver_minor}.${ver_maint}"
+if [ "${ver}" = "${VERSION_OCCT}" ] ; then
return 0
fi
return 1
print_env_bin()
{
cat > ${INSTALL_WORK}/env_${PRODUCT_TYPE}.sh <<EOF
-#$DELIM ${PRODUCT_TYPE} $DELIM
-export CASROOT=\${INST_ROOT}/${SINGLE_DIR:-${PRODUCT}}
-export CAS_ROOT_DIR=\${CASROOT}
-export PATH=\${CASROOT}/bin:\${PATH}
-export LD_LIBRARY_PATH=\${CASROOT}/lib:\${CASROOT}/lin/lib:\${LD_LIBRARY_PATH}
+#${DELIM} ${PRODUCT_TYPE} ${DELIM}
+export CAS_ROOT_DIR=\${INST_ROOT}/${SINGLE_DIR:-${PRODUCT}}
+export PATH=\${CAS_ROOT_DIR}/bin:\${PATH}
+export LD_LIBRARY_PATH=\${CAS_ROOT_DIR}/lib:\${CAS_ROOT_DIR}/lin/lib:\${LD_LIBRARY_PATH}
# Variable for Foundation Classes :
-export CSF_UnitsLexicon=\${CASROOT}/src/UnitsAPI/Lexi_Expr.dat
-export CSF_UnitsDefinition=\${CASROOT}/src/UnitsAPI/Units.dat
+export CSF_UnitsLexicon=\${CAS_ROOT_DIR}/src/UnitsAPI/Lexi_Expr.dat
+export CSF_UnitsDefinition=\${CAS_ROOT_DIR}/src/UnitsAPI/Units.dat
# Variable for DataExchange :
-export CSF_SHMessage=\${CASROOT}/src/SHMessage
-export CSF_XSMessage=\${CASROOT}/src/XSMessage
+export CSF_SHMessage=\${CAS_ROOT_DIR}/src/SHMessage
+export CSF_XSMessage=\${CAS_ROOT_DIR}/src/XSMessage
# Variable for Font :
-export CSF_MDTVFontDirectory=\${CASROOT}/src/FontMFT
-export CSF_MDTVTexturesDirectory=\${CASROOT}/src/Textures
+export CSF_MDTVFontDirectory=\${CAS_ROOT_DIR}/src/FontMFT
+export CSF_MDTVTexturesDirectory=\${CAS_ROOT_DIR}/src/Textures
# Activation of OCCT Kernel multithreading :
export MMGT_REENTRANT=1
+# this variable only needed for DRAWEXE
+export CASROOT=\${CAS_ROOT_DIR}
##
EOF
(test -w ${PRODUCT_DIR} && cp ${INSTALL_WORK}/env_${PRODUCT_TYPE}.sh ${PRODUCT_DIR})
print_env_src()
{
cat > ${INSTALL_WORK}/env_${PRODUCT_TYPE}_src.sh <<EOF
-#$DELIM ${PRODUCT_TYPE}_src $DELIM
+#${DELIM} ${PRODUCT_TYPE}_src ${DELIM}
# nothing to do
##
EOF
install_source()
{
make_env ${INST_ROOT} ${INSTALL_WORK} "${PRODUCT_SEQUENCE}" "${INSTALL_PRODUCTS}" ${PRODUCT_TYPE}_src
-source ${INSTALL_WORK}/$SHRC
+source ${INSTALL_WORK}/${SHRC}
# unpack
check_jb tar xfz ${SOURCE_DIR}/${PRODUCT}.tar.gz -C ${INST_ROOT}
local patch_sources=1
-local patch_config=1
+local patch_config=0
# apply patch for sources (if there's any)
if [ "${patch_sources}" = "1" ] ; then
( cd ${PRODUCT_SRC_DIR} && sed -i "s%AM_C_PROTOTYPES%#AM_C_PROTOTYPES%g" configure.ac )
fi
+if [ "${SALOME_IW_COMPSIZE}" = "1" ] ; then
+ du -sk ${PRODUCT_SRC_DIR} > ${INST_ROOT}/${PRODUCT_TYPE}.src.size
+fi
+
# to generate environment scripts
try_preinstalled
}
# build_configure
-echo " +++++++++++ build_configure"
-
check_job ${PRODUCT_DIR}/BUILD_CONFIGURE.LOG ./build_configure
# configure
-echo " +++++++++++ configure"
-
-flags=""
+flags="--prefix=${PRODUCT_DIR}"
# ... tcl/tk options
if [ "${TCLHOME}" != "" ] ; then
- flags="$flags --with-tcl=${TCLHOME}/lib"
- flags="$flags --with-tk=${TCLHOME}/lib"
+ flags="${flags} --with-tcl=${TCLHOME}/lib"
+ flags="${flags} --with-tk=${TCLHOME}/lib"
fi
# ... tbb options
-if [ "${TBBHOME}" != "" ] ; then
- flags="$flags --with-tbb-include=${TBBHOME}/include"
+if [ "${TBB_ROOT_DIR}" != "" ] ; then
+ flags="${flags} --with-tbb-include=${TBB_ROOT_DIR}/include"
if test `uname -m` = "x86_64" ; then
- flags="$flags --with-tbb-library=${TBBHOME}/lib/intel64/cc4.1.0_libc2.4_kernel2.6.16.21"
+ flags="${flags} --with-tbb-library=${TBB_ROOT_DIR}/lib/intel64/cc4.1.0_libc2.4_kernel2.6.16.21"
else
- flags="$flags --with-tbb-library=${TBBHOME}/lib/ia32/cc4.1.0_libc2.4_kernel2.6.16.21"
+ flags="${flags} --with-tbb-library=${TBB_ROOT_DIR}/lib/ia32/cc4.1.0_libc2.4_kernel2.6.16.21"
fi
fi
# ... freetype options
-if [ "{FREETYPEDIR}" != "" ] ; then
- flags="$flags --with-freetype=${FREETYPEDIR}"
-fi
-# ... ftgl options
-if [ "{FTGLDIR}" != "" ] ; then
- flags="$flags --with-ftgl=${FTGLDIR}"
+if [ "{FREETYPE_ROOT_DIR}" != "" ] ; then
+ flags="${flags} --with-freetype=${FREETYPE_ROOT_DIR}"
fi
# ... freeimage options
-if [ "{FREEIMAGEDIR}" != "" ] ; then
- flags="$flags --with-freeimage=${FREEIMAGEDIR}"
+if [ "{FREEIMAGE_ROOT_DIR}" != "" ] ; then
+ flags="${flags} --with-freeimage=${FREEIMAGE_ROOT_DIR}"
fi
# ... gl2ps options
-if [ "{GL2PSHOME}" != "" ] ; then
- flags="$flags --with-gl2ps=${GL2PSHOME}"
+if [ "{GL2PS_ROOT_DIR}" != "" ] ; then
+ flags="${flags} --with-gl2ps=${GL2PS_ROOT_DIR}"
fi
# other options
-flags="$flags --disable-debug --enable-production"
+flags="${flags} --disable-debug --enable-production"
-check_job ${PRODUCT_DIR}/CONFIGURE.LOG ./configure --prefix=${PRODUCT_DIR} ${flags}
+cat > ${PRODUCT_DIR}/CONFIGURE.LOG <<EOF
+-------------------
+Used options: ${flags}
+-------------------
+EOF
+check_job ${PRODUCT_DIR}/CONFIGURE.LOG ./configure ${flags}
# make
-echo " +++++++++++ make"
-
-GCC=`which gcc`
-cat >> ${PRODUCT_DIR}/MAKE.LOG <<EOF
-used gcc=$GCC
-EOF
check_job ${PRODUCT_DIR}/MAKE.LOG make -j4 install
# fix libGL dependencies
-echo " +++++++++++ fix libGL dependencies"
-cd ${PRODUCT_DIR}/lib && fix_gl_libs
-#du -sk ${PRODUCT_SRC_DIR} > ${PRODUCT_DIR}/size.log
-cd ${PRODUCT_DIR};
+( cd ${PRODUCT_DIR}/lib && fix_gl_libs )
+
+cd ${PRODUCT_DIR}
+
+if [ "${SALOME_IW_COMPSIZE}" = "1" ] ; then
+ du -sk ${PRODUCT_SRC_DIR} > ${INST_ROOT}/${PRODUCT_TYPE}.build.size
+ du -sk ${PRODUCT_DIR} > ${INST_ROOT}/${PRODUCT_TYPE}.bin.size
+fi
# remove sources and temporary files after building
echo "${INSTALL_PRODUCTS}" | grep -q "PatchForOpenCascade"
-if [ $? -eq 1 ] && [ ${REMOVE_SRC_TMP} == "TRUE" ] ; then
+if [ $? -eq 1 ] && [ ${REMOVE_SRC_TMP} = "TRUE" ] ; then
test -d ${PRODUCT_SRC_DIR} && rm -fr ${PRODUCT_SRC_DIR}
fi
install_binary()
{
make_env ${INST_ROOT} ${INSTALL_WORK} "${PRODUCT_SEQUENCE}" "${INSTALL_PRODUCTS}" ${PRODUCT_TYPE}
-source ${INSTALL_WORK}/$SHRC
+source ${INSTALL_WORK}/${SHRC}
# create a product directory
test -z ${SINGLE_DIR} && makedir ${PRODUCT_DIR} || mkdir -p ${PRODUCT_DIR}
check_jb tar xfz ${SOURCE_DIR}/${PRODUCT}.tar.gz -C ${PRODUCT_DIR}
# modify *.la files
-ldir=${PRODUCT_DIR}/lib
-if [ ! -d $ldir ]; then ldir=${PRODUCT_DIR}/Linux/lib; fi
-if [ ! -d $ldir ]; then ldir=${PRODUCT_DIR}/lin/lib; fi
-cd $ldir
-# 1. set libdir correctly, correct dependencies
+ldir=${PRODUCT_DIR}/lib
+if [ ! -d ${ldir} ]; then ldir=${PRODUCT_DIR}/Linux/lib; fi
+if [ ! -d ${ldir} ]; then ldir=${PRODUCT_DIR}/lin/lib; fi
tcldir=`printenv TCLHOME`
-freetypedir=`printenv FREETYPEDIR`
-ftgldir=`printenv FTGLDIR`
-gl2psdir=`printenv GL2PSHOME`
-freeimagedir=`printenv FREEIMAGEDIR`
-tbbbasedir=`printenv TBBHOME`
-
+freetypedir=`printenv FREETYPE_ROOT_DIR`
+gl2psdir=`printenv GL2PS_ROOT_DIR`
+freeimagedir=`printenv FREEIMAGE_ROOT_DIR`
+tbbbasedir=`printenv TBB_ROOT_DIR`
TBBKERNEL='cc4.1.0_libc2.4_kernel2.6.16.21'
if test `uname -m` = "x86_64" ; then
- export TBBMODE="intel64/$TBBKERNEL"
+ export TBBMODE="intel64/${TBBKERNEL}"
else
- export TBBMODE="ia32/$TBBKERNEL"
+ export TBBMODE="ia32/${TBBKERNEL}"
fi
+tbbdir=${tbbbasedir}/lib/${TBBMODE}
-tbbdir=${tbbbasedir}/lib/$TBBMODE
+cd ${ldir}
+# 1. set libdir correctly, correct dependencies
for l in X `find . -name "*.la"`; do
- if [ "$l" != "X" ] ; then
- l=`basename $l`
- libdir=`grep -e "libdir=.*" $l | sed -e "s/libdir=[\'|\"]\(.*\)[\'|\"]/\1/g"`
- sed -e "s%${libdir}%${ldir}%g" $l > _$l
- mv -f _$l $l
+ if [ "${l}" != "X" ] ; then
+ l=`basename ${l}`
+ libdir=`grep -e "libdir=.*" ${l} | sed -e "s/libdir=[\'|\"]\(.*\)[\'|\"]/\1/g"`
+ sed -i "s%${libdir}%${ldir}%g" ${l}
if [ -n "${tcldir}" ] && [ -d "${tcldir}" ] ; then
- sed -e "s%-L[^[:space:]]*tcltk[^[:space:]]*/lib%-L${tcldir}/lib%g" $l > _$l
- mv -f _$l $l
+ sed -i "s%-L[^[:space:]]*tcltk[^[:space:]]*/lib%-L${tcldir}/lib%g" ${l}
fi
- chmod a+x $l
if [ -n "${freetypedir}" ] && [ -d "${freetypedir}" ] ; then
- sed -e "s%-L[^[:space:]]*/freetype[^[:space:]]*/lib%-L${freetypedir}/lib%g" \
- -e "s%[^[:space:]]*/freetype[^[:space:]]*/lib/libfreetype.la%-lfreetype%g" $l > _$l
- mv -f _$l $l
+ sed -i "s%-L[^[:space:]]*/freetype[^[:space:]]*/lib%-L${freetypedir}/lib%g;s%[^[:space:]]*/freetype[^[:space:]]*/lib/libfreetype.la%-lfreetype%g" ${l}
fi
- chmod a+x $l
- if [ -n "${ftgldir}" ] && [ -d "${ftgldir}" ] ; then
- sed -e "s%\(.*\)\([[:space:]].*-L.*/ftgl-[0-9]\.[0-9]\.[0-9]/lib[[:space:]]\)\(.*\)%\1 -L${ftgldir}/lib \3%g" \
- -e 's%\(.*\)\([[:space:]].*libftgl.la\)\(.*\)%\1 -lftgl \3%g' $l > _$l
- mv -f _$l $l
- fi
- chmod a+x $l
if [ -n "${gl2psdir}" ] && [ -d "${gl2psdir}" ] ; then
- sed -e "s%\(.*\)\([[:space:]].*-L.*/gl2ps-[0-9]\.[0-9]\.[0-9]/lib[[:space:]]\)\(.*\)%\1 -L${gl2psdir}/lib \3%g" $l > _$l
- mv -f _$l $l
+ sed -i "s%\(.*\)\([[:space:]].*-L.*/gl2ps-[0-9]\.[0-9]\.[0-9]/lib[[:space:]]\)\(.*\)%\1 -L${gl2psdir}/lib \3%g" ${l}
fi
- chmod a+x $l
if [ -n "${freeimagedir}" ] && [ -d "${freeimagedir}" ] ; then
- sed -e "s%\(.*\)\([[:space:]].*-L.*/freeimage-[0-9]\.[0-9]\.[0-9]/lib[[:space:]]\)\(.*\)%\1 -L${freeimagedir}/lib \3%g" $l > _$l
- mv -f _$l $l
+ sed -i "s%\(.*\)\([[:space:]].*-L.*/freeimage-[0-9]\.[0-9]\.[0-9]/lib[[:space:]]\)\(.*\)%\1 -L${freeimagedir}/lib \3%g" ${l}
fi
- chmod a+x $l
if [ -n "${freeimagedir}" ] && [ -d "${freeimagedir}" ] ; then
- sed -e "s%\(.*\)\([[:space:]].*-L.*/freeimage-[0-9]\.[0-9][0-9]\.[0-9]/lib[[:space:]]\)\(.*\)%\1 -L${freeimagedir}/lib \3%g" $l > _$l
- mv -f _$l $l
+ sed -i "s%\(.*\)\([[:space:]].*-L.*/freeimage-[0-9]\.[0-9][0-9]\.[0-9]/lib[[:space:]]\)\(.*\)%\1 -L${freeimagedir}/lib \3%g" ${l}
fi
- chmod a+x $l
if [ -n "${tbbdir}" ] && [ -d "${tbbdir}" ] ; then
- sed -e "s%\(.*\)\([[:space:]].*-L.*/tbb[^[:space:]]*/lib[^[:space:]]*\)\(.*\)%\1 -L${tbbdir} \3%g" $l > _$l
- mv -f _$l $l
+ sed -i "s%\(.*\)\([[:space:]].*-L.*/tbb[^[:space:]]*/lib[^[:space:]]*\)\(.*\)%\1 -L${tbbdir} \3%g" ${l}
fi
- chmod a+x $l
fi
done
# 2. fix libGL dependencies
-
-cd $ldir
gllibdir="`where_gl_libs`"
-if [ "$gllibdir" != "" ] ; then
+if [ "${gllibdir}" != "" ] ; then
if [ -f ${gllibdir}/libGL.la ] ; then
libdir=`grep "libdir=" ${gllibdir}/libGL.la | sed -e "s%libdir='\(.*\)'%\1%"`
- if [ "`ls $libdir/libGL.so* 2>/dev/null`" ] ; then
+ if [ "`ls ${libdir}/libGL.so* 2>/dev/null`" ] ; then
str_to_replace="${gllibdir}/libGL.la"
fi
-fi
- if [ "$str_to_replace" == "" ] ; then
+ fi
+ if [ "${str_to_replace}" = "" ] ; then
str_to_replace="-L${gllibdir} -lGL"
fi
-
- sed -e "s%-lGL\b%%g" \
- -e "s%[^[:space:]\']*libGL.la[[:space:]]%%g" \
- -e "s%^dependency_libs='\(.*\)%dependency_libs='${str_to_replace} \1%" \
- libTKOpenGl.la > libTKOpenGl.la.new
- mv -f libTKOpenGl.la.new libTKOpenGl.la
+ sed -i "s%-lGL\b%%g;s%[^[:space:]\']*libGL.la[[:space:]]%%g;s%^dependency_libs='\(.*\)%dependency_libs='${str_to_replace} \1%" libTKOpenGl.la
fi
# to generate environment script for sources
export INSTALL_PRODUCTS=$7;
shift
REMOVE_SRC_TMP=$8;
-test $# == 10 && shift && SINGLE_DIR=$9
-export PRODUCT="OCCT-${OCCT_VERSION}"
+test $# = 10 && shift && SINGLE_DIR=$9
+export PRODUCT="OCCT-${VERSION_OCCT}"
export PRODUCT_DIR=${INST_ROOT}/${SINGLE_DIR:-${PRODUCT}}
export PRODUCT_WORK=${INSTALL_WORK}/${PRODUCT}
export PRODUCT_SRC_DIR=${INST_ROOT}/${PRODUCT}_SRC
source ./common.sh
-$PROCEDURE
+${PROCEDURE}