diff options
author | samelian <samelian@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2010-10-15 23:22:05 +0000 |
---|---|---|
committer | samelian <samelian@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2010-10-15 23:22:05 +0000 |
commit | 0266473091841973f1ff4afb1d3bf465f79316bb (patch) | |
tree | d54188a902277797d49d0e7d9deffeabb1329c49 /cmake/modules | |
parent | 8e8977b9ec07a832dfedf5c1bea74032f3b514eb (diff) | |
download | other-0266473091841973f1ff4afb1d3bf465f79316bb.tar.gz other-0266473091841973f1ff4afb1d3bf465f79316bb.zip |
[kde-common/cmake] tde_setup_paths: some paths can be detected automatically using kde-config
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kde-common@1186350 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'cmake/modules')
-rw-r--r-- | cmake/modules/TDESetupPaths.cmake | 158 |
1 files changed, 101 insertions, 57 deletions
diff --git a/cmake/modules/TDESetupPaths.cmake b/cmake/modules/TDESetupPaths.cmake index 3b122ad..2433999 100644 --- a/cmake/modules/TDESetupPaths.cmake +++ b/cmake/modules/TDESetupPaths.cmake @@ -9,135 +9,179 @@ # ################################################# +################################################# +##### +##### __tde_internal_setup_paths_error + +macro( __tde_internal_setup_paths_error ) + message( FATAL_ERROR + "#################################################\n" + " ${ARGV}\n" + "#################################################" ) +endmacro( __tde_internal_setup_paths_error ) + + +################################################# +##### +##### __tde_internal_setup_paths_status + +macro( __tde_internal_setup_paths_status __path __value __method ) + message( STATUS " ${__path}=${__value} [${__method}]" ) +endmacro( __tde_internal_setup_paths_status ) + + +################################################# +##### +##### __tde_internal_setup_path + +macro( __tde_internal_setup_path __path __default ) + set( __method "user" ) + if( NOT ${__path} ) + set( __method "default" ) + set( __kdeconfig_type ${ARGV2} ) + if( _use_kdeconfig AND __kdeconfig_type ) + execute_process( + COMMAND ${KDECONFIG_EXECUTABLE} --expandvars --install ${__kdeconfig_type} + OUTPUT_VARIABLE ${__path} + RESULT_VARIABLE __result + OUTPUT_STRIP_TRAILING_WHITESPACE ) + if( __result ) + __tde_internal_setup_paths_error( "Unable to run kde-config!\n kdelibs are correctly installed?\n LD_LIBRARY_PATH are correctly set?" ) + endif( __result ) + endif( _use_kdeconfig AND __kdeconfig_type ) + if( ${__path} ) + set( __method "kde-config" ) + else( ${__path} ) + set( ${__path} "${__default}" ) + endif( ${__path} ) + endif( NOT ${__path} ) + __tde_internal_setup_paths_status( ${__path} ${${__path}} ${__method} ) +endmacro( __tde_internal_setup_path ) + + +################################################# +##### +##### tde_setup_paths + macro( tde_setup_paths ) + message( STATUS "Setup install paths:" ) + # --prefix # install architecture-independent files in PREFIX if( NOT PREFIX ) + set( __method "CMAKE_INSTALL_PREFIX" ) set( PREFIX "${CMAKE_INSTALL_PREFIX}" ) else( NOT PREFIX ) # PREFIX have precedence over CMAKE_INSTALL_PREFIX + set( __method "user" ) set( CMAKE_INSTALL_PREFIX "${PREFIX}" ) endif( NOT PREFIX ) + __tde_internal_setup_paths_status( PREFIX ${PREFIX} ${__method} ) # --exec-prefix # install architecture-dependent files in EPREFIX if( NOT EPREFIX ) + set( __method "default" ) set( EPREFIX "${PREFIX}" ) endif( NOT EPREFIX ) + __tde_internal_setup_paths_status( EPREFIX ${EPREFIX} ${__method} ) + + # we will using kde-config for discover paths + set( _use_kdeconfig ${ARGV0} ) + if( _use_kdeconfig ) + # KDECONFIG_EXECUTABLE is not set, so will must to search for it + if( NOT KDECONFIG_EXECUTABLE ) + find_program( KDECONFIG_EXECUTABLE + NAMES kde-config + HINTS $ENV{KDEDIR}/bin + PATHS "${EPREFIX}/bin" "${PREFIX}/bin" "${CMAKE_INSTALL_PREFIX}/bin" ) + if( NOT KDECONFIG_EXECUTABLE ) + __tde_internal_setup_paths_error( + +"kde-config executable are NOT found! + kdelibs(-devel) are installed? EPREFIX are correctly set? + Try to set KDECONFIG_EXECUTABLE to kde-config path. + Example: cmake -DKDECONFIG_EXECUTABLE=/usr/kde/3.5/bin/kde-config" ) + + endif( NOT KDECONFIG_EXECUTABLE ) + endif( NOT KDECONFIG_EXECUTABLE ) + endif( _use_kdeconfig ) # --bindir # user executables - if( NOT BINDIR ) - set( BINDIR "${EPREFIX}/bin" ) - endif( NOT BINDIR ) + __tde_internal_setup_path( BINDIR "${EPREFIX}/bin" "exe" ) # --sbindir # system admin executables - if( NOT SBINDIR ) - set( SBINDIR "${EPREFIX}/sbin" ) - endif( NOT SBINDIR ) + __tde_internal_setup_path( SBINDIR "${EPREFIX}/sbin" ) # --libexecdir # program executables - if( NOT LIBEXECDIR ) - set( LIBEXECDIR "${EPREFIX}/libexec" ) - endif( NOT LIBEXECDIR ) + __tde_internal_setup_path( LIBEXECDIR "${EPREFIX}/libexec" ) # --sysconfdir # read-only single-machine data - if( NOT SYSCONFDIR ) - set( SYSCONFDIR "${PREFIX}/etc" ) - endif( NOT SYSCONFDIR ) + __tde_internal_setup_path( SYSCONFDIR "${PREFIX}/etc" ) # --sharedstatedir # modifiable architecture-independent data - if( NOT SHAREDSTATEDIR ) - set( SHAREDSTATEDIR "${PREFIX}/com" ) - endif( NOT SHAREDSTATEDIR ) + __tde_internal_setup_path( SHAREDSTATEDIR "${PREFIX}/com" ) # --localstatedir # modifiable single-machine data - if( NOT LOCALSTATEDIR ) - set( LOCALSTATEDIR "${PREFIX}/var" ) - endif( NOT LOCALSTATEDIR ) + __tde_internal_setup_path( LOCALSTATEDIR "${PREFIX}/var" ) # --libdir # object code libraries - if( NOT LIBDIR ) - set( LIBDIR "${EPREFIX}/lib" ) - endif( NOT LIBDIR ) + __tde_internal_setup_path( LIBDIR "${EPREFIX}/lib" "lib" ) # --includedir # C header files - if( NOT INCLUDEDIR ) - set( INCLUDEDIR "${PREFIX}/include" ) - endif( NOT INCLUDEDIR ) + __tde_internal_setup_path( INCLUDEDIR "${PREFIX}/include" "include" ) # --oldincludedir # C header files for non-gcc - if( NOT OLDINCLUDEDIR ) - set( OLDINCLUDEDIR "/usr/include" ) - endif( NOT OLDINCLUDEDIR ) + __tde_internal_setup_path( OLDINCLUDEDIR "/usr/include" ) # --datarootdir # read-only arch.-independent data root - if( NOT DATAROOTDIR ) - set( DATAROOTDIR "${PREFIX}/share" ) - endif( NOT DATAROOTDIR ) + __tde_internal_setup_path( DATAROOTDIR "${PREFIX}/share" ) # --datadir # read-only architecture-independent data - if( NOT DATADIR ) - set( DATADIR "${DATAROOTDIR}" ) - endif( NOT DATADIR ) + __tde_internal_setup_path( DATADIR "${DATAROOTDIR}" ) # --infodir # info documentation - if( NOT INFODIR ) - set( INFODIR "${DATAROOTDIR}/info" ) - endif( NOT INFODIR ) + __tde_internal_setup_path( INFODIR "${DATAROOTDIR}/info" ) # --localedir # locale-dependent data - if( NOT LOCALEDIR ) - set( LOCALEDIR "${DATAROOTDIR}/locale" ) - endif( NOT LOCALEDIR ) + __tde_internal_setup_path( LOCALEDIR "${DATAROOTDIR}/locale" ) # --mandir # man documentation - if( NOT MANDIR ) - set( MANDIR "${DATAROOTDIR}/man" ) - endif( NOT MANDIR ) + __tde_internal_setup_path( MANDIR "${DATAROOTDIR}/man" ) # --docdir # documentation root - if( NOT DOCDIR ) - set( DOCDIR "${DATAROOTDIR}/doc/${PACKAGE}" ) - endif( NOT DOCDIR ) + __tde_internal_setup_path( DOCDIR "${DATAROOTDIR}/doc/${PACKAGE}" ) # --htmldir # html documentation - if( NOT HTMLDIR ) - set( HTMLDIR "${DOCDIR}" ) - endif( NOT HTMLDIR ) + __tde_internal_setup_path( HTMLDIR "${DOCDIR}" "html" ) # --dvidir # dvi documentation - if( NOT DVIDIR ) - set( DVIDIR "${DOCDIR}" ) - endif( NOT DVIDIR ) + __tde_internal_setup_path( DVIDIR "${DOCDIR}" ) # --pdfdir # pdf documentation - if( NOT PDFDIR ) - set( PDFDIR "${DOCDIR}" ) - endif( NOT PDFDIR ) + __tde_internal_setup_path( PDFDIR "${DOCDIR}" ) # --psdir # ps documentation - if( NOT PSDIR ) - set( PSDIR "${DOCDIR}" ) - endif( NOT PSDIR ) + __tde_internal_setup_path( PSDIR "${DOCDIR}" ) endmacro( tde_setup_paths ) |