# Copyright 1999-2016 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 # $Id$ # @ECLASS: kde5.eclass # @MAINTAINER: # kde@gentoo.org # @BLURB: Support eclass for KDE 5-related packages. # @DESCRIPTION: # The kde5.eclass provides support for building KDE 5-related packages. if [[ -z ${_KDE5_ECLASS} ]]; then _KDE5_ECLASS=1 # @ECLASS-VARIABLE: VIRTUALX_REQUIRED # @DESCRIPTION: # For proper description see virtualx.eclass manpage. # Here we redefine default value to be manual, if your package needs virtualx # for tests you should proceed with setting VIRTUALX_REQUIRED=test. : ${VIRTUALX_REQUIRED:=manual} inherit cmake-utils eutils flag-o-matic gnome2-utils kde5-functions versionator virtualx xdg if [[ ${KDE_BUILD_TYPE} = live ]]; then case ${KDE_SCM} in svn) inherit subversion ;; git) inherit git-r3 ;; esac fi EXPORT_FUNCTIONS pkg_pretend pkg_setup src_unpack src_prepare src_configure src_compile src_test src_install pkg_preinst pkg_postinst pkg_postrm # @ECLASS-VARIABLE: QT_MINIMAL # @DESCRIPTION: # Minimal Qt version to require for the package. : ${QT_MINIMAL:=5.4.2} # @ECLASS-VARIABLE: KDE_AUTODEPS # @DESCRIPTION: # If set to "false", do nothing. # For any other value, add a dependency on dev-qt/qtcore:5 and kde-frameworks/extra-cmake-modules:5. : ${KDE_AUTODEPS:=true} # @ECLASS-VARIABLE: KDE_BLOCK_SLOT4 # @DESCRIPTION: # This variable is used when KDE_AUTODEPS is set. # If set to "true", add RDEPEND block on kde-{base,apps}/${PN}:4 : ${KDE_BLOCK_SLOT4:=true} # @ECLASS-VARIABLE: KDE_DEBUG # @DESCRIPTION: # If set to "false", unconditionally build with -DNDEBUG. # Otherwise, add debug to IUSE to control building with that flag. : ${KDE_DEBUG:=true} # @ECLASS-VARIABLE: KDE_DOXYGEN # @DESCRIPTION: # If set to "false", do nothing. # Otherwise, add "doc" to IUSE, add appropriate dependencies, and generate and # install API documentation. if [[ ${CATEGORY} = kde-frameworks ]]; then : ${KDE_DOXYGEN:=true} else : ${KDE_DOXYGEN:=false} fi # @ECLASS-VARIABLE: KDE_DOX_DIR # @DESCRIPTION: # Defaults to ".". Otherwise, use alternative KDE doxygen path. : ${KDE_DOX_DIR:=.} # @ECLASS-VARIABLE: KDE_EXAMPLES # @DESCRIPTION: # If set to "false", unconditionally ignore a top-level examples subdirectory. # Otherwise, add "examples" to IUSE to toggle adding that subdirectory. : ${KDE_EXAMPLES:=false} # @ECLASS-VARIABLE: KDE_HANDBOOK # @DESCRIPTION: # If set to "false", do nothing. # Otherwise, add "+handbook" to IUSE, add the appropriate dependency, and # generate and install KDE handbook. # If set to "forceoptional", remove a KF5DocTools dependency from the root # CMakeLists.txt in addition to the above. : ${KDE_HANDBOOK:=false} # @ECLASS-VARIABLE: KDE_DOC_DIR # @DESCRIPTION: # Defaults to "doc". Otherwise, use alternative KDE handbook path. : ${KDE_DOC_DIR:=doc} # @ECLASS-VARIABLE: KDE_TEST # @DESCRIPTION: # If set to "false", do nothing. # For any other value, add test to IUSE and add a dependency on dev-qt/qttest:5. # If set to "forceoptional", remove a Qt5Test dependency from the root # CMakeLists.txt in addition to the above. if [[ ${CATEGORY} = kde-frameworks ]]; then : ${KDE_TEST:=true} else : ${KDE_TEST:=false} fi # @ECLASS-VARIABLE: KDE_PUNT_BOGUS_DEPS # @DESCRIPTION: # If set to "false", do nothing. # For any other value, do black magic to make hardcoded-but-optional dependencies # optional again. An upstream solution is preferable and this is a last resort. : ${KDE_PUNT_BOGUS_DEPS:=false} # @ECLASS-VARIABLE: KDE_SELINUX_MODULE # @DESCRIPTION: # If set to "none", do nothing. # For any other value, add selinux to IUSE, and depending on that useflag # add a dependency on sec-policy/selinux-${KDE_SELINUX_MODULE} to (R)DEPEND. : ${KDE_SELINUX_MODULE:=none} if [[ ${KDEBASE} = kdevelop ]]; then HOMEPAGE="https://www.kdevelop.org/" else HOMEPAGE="https://www.kde.org/" fi LICENSE="GPL-2" if [[ ${CATEGORY} = kde-frameworks ]]; then SLOT=5/$(get_version_component_range 1-2) else SLOT=5 fi case ${KDE_AUTODEPS} in false) ;; *) if [[ ${KDE_BUILD_TYPE} = live ]]; then case ${CATEGORY} in kde-frameworks) FRAMEWORKS_MINIMAL=9999 ;; kde-plasma) FRAMEWORKS_MINIMAL=9999 ;; *) ;; esac fi DEPEND+=" $(add_frameworks_dep extra-cmake-modules)" RDEPEND+=" >=kde-frameworks/kf-env-3" COMMONDEPEND+=" >=dev-qt/qtcore-${QT_MINIMAL}:5" if [[ ${CATEGORY} = kde-frameworks || ${CATEGORY} = kde-plasma && ${PN} != polkit-kde-agent ]]; then RDEPEND+=" !kde-apps/kde4-l10n[-minimal(-)] !<kde-apps/kde4-l10n-15.08.0-r1 " fi if [[ ${KDE_BLOCK_SLOT4} = true && ${CATEGORY} = kde-apps ]]; then RDEPEND+=" !kde-apps/${PN}:4" fi ;; esac case ${KDE_DOXYGEN} in false) ;; *) IUSE+=" doc" DEPEND+=" doc? ( $(add_frameworks_dep kapidox) app-doc/doxygen )" ;; esac case ${KDE_DEBUG} in false) ;; *) IUSE+=" debug" ;; esac case ${KDE_EXAMPLES} in false) ;; *) IUSE+=" examples" ;; esac case ${KDE_HANDBOOK} in false) ;; *) IUSE+=" +handbook" DEPEND+=" handbook? ( $(add_frameworks_dep kdoctools) )" ;; esac case ${KDE_TEST} in false) ;; *) IUSE+=" test" DEPEND+=" test? ( >=dev-qt/qttest-${QT_MINIMAL}:5 )" ;; esac case ${KDE_SELINUX_MODULE} in none) ;; *) IUSE+=" selinux" RDEPEND+=" selinux? ( sec-policy/selinux-${KDE_SELINUX_MODULE} )" ;; esac DEPEND+=" ${COMMONDEPEND} dev-util/desktop-file-utils" RDEPEND+=" ${COMMONDEPEND}" unset COMMONDEPEND if [[ -n ${KMNAME} && ${KMNAME} != ${PN} && ${KDE_BUILD_TYPE} = release ]]; then S=${WORKDIR}/${KMNAME}-${PV} fi # Determine fetch location for released tarballs _calculate_src_uri() { debug-print-function ${FUNCNAME} "$@" local _kmname if [[ -n ${KMNAME} ]]; then _kmname=${KMNAME} else _kmname=${PN} fi case ${PN} in kdelibs4support | \ khtml | \ kjs | \ kjsembed | \ kmediaplayer | \ kross | \ krunner) _kmname="portingAids/${_kmname}" ;; esac DEPEND+=" app-arch/xz-utils" case ${CATEGORY} in kde-apps) case ${PV} in ??.?.[6-9]? | ??.??.[6-9]? ) SRC_URI="mirror://kde/unstable/applications/${PV}/src/${_kmname}-${PV}.tar.xz" RESTRICT+=" mirror" ;; *) SRC_URI="mirror://kde/stable/applications/${PV}/src/${_kmname}-${PV}.tar.xz" ;; esac ;; kde-frameworks) SRC_URI="mirror://kde/stable/frameworks/${PV%.*}/${_kmname}-${PV}.tar.xz" ;; kde-plasma) local plasmapv=$(get_version_component_range 1-3) case ${PV} in 5.?.[6-9]? ) # Plasma 5 beta releases SRC_URI="mirror://kde/unstable/plasma/${plasmapv}/${_kmname}-${PV}.tar.xz" RESTRICT+=" mirror" ;; *) # Plasma 5 stable releases SRC_URI="mirror://kde/stable/plasma/${plasmapv}/${_kmname}-${PV}.tar.xz" ;; esac ;; esac } # Determine fetch location for live sources _calculate_live_repo() { debug-print-function ${FUNCNAME} "$@" SRC_URI="" case ${KDE_SCM} in svn) # @ECLASS-VARIABLE: ESVN_MIRROR # @DESCRIPTION: # This variable allows easy overriding of default kde mirror service # (anonsvn) with anything else you might want to use. ESVN_MIRROR=${ESVN_MIRROR:=svn://anonsvn.kde.org/home/kde} local branch_prefix="trunk/KDE" if [[ ${PV} == ??.??.49.9999 && ${CATEGORY} = kde-apps ]]; then branch_prefix="branches/Applications/$(get_version_component_range 1-2)" fi if [[ ${PV} != 9999 && ${CATEGORY} = kde-plasma ]]; then branch_prefix="branches/plasma/$(get_version_component_range 1-2)" fi local _kmname if [[ -n ${KMNAME} ]]; then _kmname=${KMNAME} else _kmname=${PN} fi ESVN_REPO_URI="${ESVN_MIRROR}/${branch_prefix}/${_kmname}" ;; git) # @ECLASS-VARIABLE: EGIT_MIRROR # @DESCRIPTION: # This variable allows easy overriding of default kde mirror service # (anongit) with anything else you might want to use. EGIT_MIRROR=${EGIT_MIRROR:=git://anongit.kde.org} local _kmname # @ECLASS-VARIABLE: EGIT_REPONAME # @DESCRIPTION: # This variable allows overriding of default repository # name. Specify only if this differ from PN and KMNAME. if [[ -n ${EGIT_REPONAME} ]]; then # the repository and kmname different _kmname=${EGIT_REPONAME} elif [[ -n ${KMNAME} ]]; then _kmname=${KMNAME} else _kmname=${PN} fi if [[ ${PV} == ??.??.49.9999 && ${CATEGORY} = kde-apps ]]; then EGIT_BRANCH="Applications/$(get_version_component_range 1-2)" fi if [[ ${PV} != 9999 && ${CATEGORY} = kde-plasma ]]; then EGIT_BRANCH="Plasma/$(get_version_component_range 1-2)" fi EGIT_REPO_URI="${EGIT_MIRROR}/${_kmname}" ;; esac } case ${KDE_BUILD_TYPE} in live) _calculate_live_repo ;; *) _calculate_src_uri ;; esac debug-print "${LINENO} ${ECLASS} ${FUNCNAME}: SRC_URI is ${SRC_URI}" # @FUNCTION: kde5_pkg_pretend # @DESCRIPTION: # Do some basic settings kde5_pkg_pretend() { debug-print-function ${FUNCNAME} "$@" if [[ ${MERGE_TYPE} != binary ]]; then _check_gcc_version fi } # @FUNCTION: kde5_pkg_setup # @DESCRIPTION: # Do some basic settings kde5_pkg_setup() { debug-print-function ${FUNCNAME} "$@" if [[ ${MERGE_TYPE} != binary ]]; then _check_gcc_version fi } # @FUNCTION: kde5_src_unpack # @DESCRIPTION: # Function for unpacking KDE 5. kde5_src_unpack() { debug-print-function ${FUNCNAME} "$@" if [[ ${KDE_BUILD_TYPE} = live ]]; then case ${KDE_SCM} in svn) subversion_src_unpack ;; git) git-r3_src_unpack ;; esac else default fi } # @FUNCTION: kde5_src_prepare # @DESCRIPTION: # Function for preparing the KDE 5 sources. kde5_src_prepare() { debug-print-function ${FUNCNAME} "$@" cmake-utils_src_prepare # only build examples when required if ! use_if_iuse examples || ! use examples ; then cmake_comment_add_subdirectory examples fi # only enable handbook when required if ! use_if_iuse handbook ; then cmake_comment_add_subdirectory ${KDE_DOC_DIR} if [[ ${KDE_HANDBOOK} = forceoptional ]] ; then punt_bogus_dep KF5 DocTools fi fi # enable only the requested translations # when required if [[ ${KDE_BUILD_TYPE} = release ]] ; then if [[ -d po ]] ; then pushd po > /dev/null || die for lang in *; do if ! has ${lang} ${LINGUAS} ; then if [[ ${lang} != CMakeLists.txt ]] ; then rm -rf ${lang} fi if [[ -e CMakeLists.txt ]] ; then cmake_comment_add_subdirectory ${lang} fi fi done popd > /dev/null || die fi if [[ ${KDE_HANDBOOK} != false && -d ${KDE_DOC_DIR} && ${CATEGORY} != kde-apps ]] ; then pushd ${KDE_DOC_DIR} > /dev/null || die for lang in *; do if ! has ${lang} ${LINGUAS} ; then cmake_comment_add_subdirectory ${lang} fi done popd > /dev/null || die fi else rm -rf po fi # in frameworks, tests = manual tests so never build them if [[ ${CATEGORY} = kde-frameworks ]]; then cmake_comment_add_subdirectory tests fi case ${KDE_PUNT_BOGUS_DEPS} in false) ;; *) if ! use_if_iuse test ; then punt_bogus_dep Qt5 Test fi if ! use_if_iuse handbook ; then punt_bogus_dep KF5 DocTools fi ;; esac # only build unit tests when required if ! use_if_iuse test ; then if [[ ${KDE_TEST} = forceoptional ]] ; then punt_bogus_dep Qt5 Test # if forceoptional, also cover non-kde categories cmake_comment_add_subdirectory autotests cmake_comment_add_subdirectory test cmake_comment_add_subdirectory tests elif [[ ${CATEGORY} = kde-frameworks || ${CATEGORY} = kde-plasma || ${CATEGORY} = kde-apps ]] ; then cmake_comment_add_subdirectory autotests cmake_comment_add_subdirectory test cmake_comment_add_subdirectory tests fi fi } # @FUNCTION: kde5_src_configure # @DESCRIPTION: # Function for configuring the build of KDE 5. kde5_src_configure() { debug-print-function ${FUNCNAME} "$@" # we rely on cmake-utils.eclass to append -DNDEBUG too if ! use_if_iuse debug; then append-cppflags -DQT_NO_DEBUG fi local cmakeargs if ! use_if_iuse test ; then cmakeargs+=( -DBUILD_TESTING=OFF ) fi # install mkspecs in the same directory as qt stuff cmakeargs+=(-DKDE_INSTALL_USE_QT_SYS_PATHS=ON) # allow the ebuild to override what we set here mycmakeargs=("${cmakeargs[@]}" "${mycmakeargs[@]}") cmake-utils_src_configure } # @FUNCTION: kde5_src_compile # @DESCRIPTION: # Function for compiling KDE 5. kde5_src_compile() { debug-print-function ${FUNCNAME} "$@" cmake-utils_src_compile "$@" # Build doxygen documentation if applicable if use_if_iuse doc ; then kgenapidox ${KDE_DOX_DIR} || die fi } # @FUNCTION: kde5_src_test # @DESCRIPTION: # Function for testing KDE 5. kde5_src_test() { debug-print-function ${FUNCNAME} "$@" _test_runner() { if [[ -n "${VIRTUALDBUS_TEST}" ]]; then export $(dbus-launch) fi cmake-utils_src_test } # When run as normal user during ebuild development with the ebuild command, the # kde tests tend to access the session DBUS. This however is not possible in a real # emerge or on the tinderbox. # > make sure it does not happen, so bad tests can be recognized and disabled unset DBUS_SESSION_BUS_ADDRESS DBUS_SESSION_BUS_PID if [[ ${VIRTUALX_REQUIRED} = always || ${VIRTUALX_REQUIRED} = test ]]; then virtx _test_runner else _test_runner fi if [[ -n "${DBUS_SESSION_BUS_PID}" ]] ; then kill ${DBUS_SESSION_BUS_PID} fi } # @FUNCTION: kde5_src_install # @DESCRIPTION: # Function for installing KDE 5. kde5_src_install() { debug-print-function ${FUNCNAME} "$@" # Install doxygen documentation if applicable if use_if_iuse doc ; then dodoc -r apidocs/html fi cmake-utils_src_install # We don't want ${PREFIX}/share/doc/HTML to be compressed, # because then khelpcenter can't find the docs if [[ -d ${ED}/${PREFIX}/share/doc/HTML ]]; then docompress -x ${PREFIX}/share/doc/HTML fi } # @FUNCTION: kde5_pkg_preinst # @DESCRIPTION: # Function storing icon caches kde5_pkg_preinst() { debug-print-function ${FUNCNAME} "$@" gnome2_icon_savelist xdg_pkg_preinst } # @FUNCTION: kde5_pkg_postinst # @DESCRIPTION: # Function to rebuild the KDE System Configuration Cache after an application has been installed. kde5_pkg_postinst() { debug-print-function ${FUNCNAME} "$@" gnome2_icon_cache_update xdg_pkg_postinst } # @FUNCTION: kde5_pkg_postrm # @DESCRIPTION: # Function to rebuild the KDE System Configuration Cache after an application has been removed. kde5_pkg_postrm() { debug-print-function ${FUNCNAME} "$@" gnome2_icon_cache_update xdg_pkg_postrm } fi