Quellcode durchsuchen

ENH: add FindKDE from Alex from kde.org

Bill Hoffman vor 21 Jahren
Ursprung
Commit
50c900b85c
1 geänderte Dateien mit 151 neuen und 0 gelöschten Zeilen
  1. 151 0
      Modules/FindKDE.cmake

+ 151 - 0
Modules/FindKDE.cmake

@@ -0,0 +1,151 @@
+# Locate KDE include paths and libraries
+
+# KDE_INCLUDE_DIR
+# KDE_LIB_DIR
+# KDE_KDE_CONFIG
+# KDE_DCOP_IDL
+# KDE_VERSION
+
+#the macro ADD_DCOP_SOURCES(src_headers dest_srcs)
+#
+#usage:
+#SET(MY_APP_SOURCES main.cpp kfoo.cpp)
+#SET(MY_DCOP_SOURCES kfooiface.h)
+#ADD_DCOP_SOURCES(MY_DCOP_SOURCES MY_APP_SOURCES)
+#and then it should work :-)
+
+#uses KDE_MIN_VERSION
+
+CMAKE_MINIMUM_REQUIRED(VERSION 2.0.0) 
+
+FIND_PATH(KDE_INCLUDE_DIR kurl.h
+  $ENV{KDEDIR}/include
+  /opt/kde/include
+  /opt/kde3/include
+  /usr/local/include
+  /usr/include/
+  /usr/include/kde
+  /usr/local/include/kde
+  )
+
+IF(KDE_INCLUDE_DIR)
+   MESSAGE(STATUS "Found KDE header files in ${KDE_INCLUDE_DIR}")
+ELSE(KDE_INCLUDE_DIR)
+   MESSAGE(FATAL_ERROR "Didn't find KDE headers")
+ENDIF(KDE_INCLUDE_DIR)
+
+FIND_PROGRAM(KDE_CONFIG NAME kde-config PATHS 
+  $ENV{KDEDIR}/bin
+  /opt/kde/bin
+  /opt/kde3/bin)
+
+IF(NOT KDE_CONFIG)
+   MESSAGE(FATAL_ERROR "Didn't find the kde-config utility")
+ENDIF(NOT KDE_CONFIG)
+
+FIND_PATH(KDE_LIB_DIR libkdecore.so
+  $ENV{KDEDIR}/lib
+  /opt/kde/lib
+  /opt/kde3/lib
+  )
+
+IF(KDE_LIB_DIR)
+   MESSAGE(STATUS "Found KDE libraries in ${KDE_LIB_DIR}")
+ELSE(KDE_LIB_DIR)
+   MESSAGE(FATAL_ERROR "Didn't find KDE core library")
+ENDIF(KDE_LIB_DIR)
+
+IF (KDE_MIN_VERSION)
+   #extract the version from kdeversion.h
+
+   FILE(READ ${KDE_INCLUDE_DIR}/kdeversion.h KDE_VERSION_H)
+
+   STRING(REGEX REPLACE ".*#define[\\t\\ ]+KDE_VERSION_STRING[\\t\\ ]+\"([0-9]+\\.[0-9]+\\.[0-9]+)\".*" "\\1" KDE_VERSION "${KDE_VERSION_H}")
+   STRING(REGEX REPLACE ".*#define[\\t\\ ]+KDE_VERSION_MAJOR[\\t\\ ]+([0-9]+).*" "\\1" kde_major_vers "${KDE_VERSION_H}")
+   STRING(REGEX REPLACE ".*#define[\\t\\ ]+KDE_VERSION_MINOR[\\t\\ ]+([0-9]+).*" "\\1" kde_minor_vers "${KDE_VERSION_H}")
+   STRING(REGEX REPLACE ".*#define[\\t\\ ]+KDE_VERSION_RELEASE[\\t\\ ]+([0-9]+).*" "\\1" kde_vers_release "${KDE_VERSION_H}")
+
+#now parse the parts of the user given version string into variables 
+   STRING(REGEX MATCH "^[0-9]+\\.[0-9]+\\.[0-9]+$" req_kde_major_vers "${KDE_MIN_VERSION}")
+   IF (NOT req_kde_major_vers)
+      MESSAGE( FATAL_ERROR "Invalid KDE version string given: \"${KDE_MIN_VERSION}\", expected e.g. \"3.1.5\"")
+   ENDIF (NOT req_kde_major_vers)
+      
+   STRING(REGEX REPLACE "([0-9]+)\\.[0-9]+\\.[0-9]+" "\\1" req_kde_major_vers "${KDE_MIN_VERSION}")
+   STRING(REGEX REPLACE "[0-9]+\\.([0-9])+\\.[0-9]+" "\\1" req_kde_minor_vers "${KDE_MIN_VERSION}")
+   STRING(REGEX REPLACE "[0-9]+\\.[0-9]+\\.([0-9]+)" "\\1" req_kde_patch_vers "${KDE_MIN_VERSION}")
+
+# req = "6.5.4", qt = "3.2.1"
+
+   IF (req_kde_major_vers GREATER kde_major_vers)                  # (6 > 3) ?
+      MESSAGE(  FATAL_ERROR "KDE major version not matched (required: ${KDE_MIN_VERSION}, found: ${KDE_VERSION})")            # yes
+   ELSE  (req_kde_major_vers GREATER kde_major_vers)               # no
+      IF (req_kde_major_vers LESS kde_major_vers)                  # (6 < 3) ?
+         SET( QT_VERSION_BIG_ENOUGH "YES" )                        # yes
+      ELSE (req_kde_major_vers LESS kde_major_vers)                # ( 6==3) ?
+         IF (req_kde_minor_vers GREATER kde_minor_vers)            # (5>2) ?
+            MESSAGE(  FATAL_ERROR "KDE minor version not matched (required: ${KDE_MIN_VERSION}, found: ${KDE_VERSION})")      # yes
+         ELSE (req_kde_minor_vers GREATER kde_minor_vers)          # no
+            IF (req_kde_minor_vers LESS kde_minor_vers)            # (5<2) ?
+               SET( QT_VERSION_BIG_ENOUGH "YES" )                  # yes
+            ELSE (req_kde_minor_vers LESS kde_minor_vers)          # (5==2)
+               IF (req_kde_patch_vers GREATER kde_vers_release)    # (4>1) ?
+                  MESSAGE( FATAL_ERROR "KDE release version not matched (required: ${KDE_MIN_VERSION}, found: ${KDE_VERSION})")  # yes
+               ELSE (req_kde_patch_vers GREATER kde_patch_vers)    # (4>1) ?
+                  SET( QT_VERSION_BIG_ENOUGH "YES" )               # yes
+               ENDIF (req_kde_patch_vers GREATER kde_vers_release) # (4>1) ?
+            ENDIF (req_kde_minor_vers LESS kde_minor_vers)
+         ENDIF (req_kde_minor_vers GREATER kde_minor_vers)
+      ENDIF (req_kde_major_vers LESS kde_major_vers)
+   ENDIF (req_kde_major_vers GREATER kde_major_vers)
+   MESSAGE(STATUS "KDE version ok (required: ${KDE_MIN_VERSION}, found: ${KDE_VERSION})")
+ENDIF (KDE_MIN_VERSION)
+
+#now search for the dcop utilities
+FIND_PROGRAM(KDE_DCOPIDL NAME dcopidl PATHS 
+  $ENV{KDEDIR}/bin
+  /opt/kde/bin
+  /opt/kde3/bin)
+
+IF(NOT KDE_DCOPIDL)
+   MESSAGE(FATAL_ERROR "Didn't find the dcopidl preprocessor")
+ENDIF(NOT KDE_DCOPIDL)
+
+FIND_PROGRAM(KDE_DCOPIDL2CPP NAME dcopidl2cpp PATHS 
+  $ENV{KDEDIR}/bin
+  /opt/kde/bin
+  /opt/kde3/bin)
+
+IF(NOT KDE_DCOPIDL2CPP)
+   MESSAGE(FATAL_ERROR "Didn't find the dcopidl2cpp preprocessor")
+ENDIF(NOT KDE_DCOPIDL2CPP)
+
+MACRO(DCOP_WRAP SKEL_SOURCES)
+   FOREACH(dcop_source ${ARGN})
+
+       GET_FILENAME_COMPONENT(dcop_source_basename ${dcop_source} NAME_WE)
+
+       SET(idl_file ${CMAKE_BINARY_DIR}/${dcop_source_basename}.kidl)
+       SET(skel_file ${CMAKE_BINARY_DIR}/${dcop_source_basename}_skel.cpp)
+
+       ADD_CUSTOM_COMMAND(
+         OUTPUT ${idl_file}
+         COMMAND ${KDE_DCOPIDL}
+         ARGS  ${CMAKE_SOURCE_DIR}/${dcop_source} > ${idl_file}
+         DEPENDS  ${CMAKE_SOURCE_DIR}/${dcop_source})
+
+      ADD_CUSTOM_COMMAND(
+        OUTPUT ${skel_file}
+        COMMAND ${KDE_DCOPIDL2CPP}  
+        ARGS --c++-suffix cpp --no-signals --no-stub ${idl_file}
+        DEPENDS ${idl_file})
+
+      SET( SKEL_SOURCES ${${SKEL_SOURCES}}
+        ${skel_file})
+   ENDFOREACH(dcop_source)
+ENDMACRO (DCOP_WRAP)
+
+MARK_AS_ADVANCED(
+  KDE_INCLUDE_DIR
+  KDE_LIB_DIR
+  )