summaryrefslogtreecommitdiff
path: root/eclass/kde4-base.eclass
diff options
context:
space:
mode:
Diffstat (limited to 'eclass/kde4-base.eclass')
-rw-r--r--eclass/kde4-base.eclass568
1 files changed, 568 insertions, 0 deletions
diff --git a/eclass/kde4-base.eclass b/eclass/kde4-base.eclass
new file mode 100644
index 00000000000..92333bcf081
--- /dev/null
+++ b/eclass/kde4-base.eclass
@@ -0,0 +1,568 @@
+# Copyright 2007-2008 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/eclass/kde4-base.eclass,v 1.6 2008/03/26 20:39:05 zlin Exp $
+
+# @ECLASS: kde4-base.eclass
+# @MAINTAINER:
+# kde@gentoo.org
+# @BLURB: This eclass provides functions for kde 4.0 ebuilds
+# @DESCRIPTION:
+# The kde4-base.eclass provides support for building KDE4 monolithic ebuilds
+# and KDE4 applications.
+#
+# NOTE: This eclass uses the SLOT dependencies from EAPI="1" or compatible,
+# hence you must define EAPI="1" in the ebuild, before inheriting any eclasses.
+
+inherit base eutils multilib cmake-utils kde4-functions
+
+EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_test src_install pkg_postinst pkg_postrm
+
+kde4-base_set_qt_dependencies() {
+ local qt qtcore qtgui qt3support qtdepend qtopengldepend
+
+ # use dependencies
+ case "${EAPI}" in
+ kdebuild-1)
+ qt="[accessibility][dbus][gif][jpeg][png][qt3support][ssl][zlib]"
+ qtcore="[qt3support][ssl]"
+ qtgui="[accessibility][dbus]"
+ qt3support="[accessibility]"
+ case "${OPENGL_REQUIRED}" in
+ always)
+ qt="${qt}[opengl]"
+ ;;
+ optional)
+ qt="${qt}[opengl?]"
+ ;;
+ esac
+ ;;
+ esac
+
+ # split qt
+ qtdepend="
+ x11-libs/qt-core:4${qtcore}
+ x11-libs/qt-gui:4${qtgui}
+ x11-libs/qt-qt3support:4${qt3support}
+ x11-libs/qt-script:4
+ x11-libs/qt-svg:4
+ x11-libs/qt-test:4"
+ qtopengldepend="x11-libs/qt-opengl:4"
+
+ # allow monolithic qt for PV < 4.1
+ case "${PV}" in
+ scm|9999*|4.1*|4.0.8*|4.0.9*) : ;;
+ *)
+ qtdepend="|| ( ( ${qtdepend} ) >=x11-libs/qt-4.3.3:4${qt} )"
+ qtopengldepend="|| ( ${qtopengldepend} >=x11-libs/qt-4.3.3:4 )"
+ ;;
+ esac
+
+ # opengl dependencies
+ case "${OPENGL_REQUIRED}" in
+ always)
+ qtdepend="${qtdepend}
+ ${qtopengldepend}"
+ ;;
+ optional)
+ IUSE="${IUSE} opengl"
+ qtdepend="${qtdepend}
+ opengl? ( ${qtopengldepend} )"
+ ;;
+ *)
+ OPENGL_REQUIRED="never"
+ ;;
+ esac
+
+ COMMONDEPEND="${COMMONDEPEND} ${qtdepend}"
+}
+kde4-base_set_qt_dependencies
+
+DEPEND="${DEPEND} ${COMMONDEPEND}
+ >=dev-util/cmake-2.4.7-r1
+ dev-util/pkgconfig
+ x11-libs/libXt
+ x11-proto/xf86vidmodeproto"
+RDEPEND="${RDEPEND} ${COMMONDEPEND}"
+
+# @ECLASS-VARIABLE: OPENGL_REQUIRED
+# @DESCRIPTION:
+# Is qt-opengl required? Possible values are 'always', 'optional' and 'never'.
+# This variable must be set before inheriting any eclasses. Defaults to 'never'.
+OPENGL_REQUIRED="${OPENGL_REQUIRED:-never}"
+
+# @ECLASS-VARIABLE: CPPUNIT_REQUIRED
+# @DESCRIPTION:
+# Is cppunit required for tests? Possible values are 'always', 'optional' and 'never'.
+# This variable must be set before inheriting any eclasses. Defaults to 'never'.
+CPPUNIT_REQUIRED="${CPPUNIT_REQUIRED:-never}"
+
+case "${CPPUNIT_REQUIRED}" in
+ always)
+ DEPEND="${DEPEND} dev-util/cppunit"
+ ;;
+ optional)
+ IUSE="${IUSE} test"
+ DEPEND="${DEPEND}
+ test? ( dev-util/cppunit )"
+ ;;
+ *)
+ CPPUNIT_REQUIRED="never"
+ ;;
+esac
+
+# @ECLASS-VARIABLE: NEED_KDE
+# @DESCRIPTION:
+# This variable sets the version of KDE4 which will be used by the eclass.
+# This variable must be set by the ebuild, for all categories except for "kde-base".
+# For kde-base packages, if it is not set by the ebuild,
+# it's assumed that the required KDE4 version is the latest, non-live, available.
+#
+# @CODE
+# Acceptable values are:
+# - latest - Use latest version in the portage tree
+# Default for kde-base ebuilds. Banned for ebuilds not part of kde or koffice.
+# - svn - Use svn release (live ebuilds)
+# - :SLOT - Use any version in the SLOT specified in the NEED_KDE value.
+# - VERSION_NUMBER - Use the minimum KDE4 version specified in the NEED_KDE value.
+# - VERSION_NUMBER:SLOT - Use the minimum KDE4 version and the SLOT specified in the NEED_KDE value.
+# - none - Let the ebuild handle SLOT, kde dependencies, KDEDIR, ...
+# @CODE
+#
+# Note: There is no default NEED_KDE for ebuilds not in kde-base or part of
+# koffice, so you must set it explicitly in the ebuild, in all other cases.
+if [[ -z ${NEED_KDE} ]]; then
+ if [[ -n ${KDEBASE} ]]; then
+ NEED_KDE="latest"
+ else
+ die "kde4-base.eclass inherited but NEED_KDE not defined - broken ebuild"
+ fi
+fi
+export NEED_KDE
+
+case ${NEED_KDE} in
+ latest)
+ # Should only be used by 'kde-base'-ebuilds
+ if [[ "${KDEBASE}" == "kde-base" ]]; then
+ case ${PV} in
+ 3.9*) _kdedir="3.9" ;;
+ 4.0.8*| 4.0.9* | 4.1*) _kdedir="4.1"
+ _pv="-${PV}:4.1" ;;
+ 4.0*) _kdedir="4.0"
+ _pv="-${PV}:4.0" ;;
+ *) die "NEED_KDE=latest not supported for PV=${PV}" ;;
+ esac
+ _operator=">="
+ else
+ case ${PV} in
+ 3.9*) _kdedir="3.9" ;;
+ 4.0.8*| 4.0.9* | 4.1*) _kdedir="4.1" ;;
+ 4.0*) _kdedir="4.0" ;;
+ *) die "NEED_KDE=latest not supported for PV=${PV}" ;;
+ esac
+ fi
+ ;;
+ scm|svn|9999*|:kde-svn)
+ _kdedir="svn"
+ _pv=":kde-svn"
+ export NEED_KDE="svn"
+ ;;
+ *:kde-svn)
+ _kdedir="svn"
+ _operator=">="
+ _pv="-${NEED_KDE}"
+ export NEED_KDE="svn"
+ ;;
+ # The ebuild handles dependencies, KDEDIR, SLOT.
+ none)
+ :
+ ;;
+ # NEED_KDE=":${SLOT}"
+ :kde-4)
+ _kdedir="4.0"
+ _pv="${NEED_KDE}"
+ ;;
+ :4.1)
+ _kdedir="4.1"
+ _pv="${NEED_KDE}"
+ ;;
+ # NEED_KDE="${PV}:${SLOT}"
+ *:kde-4)
+ _kdedir="4.0"
+ _operator=">="
+ _pv="-${NEED_KDE}"
+ ;;
+ *:4.1)
+ _kdedir="4.1"
+ _operator=">="
+ _pv="-${NEED_KDE}"
+ ;;
+ 4.0.8* | 4.0.9* | 4.1*)
+ _kdedir="4.1"
+ _operator=">="
+ _pv="-${NEED_KDE}:4.1"
+ ;;
+ 4.0*)
+ _kdedir="4.0"
+ _operator=">="
+ _pv="-${NEED_KDE}:kde-4"
+ ;;
+ 3.9*)
+ _kdedir="3.9"
+ _operator=">="
+ _pv="-${NEED_KDE}:kde-4"
+ ;;
+ *) die "NEED_KDE=${NEED_KDE} currently not supported."
+ ;;
+esac
+
+if [[ ${NEED_KDE} != none ]]; then
+ KDEDIR="/usr/kde/${_kdedir}"
+ KDEDIRS="/usr:/usr/local:${KDEDIR}"
+
+ if [[ -n ${KDEBASE} ]]; then
+ if [[ ${NEED_KDE} = svn ]]; then
+ SLOT="kde-svn"
+ else
+ case ${PV} in
+ 4.0.8* | 4.0.9* | 4.1*) SLOT="4.1" ;;
+ *) SLOT="kde-4" ;;
+ esac
+ fi
+ fi
+
+ # We only need to add the dependencies if ${PN} is not "kdelibs" or "kdepimlibs"
+ if [[ ${PN} != "kdelibs" ]]; then
+ DEPEND="${DEPEND}
+ ${_operator}kde-base/kdelibs${_pv}"
+ RDEPEND="${RDEPEND}
+ ${_operator}kde-base/kdelibs${_pv}"
+ if [[ ${PN} != "kdepimlibs" ]]; then
+ DEPEND="${DEPEND}
+ ${_operator}kde-base/kdepimlibs${_pv}"
+ RDEPEND="${RDEPEND}
+ ${_operator}kde-base/kdepimlibs${_pv}"
+ fi
+ fi
+
+ unset _operator _pv _kdedir
+fi
+
+# Fetch section - If the ebuild's category is not 'kde-base' and if it is not a
+# koffice ebuild, the URI should be set in the ebuild itself
+if [[ -n ${KDEBASE} ]]; then
+ if [[ -n ${KMNAME} ]]; then
+ _kmname=${KMNAME}
+ else
+ _kmname=${PN}
+ fi
+ _kmname_pv="${_kmname}-${PV}"
+ if [[ ${NEED_KDE} != "svn" ]]; then
+ case ${KDEBASE} in
+ kde-base)
+ case ${PV} in
+ 4.0.8* | 4.0.9*)
+ SRC_URI="mirror://kde/unstable/${PV}/src/${_kmname_pv}.tar.bz2" ;;
+ *) SRC_URI="mirror://kde/stable/${PV}/src/${_kmname_pv}.tar.bz2";;
+ esac
+ ;;
+ koffice)
+ SRC_URI="mirror://kde/unstable/${_kmname_pv}/src/${_kmname_pv}.tar.bz2"
+ ;;
+ esac
+ fi
+ unset _kmname _kmname_pv
+fi
+
+debug-print "${LINENO} ${ECLASS} ${FUNCNAME}: SRC_URI is ${SRC_URI}"
+debug-print "${LINENO} ${ECLASS} ${FUNCNAME}: DEPEND ${DEPEND} - before blockers"
+
+# Monolithic ebuilds should add blockers for split ebuilds in the same slot.
+# If KMNAME is not set then this is not a split package
+if [[ -n ${KDEBASE} && -z ${KMNAME} ]]; then
+ for _x in $(get-child-packages ${CATEGORY}/${PN}); do
+ DEPEND="${DEPEND} !${_x}:${SLOT}"
+ RDEPEND="${RDEPEND} !${_x}:${SLOT}"
+ done
+ unset _x
+fi
+
+debug-print "${BASH_SOURCE} ${LINENO} ${ECLASS} ${FUNCNAME}: DEPEND ${DEPEND} - after blockers"
+
+# @ECLASS-VARIABLE: PREFIX
+# @DESCRIPTION:
+# Set the installation PREFIX. All kde-base ebuilds go into the KDE4 installation directory.
+# Applications installed by the other ebuilds go into /usr/ by default, this value
+# can be superseded by defining PREFIX before inheriting kde4-base.
+if [[ -n ${KDEBASE} ]]; then
+ PREFIX=${KDEDIR}
+else
+ # if PREFIX is not defined we set it to the default value of /usr
+ PREFIX="${PREFIX:-/usr}"
+fi
+
+debug-print "${LINENO} ${ECLASS} ${FUNCNAME}: SLOT ${SLOT} - KDEDIR ${KDEDIR} - KDEDIRS ${KDEDIRS}- PREFIX ${PREFIX} - NEED_KDE ${NEED_KDE}"
+
+# @FUNCTION: kde4-base_pkg_setup
+# @DESCRIPTION:
+# Adds flags needed by all of KDE 4 to $QT4_BUILT_WITH_USE_CHECK. Uses
+# kde4-functions_check_use from kde4-functions.eclass to print appropriate
+# errors and die if any required flags listed in $QT4_BUILT_WITH_USE_CHECK or
+# $KDE4_BUILT_WITH_USE_CHECK are missing.
+kde4-base_pkg_setup() {
+ debug-print-function $FUNCNAME "$@"
+
+ case "${EAPI}" in
+ kdebuild-1)
+ [[ -n ${QT4_BUILT_WITH_USE_CHECK} || -n ${KDE4_BUILT_WITH_USE_CHECK[@]} ]] && \
+ die "built_with_use illegal in this EAPI!"
+ ;;
+ *)
+ # Make KDE4_BUILT_WITH_USE_CHECK an array if it isn't already
+ local line kde4_built_with_use_check=()
+ if [[ -n ${KDE4_BUILT_WITH_USE_CHECK[@]} && $(declare -p KDE4_BUILT_WITH_USE_CHECK) != 'declare -a '* ]]; then
+ while read line; do
+ [[ -z ${line} ]] && continue
+ kde4_built_with_use_check+=("${line}")
+ done <<< "${KDE4_BUILT_WITH_USE_CHECK}"
+ KDE4_BUILT_WITH_USE_CHECK=("${kde4_built_with_use_check[@]}")
+ fi
+
+ # KDE4 applications require qt4 compiled with USE="accessibility dbus gif jpeg png qt3support ssl zlib".
+ if has_version '<x11-libs/qt-4.4_alpha:4'; then
+ QT4_BUILT_WITH_USE_CHECK="${QT4_BUILT_WITH_USE_CHECK} accessibility dbus gif jpeg png qt3support ssl zlib"
+ else
+ KDE4_BUILT_WITH_USE_CHECK=("${KDE4_BUILT_WITH_USE_CHECK[@]}"
+ "x11-libs/qt-core qt3support ssl"
+ "x11-libs/qt-gui accessibility dbus"
+ "x11-libs/qt-qt3support accessibility")
+ fi
+
+ if has opengl ${IUSE//+} && use opengl || [[ ${OPENGL_REQUIRED} == always ]]; then
+ if has_version '<x11-libs/qt-4.4.0_alpha:4'; then
+ QT4_BUILT_WITH_USE_CHECK="${QT4_BUILT_WITH_USE_CHECK} opengl"
+ fi
+ fi
+ kde4-functions_check_use
+ ;;
+ esac
+}
+
+# @FUNCTION: kde4-base_apply_patches
+# @DESCRIPTION:
+# This function applies patches.
+#
+# If the directory ${WORKDIR}/patches/ exists, we apply all patches in that
+# directory, provided they follow this format:
+# @CODE
+# - Monolithic ebuilds, (from kde-base)
+# - $CATEGORY=kde-base:
+# Apply ${CHILD_EBUILD_NAME}-${SLOT}-*{diff,patch}
+# - $CATEGORY=!kde-base:
+# Apply ${CHILD_EBUILD_NAME}-${PV}-*{diff,patch}
+# - Split ebuilds:
+# - $CATEGORY=kde-base:
+# Apply ${PN}-${SLOT}-*{diff,patch}
+# - $CATEGORY!=kde-base:
+# Apply ${PN}-${PV}-*{diff,patch}
+# @CODE
+#
+# If ${PATCHES} is non-zero all patches in it get applied. If there is more
+# than one patch please make ${PATCHES} an array for proper quoting.
+kde4-base_apply_patches() {
+ local _patchdir _packages _p _f
+ _patchdir="${WORKDIR}/patches/"
+ if [[ -d "${_patchdir}" ]]; then
+ if is-parent-package ${CATEGORY}/${PN} ; then
+ _packages="$(get-child-packages ${CATEGORY}/${PN})"
+ _packages="${_packages//${CATEGORY}\//} ${PN}"
+ else
+ _packages="${PN}"
+ fi
+ if [[ $(declare -p PATCHES) != 'declare -a '* ]]; then
+ PATCHES=(${PATCHES})
+ fi
+ for _p in ${_packages}; do
+ for _f in "${_patchdir}"/${_p}-${PV}-*{diff,patch}; do
+ [[ -e ${_f} ]] && PATCHES+=("${_f}")
+ done
+ if [[ -n "${KDEBASE}" ]]; then
+ for _f in "${_patchdir}"/${_p}-${SLOT}-*{diff,patch}; do
+ [[ -e ${_f} ]] && PATCHES+=("${_f}")
+ done
+ fi
+ done
+ fi
+ [[ -n ${PATCHES[@]} ]] && base_src_unpack autopatch
+}
+
+# @FUNCTION: kde4-base_src_unpack
+# @DESCRIPTION:
+# This function unpacks the source tarballs for KDE4 applications.
+#
+# If no argument is passed to this function, then standard src_unpack is
+# executed. Otherwise options are passed to base_src_unpack.
+#
+# In addition it calls kde4-base_apply_patches when no arguments are passed to
+# this function.
+#
+# It also handles translations if KDE_LINGUAS is defined. See KDE_LINGUAS and
+# enable_selected_linguas() in kde4-functions.eclass(5) for further details.
+kde4-base_src_unpack() {
+ debug-print-function $FUNCNAME "$@"
+
+ [[ -z "${KDE_S}" ]] && KDE_S="${S}"
+
+ if [[ -z $* ]]; then
+ # Unpack first and deal with KDE patches after examing possible patch sets.
+ # To be picked up, patches need to conform to the guidelines stated before.
+ # Monolithic ebuilds will use the split ebuild patches.
+ [[ -d "${KDE_S}" ]] || unpack ${A}
+ kde4-base_apply_patches
+ else
+ # Call base_src_unpack, which unpacks and patches
+ # step by step transparently as defined in the ebuild.
+ base_src_unpack $*
+ fi
+
+ # Updated cmake dir
+ if [[ -d "${WORKDIR}/cmake" ]] && [[ -d "${KDE_S}/cmake" ]]; then
+ ebegin "Updating cmake/ directory..."
+ rm -rf "${KDE_S}/cmake" || die "Unable to remove old cmake/ directory"
+ ln -s "${WORKDIR}/cmake" "${KDE_S}/cmake" || die "Unable to symlink the new cmake/ directory"
+ eend 0
+ fi
+
+ # Only enable selected languages, used for KDE extragear apps.
+ if [[ -n ${KDE_LINGUAS} ]]; then
+ enable_selected_linguas
+ fi
+}
+
+# @FUNCTION: kde4-base_src_compile
+# @DESCRIPTION:
+# General function for compiling KDE4 applications.
+kde4-base_src_compile() {
+ debug-print-function ${FUNCNAME} "$@"
+
+ # Don't set KDEHOME during compile, it will cause access violations
+ unset KDEHOME
+
+ kde4-base_src_configure
+ kde4-base_src_make
+}
+
+# @FUNCTION: kde4-base_src_configure
+# @DESCRIPTION:
+# Function for configuring the build of KDE4 applications.
+kde4-base_src_configure() {
+ debug-print-function ${FUNCNAME} "$@"
+
+ # Don't set KDEHOME during compile, it will cause access violations
+ unset KDEHOME
+
+ # Final flag handling
+ if has kdeenablefinal ${IUSE//+} && use kdeenablefinal; then
+ echo "Activating enable-final flag"
+ mycmakeargs="${mycmakeargs} -DKDE4_ENABLE_FINAL=ON"
+ fi
+
+ # Enable generation of HTML handbook
+ if has htmlhandbook ${IUSE//+} && use htmlhandbook; then
+ echo "Enabling building of HTML handbook"
+ mycmakeargs="${mycmakeargs} -DKDE4_ENABLE_HTMLHANDBOOK=ON"
+ fi
+
+ # Build tests in src_test only, where we override this value
+ mycmakeargs="${mycmakeargs} -DKDE4_BUILD_TESTS=OFF"
+
+ # Set distribution name
+ [[ ${PN} == "kdelibs" ]] && mycmakeargs="${mycmakeargs} -DKDE_DISTRIBUTION_TEXT=Gentoo"
+
+ # runpath linking
+ mycmakeargs="${mycmakeargs} -DKDE4_USE_ALWAYS_FULL_RPATH=ON"
+
+ # Here we set the install prefix
+ mycmakeargs="${mycmakeargs} -DCMAKE_INSTALL_PREFIX=${PREFIX}"
+
+ # Set environment
+ QTEST_COLORED=1
+ QT_PLUGIN_PATH=${KDEDIR}/$(get_libdir)/kde4/plugins/
+
+ cmake-utils_src_configureout
+}
+
+# @FUNCTION: kde4-base_src_make
+# @DESCRIPTION:
+# Function for building KDE4 applications.
+# Options are passed to cmake-utils_src_make.
+kde4-base_src_make() {
+ debug-print-function ${FUNCNAME} "$@"
+
+ cmake-utils_src_make "$@"
+}
+
+# @FUNCTION: kde4-base_src_test
+# @DESCRIPTION:
+# Function for testing KDE4 applications.
+kde4-base_src_test() {
+ debug-print-function ${FUNCNAME} "$@"
+
+ # Override this value, set in kde4-base_src_configure()
+ mycmakeargs="${mycmakeargs} -DKDE4_BUILD_TESTS=ON"
+ cmake-utils_src_compile
+
+ cmake-utils_src_test
+}
+
+# @FUNCTION: kde4-base_src_install
+# @DESCRIPTION:
+# Function for installing KDE4 applications.
+kde4-base_src_install() {
+ debug-print-function ${FUNCNAME} "$@"
+
+ kde4-base_src_make_doc
+ cmake-utils_src_install
+}
+
+# @FUNCTION: kde4-base_src_make_doc
+# @DESCRIPTION:
+# Function for installing the documentation of KDE4 applications.
+kde4-base_src_make_doc() {
+ debug-print-function ${FUNCNAME} "$@"
+
+ local doc
+ for doc in AUTHORS ChangeLog* README* NEWS TODO; do
+ [[ -s $doc ]] && dodoc ${doc}
+ done
+
+ if [[ -z ${KMNAME} ]]; then
+ for doc in {apps,runtime,workspace,.}/*/{AUTHORS,README*}; do
+ if [[ -s $doc ]]; then
+ local doc_complete=${doc}
+ doc="${doc#*/}"
+ newdoc "$doc_complete" "${doc%/*}.${doc##*/}"
+ fi
+ done
+ fi
+
+ if [[ -n ${KDEBASE} && -d "${D}"/usr/share/doc/${PF} ]]; then
+ # work around bug #97196
+ dodir /usr/share/doc/kde && \
+ mv "${D}"/usr/share/doc/${PF} "${D}"/usr/share/doc/kde/ || \
+ die "Failed to move docs to kde/ failed."
+ fi
+}
+
+# @FUNCTION: kde4-base_pkg_postinst
+# @DESCRIPTION:
+# Function to rebuild the KDE System Configuration Cache after an application has been installed.
+kde4-base_pkg_postinst() {
+ buildsycoca
+}
+
+# @FUNCTION: kde4-base_pkg_postrm
+# @DESCRIPTION:
+# Function to rebuild the KDE System Configuration Cache after an application has been removed.
+kde4-base_pkg_postrm() {
+ buildsycoca
+}