aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'sci-misc/elmer-gui/elmer-gui-9999.ebuild')
-rw-r--r--sci-misc/elmer-gui/elmer-gui-9999.ebuild153
1 files changed, 153 insertions, 0 deletions
diff --git a/sci-misc/elmer-gui/elmer-gui-9999.ebuild b/sci-misc/elmer-gui/elmer-gui-9999.ebuild
new file mode 100644
index 000000000..2d006c9ff
--- /dev/null
+++ b/sci-misc/elmer-gui/elmer-gui-9999.ebuild
@@ -0,0 +1,153 @@
+# Copyright 1999-2007 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: $
+
+EAPI="4"
+
+inherit autotools eutils qt4-r2 subversion python versionator
+
+ELMER_ROOT="elmerfem"
+MY_PN=ElmerGUI
+
+DESCRIPTION="Elmer is a collection of finite element programs, libraries, and visualization tools, New Elmer pre-processor"
+HOMEPAGE="http://www.csc.fi/english/pages/elmer"
+#SRC_URI="http://elmerfem.svn.sourceforge.net/viewvc/${ELMER_ROOT}/release/${PV}/${MY_PN}/?view=tar -> ${P}.tar.gz"
+SRC_URI=""
+RESTRICT="mirror"
+ESVN_REPO_URI="https://elmerfem.svn.sourceforge.net/svnroot/elmerfem/trunk/${MY_PN}"
+ESVN_PROJECT="${MY_PN}"
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~hppa ~ppc ~ppc64 ~sparc ~x86"
+IUSE="debug bundled_netgen matc opencascade python qwt vtk"
+
+REQUIRED_USE="opencascade? ( vtk )"
+
+DEPEND="=sci-libs/elmer-eio-${PV}
+ !bundled_netgen? ( sci-mathematics/netgen )
+ virtual/glu
+ || ( =sci-misc/elmer-post-${PV}
+ >=sci-libs/vtk-5.0.0[qt4,python?]
+ )
+ matc? ( =sci-libs/matc-${PV} )
+ vtk? ( >=sci-libs/vtk-5.0.0[qt4,python?] )
+ opencascade? ( >=sci-libs/opencascade-6.3 )
+ python? ( <=dev-python/pythonqt-1.1 )
+ x11-libs/qwt:5
+ || ( >=x11-libs/qt-core-4.3:4
+ ( x11-libs/qt-core:5
+ x11-libs/qt-xml:5
+ )
+ )
+ >=x11-libs/qt-opengl-4.3
+ >=x11-libs/qt-script-4.3"
+RDEPEND="${DEPEND}"
+
+src_prepare() {
+ # Do not build bundled matc and PythonQt
+ sed -i \
+ -e 's/matc//' \
+ -e 's/PythonQt//' \
+ ${MY_PN}.pro || die
+
+ # Ideally we would avoid buildling thirdparty code
+ # and use a separate package but this currently fails
+ # to build. ElmerGui provides its own patched version of
+ # NetGen. Currently considering backporting them to
+ # sci-mathematics/netgen
+ if use !bundled_netgen; then
+ sed -i 's/netgen//' ${MY_PN}.pro || die
+ sed -i \
+ -e "s:INCLUDEPATH += ../netgen/libsrc/interface:INCLUDEPATH += ${EPREFIX}/usr/include:g" \
+ -e "s:LIBPATH += ../netgen/ngcore:LIBPATH += ${EPREFIX}/usr/$(get_libdir):g" \
+ -e "s:LIBS += -lng:LIBS += -lnglib:g" \
+ Application/Application.pro || die
+
+ eerror "${PN} currently fails to build against sci-mathematics/netgen."
+ fi
+
+ # Fix install path
+ sed -i \
+ -e 's|unix: ELMER_HOME = /usr/local|unix: ELMER_HOME = /usr|g' \
+ ${MY_PN}.pri || die
+
+ if use amd64; then
+ sed -i 's/32/64/' ${MY_PN}.pri || die
+ fi
+
+ if use !qwt; then
+ # QWT is activated by default, disable
+ sed -i 's/DEFINES += EG_QWT//' ${MY_PN}.pri || die
+ else
+ # Detect x11-libs/qwt version and fix paths
+ local QWT_VER=`echo $(best_version "x11-libs/qwt") | sed 's:x11-libs/qwt-::'`
+ local QWT_MAJOR=$(get_major_version ${QWT_VER})
+ local QWT_MAJOR=5
+
+ if [[ ${QWT_MAJOR} -lt 6 ]]; then
+ local QWT_LIBS=-lqwt
+ else
+ local QWT_LIBS=-lqwt${QWT_MAJOR}
+ fi
+
+ local QWT_INCLUDEPATH=${EPREFIX}/usr/include/qwt${QWT_MAJOR}
+ local QWT_LIBPATH=${EPREFIX}/usr/$(get_libdir)
+
+ sed -i \
+ -e "s:QWT_INCLUDEPATH.*:QWT_INCLUDEPATH = ${QWT_INCLUDEPATH}:g" \
+ -e "s:QWT_LIBPATH.*:QWT_LIBPATH = ${QWT_LIBPATH}:g" \
+ -e "s:QWT_LIBS.*:QWT_LIBS = ${QWT_LIBS}:g" \
+ ${MY_PN}.pri || die
+ fi
+
+ if use !vtk; then
+ # VTK is activated by default, disable
+ sed -i 's/DEFINES += EG_VTK//' ${MY_PN}.pri || die
+ else
+ # Fix paths
+ local VTK_VER=`echo ${VTK_DIR} | cut -d/ -f4`
+ sed -i \
+ -e "s:VTK_INCLUDEPATH.*:VTK_INCLUDEPATH = ${EPREFIX}/usr/include/${VTK_VER}:g" \
+ -e "s:VTK_LIBPATH.*:VTK_LIBPATH = ${VTK_DIR}:g" \
+ ${MY_PN}.pri || die
+ fi
+
+ if use !matc; then
+ sed -i 's/DEFINES += EG_MATC//' ${MY_PN}.pri || die
+ else
+ sed -i "s:LIBPATH += ../matc/lib:LIBPATH += ${EPREFIX}/usr/$(get_libdir):g" Application/Application.pro || die
+ fi
+
+ if use !opencascade; then
+ # Opencascade is activated by default, disable
+ sed -i 's/DEFINES += EG_OCC//' ${MY_PN}.pri || die
+ else
+ # Fix paths, depend on portage version of opencascade
+ sed -i \
+ -e "s:OCC_INCLUDEPATH.*:OCC_INCLUDEPATH = ${CASROOT}/inc:g" \
+ -e "s:OCC_LIBPATH.*:OCC_LIBPATH = ${CASROOT}/$(get_libdir):g" \
+ ${MY_PN}.pri || die
+ fi
+
+ if use python; then
+ # Fix paths
+ sed -i \
+ -e 's/DEFINES -= EG_PYTHON/DEFINES += EG_PYTHON/g' \
+ -e "s:PY_INCLUDEPATH.*:PY_INCLUDEPATH = $(python_get_includedir):g" \
+ -e "s:PY_LIBPATH.*:PY_LIBPATH = $(python_get_libdir):g" \
+ -e "s:PY_LIBS.*:PY_LIBS = $(python_get_library -l):g" \
+ ${MY_PN}.pri || die
+
+ # Fix paths and invert Python(Qt) linking order to work with --Wl,--as-needed
+ sed -i \
+ -e "s:INCLUDEPATH += $${PY_INCLUDEPATH} ../PythonQt/src:${EPREFIX}/usr/include/PythonQt:g" \
+ -e "s:LIBPATH += $${PY_LIBPATH} ../PythonQt/lib:${EPREFIX}/usr/$(get_libdir):g" \
+ -e "s:LIBS += $${PY_LIBS} -lPythonQt:LIBS += -lPythonQt $${PY_LIBS}:" \
+ Application/Application.pro || die
+ fi
+}
+
+src_configure() {
+ eqmake4 "${S}" ./${MY_PN}.pro
+}