diff options
| author | Alexander Neundorf <neundorf@kde.org> | 2006-02-18 09:20:03 +0000 | 
|---|---|---|
| committer | Alexander Neundorf <neundorf@kde.org> | 2006-02-18 09:20:03 +0000 | 
| commit | 877e4bdedab9045e55cd182a9442c348ac8769ee (patch) | |
| tree | 94debf34eaf56da67ace8b2a11a9d2e8a4712e64 | |
| parent | 590106d0c8ee50cec2b570e1c10e49275f081f16 (diff) | |
| download | extra-cmake-modules-877e4bdedab9045e55cd182a9442c348ac8769ee.tar.gz extra-cmake-modules-877e4bdedab9045e55cd182a9442c348ac8769ee.tar.bz2 | |
-apply patch from  Andreas Beckermann
-rename KDE3_CREATE_LIBTOOL_FILE to KDE3_INSTALL_LIBTOOL_FILE
-require cmake 2.3.3: http://www.cmake.org/files/v2.3/cmake-2.3.3-20060210.tar.gz
-use GET_FILENAME_COMPONENT(...ABSOLUTE )
-the Macro*.cmake files are now required too
Alex
If you use these files, please test that they work for you.
CCMAIL: b_mann@gmx.de
CCMAIL: christian.loose@hamburg.de
svn path=/trunk/KDE/kdelibs/; revision=510821
| -rw-r--r-- | modules/FindKDE3.cmake | 19 | ||||
| -rw-r--r-- | modules/KDE3Macros.cmake | 106 | 
2 files changed, 60 insertions, 65 deletions
| diff --git a/modules/FindKDE3.cmake b/modules/FindKDE3.cmake index 828ca056..d6945cdb 100644 --- a/modules/FindKDE3.cmake +++ b/modules/FindKDE3.cmake @@ -18,14 +18,14 @@  # KDE3_ADD_KCFG_FILES  # KDE3_AUTOMOC  # KDE3_PLACEHOLDER -# KDE3_CREATE_LIBTOOL_FILE +# KDE3_INSTALL_LIBTOOL_FILE  # KDE3_CREATE_FINAL_FILE  # KDE3_ADD_KPART  # KDE3_ADD_KLM  # KDE3_ADD_EXECUTABLE -CMAKE_MINIMUM_REQUIRED(VERSION 2.2) +CMAKE_MINIMUM_REQUIRED(VERSION "2.3.3")  set(QT_MT_REQUIRED TRUE)  #set(QT_MIN_VERSION "3.0.0") @@ -40,13 +40,21 @@ FIND_PACKAGE(X11 REQUIRED)  set(QT_AND_KDECORE_LIBS ${QT_LIBRARIES} kdecore)  #add some KDE specific stuff -set(KDE3_DEFINITIONS -DQT_CLEAN_NAMESPACE -Wnon-virtual-dtor -Wno-long-long -Wundef -ansi -Wcast-align -Wconversion -Wchar-subscripts -Wall -W -Wpointer-arith -Wwrite-strings -O2 -Wformat-security -Wmissing-format-attribute -fno-exceptions -fno-check-new -fno-common) +set(KDE3_DEFINITIONS -DQT_CLEAN_NAMESPACE -D_GNU_SOURCE)  #only on linux, but NOT e.g. on FreeBSD:  if(CMAKE_SYSTEM_NAME MATCHES "Linux") -  set(KDE3_DEFINITIONS ${KDE3_DEFINITIONS} -D_XOPEN_SOURCE=500 -D_BSD_SOURCE -D_GNU_SOURCE) +   set (KDE3_DEFINITIONS ${KDE3_DEFINITIONS} -D_XOPEN_SOURCE=500 -D_BSD_SOURCE) +   set ( CMAKE_C_FLAGS     "${CMAKE_C_FLAGS} -Wno-long-long -ansi -Wundef -Wcast-align -Wconversion -Wchar-subscripts -Wall -W -Wpointer-arith -Wwrite-strings -O2 -Wformat-security -Wmissing-format-attribute -fno-common") +   set ( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wnon-virtual-dtor -Wno-long-long -ansi -Wundef -Wcast-align -Wconversion -Wchar-subscripts -Wall -W -Wpointer-arith -Wwrite-strings -O2 -Wformat-security -fno-exceptions -fno-check-new -fno-common")  endif(CMAKE_SYSTEM_NAME MATCHES "Linux") +# works on FreeBSD, NOT tested on NetBSD and OpenBSD +if (CMAKE_SYSTEM_NAME MATCHES BSD) +   set ( CMAKE_C_FLAGS     "${CMAKE_C_FLAGS} -Wno-long-long -ansi -Wundef -Wcast-align -Wconversion -Wchar-subscripts -Wall -W -Wpointer-arith -Wwrite-strings -O2 -Wformat-security -Wmissing-format-attribute -fno-common") +   set ( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wnon-virtual-dtor -Wno-long-long -Wundef -Wcast-align -Wconversion -Wchar-subscripts -Wall -W -Wpointer-arith -Wwrite-strings -O2 -Wformat-security -Wmissing-format-attribute -fno-exceptions -fno-check-new -fno-common") +endif (CMAKE_SYSTEM_NAME MATCHES BSD) +  #set(CMAKE_SHARED_LINKER_FLAGS "-avoid-version -module -Wl,--no-undefined -Wl,--allow-shlib-undefined")  #set(CMAKE_SHARED_LINKER_FLAGS "-Wl,--fatal-warnings -avoid-version -Wl,--no-undefined -lc") @@ -55,7 +63,8 @@ endif(CMAKE_SYSTEM_NAME MATCHES "Linux")  #now try to find some kde stuff  #at first the KDE include direcory -FIND_PATH(KDE3_INCLUDE_DIR kurl.h +# kpassdlg.h comes from kdeui and doesn't exist in KDE4 anymore +FIND_PATH(KDE3_INCLUDE_DIR kpassdlg.h    $ENV{KDEDIR}/include    /opt/kde/include    /opt/kde3/include diff --git a/modules/KDE3Macros.cmake b/modules/KDE3Macros.cmake index c7da385a..f21b6dcb 100644 --- a/modules/KDE3Macros.cmake +++ b/modules/KDE3Macros.cmake @@ -6,7 +6,7 @@  # KDE3_ADD_UI_FILES  # KDE3_ADD_KCFG_FILES  # KDE3_AUTOMOC -# KDE3_CREATE_LIBTOOL_FILE +# KDE3_INSTALL_LIBTOOL_FILE  # KDE3_PLACEHOLDER  # KDE3_CREATE_FINAL_FILE  # KDE3_ADD_KPART @@ -16,36 +16,14 @@  #neundorf@kde.org -#this should better be part of cmake: -#add an additional file to the list of files a source file depends on -MACRO(KDE3_ADD_FILE_DEPENDANCY file) - -   GET_SOURCE_FILE_PROPERTY(_deps ${file} OBJECT_DEPENDS) -   if (_deps) -      set(_deps ${_deps} ${ARGN}) -   else (_deps) -      set(_deps ${ARGN}) -   endif (_deps) - -   SET_SOURCE_FILES_PROPERTIES(${file} PROPERTIES OBJECT_DEPENDS "${_deps}") - -ENDMACRO(KDE3_ADD_FILE_DEPENDANCY) - -MACRO(KDE3_GET_ABS_PATH _abs_filename _filename) -   if(${_filename} MATCHES "^/.+") -      set(${_abs_filename} ${_filename}) -   else(${_filename} MATCHES "^/.+") -      set(${_abs_filename} ${CMAKE_CURRENT_SOURCE_DIR}/${_filename}) -   endif(${_filename} MATCHES "^/.+") -ENDMACRO(KDE3_GET_ABS_PATH) +INCLUDE(MacroLibrary)  #create the kidl and skeletion file for dcop stuff  #usage: KDE_ADD_COP_SKELS(foo_SRCS ${dcop_headers})  MACRO(KDE3_ADD_DCOP_SKELS _sources) -   foreach (_current_FILE ${ARGN}) - -      KDE3_GET_ABS_PATH(_tmp_FILE ${_current_FILE}) +   FOREACH (_current_FILE ${ARGN}) +      GET_FILENAME_COMPONENT(_tmp_FILE ${_current_FILE} ABSOLUTE)        GET_FILENAME_COMPONENT(_basename ${_tmp_FILE} NAME_WE)        set(_skel ${CMAKE_CURRENT_BINARY_DIR}/${_basename}_skel.cpp) @@ -74,14 +52,15 @@ MACRO(KDE3_ADD_DCOP_SKELS _sources)        set(${_sources} ${${_sources}} ${_skel}) -   endforeach (_current_FILE) +   ENDFOREACH (_current_FILE)  ENDMACRO(KDE3_ADD_DCOP_SKELS) +  MACRO(KDE3_ADD_DCOP_STUBS _sources) -   foreach (_current_FILE ${ARGN}) +   FOREACH (_current_FILE ${ARGN}) -      KDE3_GET_ABS_PATH(_tmp_FILE ${_current_FILE}) +      GET_FILENAME_COMPONENT(_tmp_FILE ${_current_FILE} ABSOLUTE)        GET_FILENAME_COMPONENT(_basename ${_tmp_FILE} NAME_WE) @@ -114,14 +93,15 @@ MACRO(KDE3_ADD_DCOP_STUBS _sources)        set(${_sources} ${${_sources}} ${_stub_CPP}) -   endforeach (_current_FILE) +   ENDFOREACH (_current_FILE)  ENDMACRO(KDE3_ADD_DCOP_STUBS) +  MACRO(KDE3_ADD_KCFG_FILES _sources) -   foreach (_current_FILE ${ARGN}) +   FOREACH (_current_FILE ${ARGN}) -      KDE3_GET_ABS_PATH(_tmp_FILE ${_current_FILE}) +      GET_FILENAME_COMPONENT(_tmp_FILE ${_current_FILE} ABSOLUTE)        GET_FILENAME_COMPONENT(_basename ${_tmp_FILE} NAME_WE) @@ -138,7 +118,7 @@ MACRO(KDE3_ADD_KCFG_FILES _sources)        set(${_sources} ${${_sources}} ${_src_FILE}) -   endforeach (_current_FILE) +   ENDFOREACH (_current_FILE)  ENDMACRO(KDE3_ADD_KCFG_FILES) @@ -146,9 +126,9 @@ ENDMACRO(KDE3_ADD_KCFG_FILES)  #create the moc files and add them to the list of sources  #usage: KDE_ADD_MOC_FILES(foo_SRCS ${moc_headers})  MACRO(KDE3_ADD_MOC_FILES _sources) -   foreach (_current_FILE ${ARGN}) +   FOREACH (_current_FILE ${ARGN}) -      KDE3_GET_ABS_PATH(_tmp_FILE ${_current_FILE}) +      GET_FILENAME_COMPONENT(_tmp_FILE ${_current_FILE} ABSOLUTE)        GET_FILENAME_COMPONENT(_basename ${_tmp_FILE} NAME_WE)        set(_moc ${CMAKE_CURRENT_BINARY_DIR}/${_basename}.moc.cpp) @@ -161,17 +141,18 @@ MACRO(KDE3_ADD_MOC_FILES _sources)        set(${_sources} ${${_sources}} ${_moc}) -   endforeach (_current_FILE) +   ENDFOREACH (_current_FILE)  ENDMACRO(KDE3_ADD_MOC_FILES) +GET_FILENAME_COMPONENT( KDE3_MODULE_DIR  ${CMAKE_CURRENT_LIST_FILE} PATH) +  #create the implementation files from the ui files and add them to the list of sources  #usage: KDE_ADD_UI_FILES(foo_SRCS ${ui_files})  MACRO(KDE3_ADD_UI_FILES _sources ) -   foreach (_current_FILE ${ARGN}) - -      KDE3_GET_ABS_PATH(_tmp_FILE ${_current_FILE}) +   FOREACH (_current_FILE ${ARGN}) +      GET_FILENAME_COMPONENT(_tmp_FILE ${_current_FILE} ABSOLUTE)        GET_FILENAME_COMPONENT(_basename ${_tmp_FILE} NAME_WE)        set(_header ${CMAKE_CURRENT_BINARY_DIR}/${_basename}.h) @@ -196,7 +177,7 @@ MACRO(KDE3_ADD_UI_FILES _sources )           -DKDE_UIC_FILE:STRING=${_tmp_FILE}           -DKDE_UIC_CPP_FILE:STRING=${_src}           -DKDE_UIC_H_FILE:STRING=${_header} -         -P ${CMAKE_ROOT}/Modules/kde3uic.cmake +         -P ${KDE3_MODULE_DIR}/kde3uic.cmake           DEPENDS ${_header}        ) @@ -208,14 +189,15 @@ MACRO(KDE3_ADD_UI_FILES _sources )        set(${_sources} ${${_sources}} ${_src} ${_moc} ) -   endforeach (_current_FILE) +   ENDFOREACH (_current_FILE)  ENDMACRO(KDE3_ADD_UI_FILES) +  MACRO(KDE3_AUTOMOC)     set(_matching_FILES ) -   foreach (_current_FILE ${ARGN}) +   FOREACH (_current_FILE ${ARGN}) -      KDE3_GET_ABS_PATH(_tmp_FILE ${_current_FILE}) +      GET_FILENAME_COMPONENT(_tmp_FILE ${_current_FILE} ABSOLUTE)        if (EXISTS ${_tmp_FILE}) @@ -226,7 +208,7 @@ MACRO(KDE3_AUTOMOC)           STRING(REGEX MATCHALL "#include +[^ ]+\\.moc[\">]" _match "${_contents}")           if(_match) -            foreach (_current_MOC_INC ${_match}) +            FOREACH (_current_MOC_INC ${_match})                 STRING(REGEX MATCH "[^ <\"]+\\.moc" _current_MOC "${_current_MOC_INC}")                 GET_FILENAME_COMPONENT(_basename ${_current_MOC} NAME_WE) @@ -240,15 +222,16 @@ MACRO(KDE3_AUTOMOC)                    DEPENDS ${_header}                 ) -               KDE3_ADD_FILE_DEPENDANCY(${CMAKE_CURRENT_SOURCE_DIR}/${_current_FILE} ${_moc}) +               MACRO_ADD_FILE_DEPENDENCIES(${_tmp_FILE} ${_moc}) -            endforeach (_current_MOC_INC) +            ENDFOREACH (_current_MOC_INC)           endif(_match)        endif (EXISTS ${_tmp_FILE}) -   endforeach (_current_FILE) +   ENDFOREACH (_current_FILE)  ENDMACRO(KDE3_AUTOMOC) +  MACRO(KDE3_INSTALL_ICONS _theme)     ADD_CUSTOM_TARGET(install_icons )     SET_TARGET_PROPERTIES(install_icons PROPERTIES POST_INSTALL_SCRIPT ${CMAKE_CURRENT_BINARY_DIR}/install_icons.cmake ) @@ -256,7 +239,7 @@ MACRO(KDE3_INSTALL_ICONS _theme)     FILE(APPEND ${CMAKE_CURRENT_BINARY_DIR}/install_icons.cmake "set(CMAKE_BACKWARDS_COMPATIBILITY \"2.2\") \n")     FILE(GLOB _icons *.png) -   foreach(_current_ICON ${_icons} ) +   FOREACH(_current_ICON ${_icons} )        STRING(REGEX REPLACE "^.*/[a-zA-Z]+([0-9]+)\\-([a-z]+)\\-(.+\\.png)$" "\\1" _size "${_current_ICON}")        STRING(REGEX REPLACE "^.*/[a-zA-Z]+([0-9]+)\\-([a-z]+)\\-(.+\\.png)$" "\\2" _group "${_current_ICON}")        STRING(REGEX REPLACE "^.*/[a-zA-Z]+([0-9]+)\\-([a-z]+)\\-(.+\\.png)$" "\\3" _name "${_current_ICON}") @@ -288,15 +271,16 @@ MACRO(KDE3_INSTALL_ICONS _theme)        FILE(APPEND ${CMAKE_CURRENT_BINARY_DIR}/install_icons.cmake "message(STATUS \"Installing ${_ICON_INSTALL_NAME}\") \n")        FILE(APPEND ${CMAKE_CURRENT_BINARY_DIR}/install_icons.cmake "CONFIGURE_FILE( ${_current_ICON} ${_ICON_INSTALL_NAME} COPYONLY) \n") -   endforeach (_current_ICON) -ENDMACRO(KDE3_INSTALL_ICONS _theme) +   ENDFOREACH (_current_ICON) +ENDMACRO(KDE3_INSTALL_ICONS) -MACRO(KDE3_CREATE_LIBTOOL_FILE _target) + +MACRO(KDE3_INSTALL_LIBTOOL_FILE _target)     GET_TARGET_PROPERTY(_target_location ${_target} LOCATION)     GET_FILENAME_COMPONENT(_laname ${_target_location} NAME_WE)     GET_FILENAME_COMPONENT(_soname ${_target_location} NAME) -   set(_laname ${_laname}.la) +   set(_laname ${CMAKE_CURRENT_BINARY_DIR}/${_laname}.la)     FILE(WRITE ${_laname} "# ${_laname} - a libtool library file, generated by cmake \n")     FILE(APPEND ${_laname} "# The name that we can dlopen(3).\n") @@ -316,21 +300,22 @@ MACRO(KDE3_CREATE_LIBTOOL_FILE _target)     FILE(APPEND ${_laname} "libdir='${CMAKE_INSTALL_PREFIX}/lib/kde3'\n")     INSTALL_FILES(/lib/kde3 FILES ${_laname}) -ENDMACRO(KDE3_CREATE_LIBTOOL_FILE) +ENDMACRO(KDE3_INSTALL_LIBTOOL_FILE)  MACRO(KDE3_CREATE_FINAL_FILE _filename)     FILE(WRITE ${_filename} "//autogenerated file\n") -   foreach (_current_FILE ${ARGN}) +   FOREACH (_current_FILE ${ARGN})        FILE(APPEND ${_filename} "#include \"${_current_FILE}\"\n") -   endforeach (_current_FILE) +   ENDFOREACH (_current_FILE) -ENDMACRO(KDE3_CREATE_FINAL_FILE _filename) +ENDMACRO(KDE3_CREATE_FINAL_FILE)  OPTION(KDE3_ENABLE_FINAL "Enable final all-in-one compilation")  OPTION(KDE3_BUILD_TESTS  "Build the tests") +  MACRO(KDE3_ADD_KPART _target_NAME _with_PREFIX)  #is the first argument is "WITH_PREFIX" then keep the standard "lib" prefix, otherwise set the prefix empty     if (${_with_PREFIX} STREQUAL "WITH_PREFIX") @@ -352,7 +337,8 @@ MACRO(KDE3_ADD_KPART _target_NAME _with_PREFIX)     KDE3_CREATE_LIBTOOL_FILE(${_target_NAME}) -ENDMACRO(KDE3_ADD_KPART _target_NAME _with_PREFIX) +ENDMACRO(KDE3_ADD_KPART) +  MACRO(KDE3_ADD_KLM _target_NAME ) @@ -363,12 +349,12 @@ MACRO(KDE3_ADD_KLM _target_NAME )        ADD_LIBRARY(kdeinit_${_target_NAME} SHARED ${ARGN} )     endif (KDE3_ENABLE_FINAL) -   CONFIGURE_FILE(${CMAKE_ROOT}/Modules/kde3init_dummy.cpp.in ${CMAKE_CURRENT_BINARY_DIR}/${_target_NAME}_dummy.cpp) +   CONFIGURE_FILE(${KDE3_MODULE_DIR}/kde3init_dummy.cpp.in ${CMAKE_CURRENT_BINARY_DIR}/${_target_NAME}_dummy.cpp)     ADD_EXECUTABLE( ${_target_NAME} ${CMAKE_CURRENT_BINARY_DIR}/${_target_NAME}_dummy.cpp )     TARGET_LINK_LIBRARIES( ${_target_NAME} kdeinit_${_target_NAME} ) -ENDMACRO(KDE3_ADD_KLM _target_NAME) +ENDMACRO(KDE3_ADD_KLM)  MACRO(KDE3_ADD_EXECUTABLE _target_NAME ) @@ -380,6 +366,6 @@ MACRO(KDE3_ADD_EXECUTABLE _target_NAME )        ADD_EXECUTABLE(${_target_NAME} ${ARGN} )     endif (KDE3_ENABLE_FINAL) -ENDMACRO(KDE3_ADD_EXECUTABLE _target_NAME) +ENDMACRO(KDE3_ADD_EXECUTABLE) | 
