build: cmake 3.1 compatibility
authorBernhard Miklautz <bernhard.miklautz@shacknet.at>
Fri, 12 Dec 2014 17:26:45 +0000 (18:26 +0100)
committerBernhard Miklautz <bernhard.miklautz@shacknet.at>
Fri, 12 Dec 2014 18:26:22 +0000 (19:26 +0100)
* fix problem with REMOVE_DUPLICATES on undefined lists
* since 3.1 file(GLOB FILEPATHS RELATIVE .. returns single / instead of // as
  previously - necessary adoptions for regex and matches done. Should
work with all cmake versions.

Tested with 3.1.0-rc3

channels/CMakeLists.txt
channels/client/CMakeLists.txt
client/CMakeLists.txt
server/CMakeLists.txt
third-party/CMakeLists.txt

index c4e6048..540b1ac 100644 (file)
@@ -253,8 +253,8 @@ set(FILENAME "ChannelOptions.cmake")
 file(GLOB FILEPATHS RELATIVE ${CMAKE_CURRENT_SOURCE_DIR} "*/${FILENAME}")
 
 foreach(FILEPATH ${FILEPATHS})
-       if(${FILEPATH} MATCHES "^([^/]*)//${FILENAME}")
-               string(REGEX REPLACE "^([^/]*)//${FILENAME}" "\\1" DIR ${FILEPATH})
+       if(${FILEPATH} MATCHES "^([^/]*)/+${FILENAME}")
+               string(REGEX REPLACE "^([^/]*)/+${FILENAME}" "\\1" DIR ${FILEPATH})
                set(CHANNEL_OPTION)
                include(${FILEPATH})
                if(${CHANNEL_OPTION})
index 049bc7b..2db18e8 100644 (file)
@@ -24,7 +24,9 @@ set(${MODULE_PREFIX}_SRCS
        ${CMAKE_CURRENT_SOURCE_DIR}/addin.c
        ${CMAKE_CURRENT_SOURCE_DIR}/addin.h)
 
+if(CHANNEL_STATIC_CLIENT_ENTRIES)
 list(REMOVE_DUPLICATES CHANNEL_STATIC_CLIENT_ENTRIES)
+endif()
 
 foreach(STATIC_ENTRY ${CHANNEL_STATIC_CLIENT_ENTRIES})
        foreach(STATIC_MODULE ${CHANNEL_STATIC_CLIENT_MODULES})
index 14ed363..b8b7699 100644 (file)
@@ -63,8 +63,8 @@ set(FILENAME "ModuleOptions.cmake")
 file(GLOB FILEPATHS RELATIVE ${CMAKE_CURRENT_SOURCE_DIR} "*/${FILENAME}")
 
 foreach(FILEPATH ${FILEPATHS})
-       if(${FILEPATH} MATCHES "^([^/]*)//${FILENAME}")
-               string(REGEX REPLACE "^([^/]*)//${FILENAME}" "\\1" FREERDP_CLIENT ${FILEPATH})
+       if(${FILEPATH} MATCHES "^([^/]*)/+${FILENAME}")
+               string(REGEX REPLACE "^([^/]*)/+${FILENAME}" "\\1" FREERDP_CLIENT ${FILEPATH})
                set(FREERDP_CLIENT_ENABLED 0)
                include(${FILEPATH})
                if(FREERDP_CLIENT_ENABLED)
index cda14ba..ee9458e 100644 (file)
@@ -48,8 +48,8 @@ set(FILENAME "ModuleOptions.cmake")
 file(GLOB FILEPATHS RELATIVE ${CMAKE_CURRENT_SOURCE_DIR} "*/${FILENAME}")
 
 foreach(FILEPATH ${FILEPATHS})
-       if(${FILEPATH} MATCHES "^([^/]*)//${FILENAME}")
-               string(REGEX REPLACE "^([^/]*)//${FILENAME}" "\\1" FREERDP_SERVER ${FILEPATH})
+       if(${FILEPATH} MATCHES "^([^/]*)/+${FILENAME}")
+               string(REGEX REPLACE "^([^/]*)/+${FILENAME}" "\\1" FREERDP_SERVER ${FILEPATH})
                set(FREERDP_SERVER_ENABLED 0)
                include(${FILEPATH})
                if(FREERDP_SERVER_ENABLED)
index 09b1fd4..610f35e 100644 (file)
 file(GLOB all_valid_subdirs RELATIVE ${CMAKE_CURRENT_SOURCE_DIR} "*/CMakeLists.txt")
 
 foreach(dir ${all_valid_subdirs})
-       if(${dir} MATCHES "^([^/]*)//CMakeLists.txt")
-               string(REGEX REPLACE "^([^/]*)//CMakeLists.txt" "\\1" dir_trimmed ${dir})
+       if(${dir} MATCHES "^([^/]*)/+CMakeLists.txt")
+               string(REGEX REPLACE "^([^/]*)/+CMakeLists.txt" "\\1" dir_trimmed ${dir})
                message(STATUS "Adding third-party component ${dir_trimmed}")
                add_subdirectory(${dir_trimmed})
        endif()
 endforeach(dir)
 
-set(THIRD_PARTY_INCLUDES ${THIRD_PARTY_INCLUDES} PARENT_SCOPE)
\ No newline at end of file
+set(THIRD_PARTY_INCLUDES ${THIRD_PARTY_INCLUDES} PARENT_SCOPE)