Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/Remmina/Remmina.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAntenore Gatta <antenore.gatta@kyndryl.com>2021-10-29 13:30:51 +0300
committerAntenore Gatta <antenore.gatta@kyndryl.com>2021-10-29 13:30:51 +0300
commit6eccc4844cb508d29afc1d503ae0df9816a99885 (patch)
tree0f4c6e7e618bd8d862480bad976fa8dfdba11178 /CMakeLists.txt
parent7f8519c0c6ea7eedaa30d121e0d99f98ae3b3b7a (diff)
Updating to CMake 3.10.0 specs
Diffstat (limited to 'CMakeLists.txt')
-rw-r--r--CMakeLists.txt639
1 files changed, 326 insertions, 313 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 66e977a3a..42b5d520f 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -29,16 +29,24 @@
# this exception statement from all source files in the program, then also
# delete it here.
-cmake_minimum_required(VERSION 3.4.0)
+cmake_minimum_required(VERSION 3.10.0)
+
+cmake_policy(SET CMP0048 NEW)
+
+project(
+ Remmina
+ VERSION 1.4.21
+ DESCRIPTION "The Gtk Remote Desktop Client"
+ LANGUAGES C CXX
+)
list(APPEND CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_SOURCE_DIR}/cmake)
-list(APPEND CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_SOURCE_DIR}/cmake/macros)
+list(APPEND CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH}
+ ${CMAKE_SOURCE_DIR}/cmake/macros)
set(CMAKE_COLOR_MAKEFILE ON)
set(CMAKE_EXPORT_COMPILE_COMMANDS ON)
-project(Remmina C CXX)
-
include(CheckCCompilerFlag)
include(CheckIncludeFiles)
include(CheckLibraryExists)
@@ -54,20 +62,24 @@ include(FindPCRE2)
include(GlibCompileResourcesSupport)
include(FindIntl)
-#---------------------------------------------------------------------
-# Package creation with CMake depends on the value of umask - if permissions
-# are such that temporary files are created without permissions needed for
-# generated packages, the resulting packages may behave badly when installed.
-# In particular, RPM packages may improperly reset permissions on core
-# directories such as /usr.
+# ---------------------------------------------------------------------
+# Package creation with CMake depends on the value of umask - if permissions are
+# such that temporary files are created without permissions needed for generated
+# packages, the resulting packages may behave badly when installed. In
+# particular, RPM packages may improperly reset permissions on core directories
+# such as /usr.
function(check_umask umask_val status_var)
- string(REGEX REPLACE "[^x]" "" umask_x "${umask_val}")
- string(REGEX REPLACE "[^r]" "" umask_r "${umask_val}")
- string(LENGTH "${umask_r}" UMASK_HAVE_R)
- set(${status_var} 0 PARENT_SCOPE)
- if(UMASK_HAVE_R AND "${umask_x}" STREQUAL "xxx")
- set(${status_var} 1 PARENT_SCOPE)
- endif()
+ string(REGEX REPLACE "[^x]" "" umask_x "${umask_val}")
+ string(REGEX REPLACE "[^r]" "" umask_r "${umask_val}")
+ string(LENGTH "${umask_r}" UMASK_HAVE_R)
+ set(${status_var}
+ 0
+ PARENT_SCOPE)
+ if(UMASK_HAVE_R AND "${umask_x}" STREQUAL "xxx")
+ set(${status_var}
+ 1
+ PARENT_SCOPE)
+ endif()
endfunction()
find_program(SLEEP_EXEC sleep)
@@ -78,176 +90,184 @@ mark_as_advanced(SLEEP_EXEC)
find_program(UMASK_EXEC umask)
mark_as_advanced(UMASK_EXEC)
if(NOT UMASK_EXEC)
- # If we don't have a umask cmd, see if sh -c "umask -S" works
- execute_process(COMMAND sh -c "umask -S" OUTPUT_VARIABLE umask_out)
- # Check if we've got something that looks like a umask output
- if("${umask_out}" MATCHES "^u=.*g=.*o=.*")
- set(UMASK_EXEC sh)
- set(UMASK_EXEC_ARGS -c "umask -S")
- endif()
+ # If we don't have a umask cmd, see if sh -c "umask -S" works
+ execute_process(COMMAND sh -c "umask -S" OUTPUT_VARIABLE umask_out)
+ # Check if we've got something that looks like a umask output
+ if("${umask_out}" MATCHES "^u=.*g=.*o=.*")
+ set(UMASK_EXEC sh)
+ set(UMASK_EXEC_ARGS -c "umask -S")
+ endif()
else()
- set(UMASK_EXEC_ARGS -S)
+ set(UMASK_EXEC_ARGS -S)
endif()
if(UMASK_EXEC)
- execute_process(COMMAND ${UMASK_EXEC} ${UMASK_EXEC_ARGS} OUTPUT_VARIABLE umask_curr)
- string(STRIP "${umask_curr}" umask_curr)
- check_umask("${umask_curr}" UMASK_OK)
- if(NOT UMASK_OK)
- message(" ")
- message(WARNING "umask is set to ${umask_curr} - this setting is not recommended if one of the goals of this build is to generate packages. Use 'umask 022' for improved package behavior.")
- if(SLEEP_EXEC)
- execute_process(COMMAND ${SLEEP_EXEC} 10)
- endif()
+ execute_process(COMMAND ${UMASK_EXEC} ${UMASK_EXEC_ARGS}
+ OUTPUT_VARIABLE umask_curr)
+ string(STRIP "${umask_curr}" umask_curr)
+ check_umask("${umask_curr}" UMASK_OK)
+ if(NOT UMASK_OK)
+ message(" ")
+ message(
+ WARNING
+ "\
+ umask is set to ${umask_curr} - this setting is not recommended if one\
+ of the goals of this build is to generate packages. Use 'umask 022' \
+ for improved package behavior.
+ ")
+ if(SLEEP_EXEC)
+ execute_process(COMMAND ${SLEEP_EXEC} 10)
endif()
+ endif()
endif()
if(NOT CMAKE_BUILD_TYPE)
- set(CMAKE_BUILD_TYPE "Release")
+ set(CMAKE_BUILD_TYPE "Release")
endif()
if(NOT BUILD_SHARED_LIBS)
- set(BUILD_SHARED_LIBS ON)
+ set(BUILD_SHARED_LIBS ON)
endif()
if(CMAKE_COMPILER_IS_GNUCC)
- if(CMAKE_SYSTEM_PROCESSOR MATCHES "x86_64" OR CMAKE_SYSTEM_PROCESSOR MATCHES
- "i686")
- check_symbol_exists(__x86_64__ "" IS_X86_64)
- if(IS_X86_64)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fPIC")
- else()
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -march=i686")
- endif()
+ if(CMAKE_SYSTEM_PROCESSOR MATCHES "x86_64" OR CMAKE_SYSTEM_PROCESSOR MATCHES
+ "i686")
+ check_symbol_exists(__x86_64__ "" IS_X86_64)
+ if(IS_X86_64)
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fPIC")
else()
- if(CMAKE_POSITION_INDEPENDENT_CODE)
- if(${CMAKE_VERSION} VERSION_LESS 2.8.9)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fPIC")
- endif()
- endif()
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -march=i686")
endif()
+ else()
+ if(CMAKE_POSITION_INDEPENDENT_CODE)
+ if(${CMAKE_VERSION} VERSION_LESS 2.8.9)
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fPIC")
+ endif()
+ endif()
+ endif()
+
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall")
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall")
+ if(WITH_SSE2)
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -msse2")
+ endif()
+
+ if(CMAKE_BUILD_TYPE STREQUAL "Debug")
+ add_definitions(-DDEBUG)
+ check_c_compiler_flag(-Wunused-result Wunused-result)
+ if(Wunused-result)
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wunused-result")
+ endif()
+ check_c_compiler_flag(-Wunused-but-set-variable Wunused-but-set-variable)
+ if(Wunused-but-set-variable)
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wunused-but-set-variable")
+ endif()
+ check_c_compiler_flag(-Wdeprecated-declarations Wdeprecated-declarations)
+ if(Wdeprecated-declarations)
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wdeprecated-declarations")
+ endif()
- if(WITH_SSE2)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -msse2")
+ check_c_compiler_flag(-Wimplicit-function-declaration
+ Wimplicit-function-declaration)
+ if(Wimplicit-function-declaration)
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wimplicit-function-declaration")
+ endif()
+ if(NOT OPENBSD)
+ check_c_compiler_flag(-Wredundant-decls Wredundant-decls)
+ if(Wredundant-decls)
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wredundant-decls")
+ endif()
endif()
+ endif()
- if(CMAKE_BUILD_TYPE STREQUAL "Debug")
- add_definitions(-DDEBUG)
- check_c_compiler_flag(-Wunused-result Wunused-result)
- if(Wunused-result)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wunused-result")
- endif()
- check_c_compiler_flag(-Wunused-but-set-variable Wunused-but-set-variable)
- if(Wunused-but-set-variable)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wunused-but-set-variable")
- endif()
- check_c_compiler_flag(-Wdeprecated-declarations Wdeprecated-declarations)
- if(Wdeprecated-declarations)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wdeprecated-declarations")
- endif()
-
- check_c_compiler_flag(-Wimplicit-function-declaration
- Wimplicit-function-declaration)
- if(Wimplicit-function-declaration)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wimplicit-function-declaration")
- endif()
- if(NOT OPENBSD)
- check_c_compiler_flag(-Wredundant-decls Wredundant-decls)
- if(Wredundant-decls)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wredundant-decls")
- endif()
- endif()
+ if(CMAKE_BUILD_TYPE STREQUAL "Release")
+ add_definitions(-DNDEBUG)
+ check_c_compiler_flag(-Wno-unused-result Wno-unused-result)
+ if(Wno-unused-result)
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-result")
+ endif()
+ check_c_compiler_flag(-Wno-unused-but-set-variable
+ Wno-unused-but-set-variable)
+ if(Wno-unused-but-set-variable)
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-but-set-variable")
+ endif()
+ check_c_compiler_flag(-Wno-deprecated-declarations
+ Wno-deprecated-declarations)
+ if(Wno-deprecated-declarations)
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-deprecated-declarations")
endif()
- if(CMAKE_BUILD_TYPE STREQUAL "Release")
- add_definitions(-DNDEBUG)
- check_c_compiler_flag(-Wno-unused-result Wno-unused-result)
- if(Wno-unused-result)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-result")
- endif()
- check_c_compiler_flag(-Wno-unused-but-set-variable
- Wno-unused-but-set-variable)
- if(Wno-unused-but-set-variable)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-but-set-variable")
- endif()
- check_c_compiler_flag(-Wno-deprecated-declarations
- Wno-deprecated-declarations)
- if(Wno-deprecated-declarations)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-deprecated-declarations")
- endif()
-
- check_c_compiler_flag(-Wimplicit-function-declaration
- Wimplicit-function-declaration)
- if(Wimplicit-function-declaration)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wimplicit-function-declaration")
- endif()
- if(NOT OPENBSD)
- check_c_compiler_flag(-Wredundant-decls Wredundant-decls)
- if(Wredundant-decls)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wredundant-decls")
- endif()
- endif()
- else()
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -g")
+ check_c_compiler_flag(-Wimplicit-function-declaration
+ Wimplicit-function-declaration)
+ if(Wimplicit-function-declaration)
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wimplicit-function-declaration")
+ endif()
+ if(NOT OPENBSD)
+ check_c_compiler_flag(-Wredundant-decls Wredundant-decls)
+ if(Wredundant-decls)
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wredundant-decls")
+ endif()
endif()
+ else()
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -g")
+ endif()
endif()
if((TARGET_ARCH MATCHES "x86|x64") AND (NOT DEFINED WITH_SSE2))
- option(WITH_SSE2 "Enable SSE2 optimization." ON)
+ option(WITH_SSE2 "Enable SSE2 optimization." ON)
else()
- option(WITH_SSE2 "Enable SSE2 optimization." OFF)
+ option(WITH_SSE2 "Enable SSE2 optimization." OFF)
endif()
if(TARGET_ARCH MATCHES "ARM")
- if(NOT DEFINED WITH_NEON)
- option(WITH_NEON "Enable NEON optimization." ON)
- else()
- option(WITH_NEON "Enable NEON optimization." OFF)
- endif()
+ if(NOT DEFINED WITH_NEON)
+ option(WITH_NEON "Enable NEON optimization." ON)
+ else()
+ option(WITH_NEON "Enable NEON optimization." OFF)
+ endif()
else()
- if(NOT APPLE)
- option(WITH_IPP "Use Intel Performance Primitives." OFF)
- endif()
+ if(NOT APPLE)
+ option(WITH_IPP "Use Intel Performance Primitives." OFF)
+ endif()
endif()
if(${CMAKE_C_COMPILER_ID} STREQUAL "Clang")
- if(CMAKE_BUILD_TYPE STREQUAL "Release")
- add_definitions(-DNDEBUG)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-parameter")
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros -Wno-padded")
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-c11-extensions -Wno-gnu")
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-command-line-argument")
- check_c_compiler_flag(-Wno-deprecated-declarations
- Wno-deprecated-declarations)
- if(Wno-deprecated-declarations)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-deprecated-declarations")
- endif()
- else()
- add_definitions(-DDEBUG)
- # set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wunused-parameter") set(CMAKE_C_FLAGS
- # "${CMAKE_C_FLAGS} -Wunused-macros -Wpadded") set(CMAKE_C_FLAGS
- # "${CMAKE_C_FLAGS} -Wc11-extensions -Wgnu") set(CMAKE_C_FLAGS
- # "${CMAKE_C_FLAGS} -Wunused-command-line-argument")
- check_c_compiler_flag(-Wdeprecated-declarations Wdeprecated-declarations)
- if(Wdeprecated-declarations)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wdeprecated-declarations")
- endif()
+ if(CMAKE_BUILD_TYPE STREQUAL "Release")
+ add_definitions(-DNDEBUG)
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-parameter")
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-macros -Wno-padded")
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-c11-extensions -Wno-gnu")
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-command-line-argument")
+ check_c_compiler_flag(-Wno-deprecated-declarations
+ Wno-deprecated-declarations)
+ if(Wno-deprecated-declarations)
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-deprecated-declarations")
+ endif()
+ else()
+ add_definitions(-DDEBUG)
+ # set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wunused-parameter") set(CMAKE_C_FLAGS
+ # "${CMAKE_C_FLAGS} -Wunused-macros -Wpadded") set(CMAKE_C_FLAGS
+ # "${CMAKE_C_FLAGS} -Wc11-extensions -Wgnu") set(CMAKE_C_FLAGS
+ # "${CMAKE_C_FLAGS} -Wunused-command-line-argument")
+ check_c_compiler_flag(-Wdeprecated-declarations Wdeprecated-declarations)
+ if(Wdeprecated-declarations)
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wdeprecated-declarations")
endif()
+ endif()
endif()
# Figure out no-undefined flag
if(${CMAKE_SYSTEM_NAME} STREQUAL Darwin)
- set(NO_UNDEFINED_FLAG "-Wl,-undefined,error")
+ set(NO_UNDEFINED_FLAG "-Wl,-undefined,error")
elseif((${CMAKE_SYSTEM_NAME} STREQUAL Linux) OR MINGW)
- set(NO_UNDEFINED_FLAG "-Wl,--no-undefined")
+ set(NO_UNDEFINED_FLAG "-Wl,--no-undefined")
else()
- # On OpenBSD this seems to cause problems, so we unset it
- set(NO_UNDEFINED_FLAG "")
+ # On OpenBSD this seems to cause problems, so we unset it
+ set(NO_UNDEFINED_FLAG "")
endif()
-set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} ${NO_UNDEFINED_FLAG}")
+set(CMAKE_SHARED_LINKER_FLAGS
+ "${CMAKE_SHARED_LINKER_FLAGS} ${NO_UNDEFINED_FLAG}")
check_include_files(sys/socket.h HAVE_SYS_SOCKET_H)
check_include_files(arpa/inet.h HAVE_ARPA_INET_H)
@@ -266,30 +286,22 @@ include_directories(src/include)
# FreeBSD
if(CMAKE_SYSTEM_NAME MATCHES "FreeBSD")
- set(CMAKE_SHARED_LIBRARY_LINK_C_FLAGS "-rdynamic")
- include_directories(/usr/local/include /usr/include)
- link_directories(/usr/local/lib /usr/lib)
- set(CMAKE_REQUIRED_INCLUDES /usr/local/include)
- set(CMAKE_SHARED_LIBRARY_PREFIX ${CMAKE_SHARED_LIBRARY_PREFIX} /usr/local/lib)
+ set(CMAKE_SHARED_LIBRARY_LINK_C_FLAGS "-rdynamic")
+ include_directories(/usr/local/include /usr/include)
+ link_directories(/usr/local/lib /usr/lib)
+ set(CMAKE_REQUIRED_INCLUDES /usr/local/include)
+ set(CMAKE_SHARED_LIBRARY_PREFIX ${CMAKE_SHARED_LIBRARY_PREFIX} /usr/local/lib)
endif()
# Versioning
set(WITH_LIBRARY_VERSIONING "ON")
-set(REMMINA_VERSION_MAJOR "1")
-set(REMMINA_VERSION_MINOR "4")
-set(REMMINA_VERSION_REVISION "21")
-# set(REMMINA_VERSION_SUFFIX "1") set(REMMINA_VERSION
-# "${REMMINA_VERSION_MAJOR}.${REMMINA_VERSION_MINOR}.${REMMINA_VERSION_REVISION}.${REMMINA_VERSION_SUFFIX}")
-set(REMMINA_VERSION
- "${REMMINA_VERSION_MAJOR}.${REMMINA_VERSION_MINOR}.${REMMINA_VERSION_REVISION}"
- )
-message(STATUS "Remmina version: ${REMMINA_VERSION}")
+message(STATUS "Remmina version: ${Remmina_VERSION}")
include(GetGitRevisionDescription)
git_get_exact_tag(REMMINA_GIT_REVISION --tags --always)
if(${REMMINA_GIT_REVISION} STREQUAL "n/a")
- git_rev_parse(REMMINA_GIT_REVISION --short)
+ git_rev_parse(REMMINA_GIT_REVISION --short)
endif()
message(STATUS "Git Revision: ${REMMINA_GIT_REVISION}")
@@ -298,257 +310,259 @@ message(STATUS "Git Revision: ${REMMINA_GIT_REVISION}")
set(REMMINA_APP_ID "org.remmina.Remmina")
if(NOT REMMINA_DATADIR)
- set(REMMINA_DATADIR "${CMAKE_INSTALL_FULL_DATADIR}")
- if(NOT REMMINA_RUNTIME_DATADIR)
- set(REMMINA_RUNTIME_DATADIR "${REMMINA_DATADIR}")
- endif()
+ set(REMMINA_DATADIR "${CMAKE_INSTALL_FULL_DATADIR}")
+ if(NOT REMMINA_RUNTIME_DATADIR)
+ set(REMMINA_RUNTIME_DATADIR "${REMMINA_DATADIR}")
+ endif()
endif()
if(NOT REMMINA_TERM_CS_DIR)
- set(REMMINA_TERM_CS_DIR "${REMMINA_DATADIR}/remmina/theme")
+ set(REMMINA_TERM_CS_DIR "${REMMINA_DATADIR}/remmina/theme")
endif()
if(NOT REMMINA_LOCALEDIR)
- set(REMMINA_LOCALEDIR "${CMAKE_INSTALL_FULL_LOCALEDIR}")
- if(NOT REMMINA_RUNTIME_LOCALEDIR)
- set(REMMINA_RUNTIME_LOCALEDIR "${REMMINA_LOCALEDIR}")
- endif()
+ set(REMMINA_LOCALEDIR "${CMAKE_INSTALL_FULL_LOCALEDIR}")
+ if(NOT REMMINA_RUNTIME_LOCALEDIR)
+ set(REMMINA_RUNTIME_LOCALEDIR "${REMMINA_LOCALEDIR}")
+ endif()
endif()
if(NOT REMMINA_PLUGINDIR)
- set(REMMINA_PLUGINDIR "${CMAKE_INSTALL_FULL_LIBDIR}/remmina/plugins")
- if(NOT REMMINA_RUNTIME_PLUGINDIR)
- set(REMMINA_RUNTIME_PLUGINDIR "${REMMINA_PLUGINDIR}")
- endif()
+ set(REMMINA_PLUGINDIR "${CMAKE_INSTALL_FULL_LIBDIR}/remmina/plugins")
+ if(NOT REMMINA_RUNTIME_PLUGINDIR)
+ set(REMMINA_RUNTIME_PLUGINDIR "${REMMINA_PLUGINDIR}")
+ endif()
endif()
if(NOT REMMINA_UIDIR)
- set(REMMINA_UIDIR "${REMMINA_DATADIR}/remmina/ui")
- if(NOT REMMINA_RUNTIME_UIDIR)
- set(REMMINA_RUNTIME_UIDIR "${REMMINA_UIDIR}")
- endif()
+ set(REMMINA_UIDIR "${REMMINA_DATADIR}/remmina/ui")
+ if(NOT REMMINA_RUNTIME_UIDIR)
+ set(REMMINA_RUNTIME_UIDIR "${REMMINA_UIDIR}")
+ endif()
endif()
if(NOT REMMINA_THEMEDIR)
- set(REMMINA_THEMEDIR "${REMMINA_DATADIR}/remmina/theme")
- if(NOT REMMINA_RUNTIME_THEMEDIR)
- set(REMMINA_RUNTIME_THEMEDIR "${REMMINA_THEMEDIR}")
- endif()
+ set(REMMINA_THEMEDIR "${REMMINA_DATADIR}/remmina/theme")
+ if(NOT REMMINA_RUNTIME_THEMEDIR)
+ set(REMMINA_RUNTIME_THEMEDIR "${REMMINA_THEMEDIR}")
+ endif()
endif()
if(NOT REMMINA_RESDIR)
- set(REMMINA_RESDIR "${REMMINA_DATADIR}/remmina/res")
- if(NOT REMMINA_RUNTIME_RESDIR)
- set(REMMINA_RUNTIME_RESDIR "${REMMINA_RESDIR}")
- endif()
+ set(REMMINA_RESDIR "${REMMINA_DATADIR}/remmina/res")
+ if(NOT REMMINA_RUNTIME_RESDIR)
+ set(REMMINA_RUNTIME_RESDIR "${REMMINA_RESDIR}")
+ endif()
endif()
if(NOT REMMINA_EXTERNAL_TOOLS_DIR)
- set(REMMINA_EXTERNAL_TOOLS_DIR "${REMMINA_DATADIR}/remmina/external_tools")
- if(NOT REMMINA_RUNTIME_EXTERNAL_TOOLS_DIR)
- set(REMMINA_RUNTIME_EXTERNAL_TOOLS_DIR "${REMMINA_EXTERNAL_TOOLS_DIR}")
- endif()
+ set(REMMINA_EXTERNAL_TOOLS_DIR "${REMMINA_DATADIR}/remmina/external_tools")
+ if(NOT REMMINA_RUNTIME_EXTERNAL_TOOLS_DIR)
+ set(REMMINA_RUNTIME_EXTERNAL_TOOLS_DIR "${REMMINA_EXTERNAL_TOOLS_DIR}")
+ endif()
endif()
option(SNAP_BUILD_ONLY "SNAP_BUILD_ONLY" OFF)
if(SNAP_BUILD_ONLY)
- if(NOT SNAPCRAFT)
- message(
- FATAL_ERROR "snapcraft not found, impossible to create only snap target")
- endif()
- return()
+ if(NOT SNAPCRAFT)
+ message(
+ FATAL_ERROR "snapcraft not found, impossible to create only snap target")
+ endif()
+ return()
endif()
if(SNAP_BUILD)
- add_definitions(-DSNAP_BUILD)
+ add_definitions(-DSNAP_BUILD)
endif()
# Uninstall support
-# setup a 'make uninstall' target if we find a
-# cmake_uninstall.cmake.in in the module path
-#===========================================================
-foreach( MODULE_PATH ${CMAKE_MODULE_PATH} )
- set( UNINSTALL_IN "${MODULE_PATH}/cmake_uninstall.cmake.in" )
- set( UNINSTALL_OUT "${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake" )
- if( EXISTS ${UNINSTALL_IN} )
- configure_file("${UNINSTALL_IN}"
- "${UNINSTALL_OUT}"
- IMMEDIATE @ONLY
- )
- if(WITH_CLEANUP)
- message(STATUS "Remove folders during uninstall target")
- add_definitions(-DREMOVE_DIRS)
- set(UNINST_RMDIRS 1)
- else()
- message(STATUS "Folders won't be removed during uninstall target")
- set(UNINST_RMDIRS 0)
- endif()
- add_custom_target(uninstall
- "${CMAKE_COMMAND}" -DWITH_CLEANUP:BOOL=${WITH_CLEANUP} -P "${UNINSTALL_OUT}")
- option(WITH_CLEANUP "Remove folders during uninstall target" OFF)
- break()
+# setup a 'make uninstall' target if we find a cmake_uninstall.cmake.in in the
+# module path
+# ===========================================================
+foreach(module_path ${CMAKE_MODULE_PATH})
+ set(UNINSTALL_in "${module_path}/cmake_uninstall.cmake.in")
+ set(UNINSTALL_out "${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake")
+ if(EXISTS ${UNINSTALL_in})
+ configure_file("${UNINSTALL_in}" "${UNINSTALL_out}" IMMEDIATE @ONLY)
+ if(WITH_CLEANUP)
+ message(STATUS "Remove folders during uninstall target")
+ add_definitions(-DREMOVE_DIRS)
+ set(UNINST_RMDIRS 1)
+ else()
+ message(STATUS "Folders won't be removed during uninstall target")
+ set(UNINST_RMDIRS 0)
endif()
+ add_custom_target(
+ uninstall
+ "${CMAKE_COMMAND}" -DWITH_CLEANUP:BOOL=${WITH_CLEANUP} -P
+ "${UNINSTALL_out}"
+ COMMENT "Uninstall target")
+ option(WITH_CLEANUP "Remove folders during uninstall target" OFF)
+ break()
+ endif()
endforeach()
-#find_required_package(GTK)
+# find_required_package(GTK)
find_package(GLib REQUIRED)
if(NOT GLib_FOUND)
- message(FATAL_ERROR "GLIB2 library not found")
+ message(FATAL_ERROR "GLIB2 library not found")
endif()
include_directories(${GLib_INCLUDE_DIRS})
include_directories(${GMODULE_INCLUDE_DIR})
find_package(GTK3 3.14.0 REQUIRED)
if(NOT GTK3_FOUND)
- message(FATAL_ERROR "GTK3 library not found")
+ message(FATAL_ERROR "GTK3 library not found")
endif()
include_directories(${GTK3_INCLUDE_DIRS})
pkg_check_modules(wayland-client wayland-client)
if(wayland-client_FOUND)
- set(GTK_LIBRARIES
- ${GTK3_LIBRARY}
- ${GDK3_LIBRARY}
- ${GDKPixbuf_LIBRARY}
- ${Pango_LIBRARY}
- ${Cairo_LIBRARY}
- ${GObject_LIBRARY}
- ${GLib_LIBRARY}
- ${GIO_LIBRARY}
- ${Gmodule_LIBRARIES}
- ${GMODULE_LIBRARY}
- ${wayland-client_LIBRARIES}
- )
- include_directories(${wayland-client_INCLUDE_DIRS})
- message(STATUS "Wayland library found.")
+ set(GTK_LIBRARIES
+ ${GTK3_LIBRARY}
+ ${GDK3_LIBRARY}
+ ${GDKPixbuf_LIBRARY}
+ ${Pango_LIBRARY}
+ ${Cairo_LIBRARY}
+ ${GObject_LIBRARY}
+ ${GLib_LIBRARY}
+ ${GIO_LIBRARY}
+ ${Gmodule_LIBRARIES}
+ ${GMODULE_LIBRARY}
+ ${wayland-client_LIBRARIES})
+ include_directories(${wayland-client_INCLUDE_DIRS})
+ message(STATUS "Wayland library found.")
else()
- set(GTK_LIBRARIES
- ${GTK3_LIBRARY}
- ${GDK3_LIBRARY}
- ${GDKPixbuf_LIBRARY}
- ${Pango_LIBRARY}
- ${Cairo_LIBRARY}
- ${GObject_LIBRARY}
- ${GLib_LIBRARY}
- ${GIO_LIBRARY}
- ${Gmodule_LIBRARIES}
- ${GMODULE_LIBRARY}
- )
- message(STATUS "Wayland library not found.")
+ set(GTK_LIBRARIES
+ ${GTK3_LIBRARY}
+ ${GDK3_LIBRARY}
+ ${GDKPixbuf_LIBRARY}
+ ${Pango_LIBRARY}
+ ${Cairo_LIBRARY}
+ ${GObject_LIBRARY}
+ ${GLib_LIBRARY}
+ ${GIO_LIBRARY}
+ ${Gmodule_LIBRARIES}
+ ${GMODULE_LIBRARY})
+ message(STATUS "Wayland library not found.")
endif()
set(CMAKE_THREAD_PREFER_PTHREAD TRUE)
find_package(Threads REQUIRED)
if(NOT CMAKE_USE_PTHREADS_INIT)
- message(FATAL_ERROR "pthreads thread library not found")
+ message(FATAL_ERROR "pthreads thread library not found")
endif()
# Add GCC sanitizer options, must be done after pthreads detection see remmina
# issue #1276
if(CMAKE_COMPILER_IS_GNUCC AND WITH_GCC_SANITIZE_ADDRESS)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fsanitize=address")
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fsanitize=address")
endif()
# LLVM coverage flags - https://clang.llvm.org/docs/SourceBasedCodeCoverage.html
if("${CMAKE_C_COMPILER_ID}" MATCHES "Clang" AND WITH_CLANG_COVERAGE)
- message(STATUS "Enabling coverage.")
- add_definitions(-DWITH_CLANG_COVERAGE)
- set(CMAKE_C_FLAGS
- "${CMAKE_C_FLAGS} -g -fprofile-instr-generate -fcoverage-mapping -ftest-coverage"
- )
- set(CMAKE_EXE_LINKER_FLAGS
- "${CMAKE_EXE_LINKER_FLAGS} -fprofile-instr-generate")
+ message(STATUS "Enabling coverage.")
+ add_definitions(-DWITH_CLANG_COVERAGE)
+ set(CMAKE_C_FLAGS
+ "\
+ ${CMAKE_C_FLAGS} -g -fprofile-instr-generate \
+ -fcoverage-mapping -ftest-coverage\
+ ")
+ set(CMAKE_EXE_LINKER_FLAGS
+ "${CMAKE_EXE_LINKER_FLAGS} -fprofile-instr-generate")
elseif("${CMAKE_C_COMPILER_ID}" MATCHES "GNU" AND WITH_GCC_PROFILING)
- message(STATUS "Enabling profiling.")
- add_definitions(-DWITH_GCC_PROFILING)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -pg")
+ message(STATUS "Enabling profiling.")
+ add_definitions(-DWITH_GCC_PROFILING)
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -pg")
endif()
find_suggested_package(GCRYPT)
find_package(OpenSSL)
find_package(sodium REQUIRED)
if(sodium_FOUND)
- message(STATUS "sodium_LIBRARY_RELEASE: ${sodium_LIBRARY_RELEASE}")
- message(STATUS "sodium_INCLUDE_DIR: ${sodium_INCLUDE_DIR}")
- message(STATUS "sodium_LIBRARY_DEBUG: ${sodium_LIBRARY_DEBUG}")
+ message(STATUS "sodium_LIBRARY_RELEASE: ${sodium_LIBRARY_RELEASE}")
+ message(STATUS "sodium_INCLUDE_DIR: ${sodium_INCLUDE_DIR}")
+ message(STATUS "sodium_LIBRARY_DEBUG: ${sodium_LIBRARY_DEBUG}")
endif()
option(TOGTK4 "Disable deprecations to easy GTK4 migration")
if(TOGTK4)
- message(STATUS "Do not use GTK3 and GDK deprecated symbols")
- add_definitions(-DGDK_DISABLE_DEPRECATED -DGTK_DISABLE_DEPRECATED)
+ message(STATUS "Do not use GTK3 and GDK deprecated symbols")
+ add_definitions(-DGDK_DISABLE_DEPRECATED -DGTK_DISABLE_DEPRECATED)
endif()
if(WITH_TRACE_CALLS)
- message(STATUS "Enabling trace calls.")
- add_definitions(-DWITH_TRACE_CALLS)
+ message(STATUS "Enabling trace calls.")
+ add_definitions(-DWITH_TRACE_CALLS)
endif()
option(WITH_NEWS "Disable online version checking" ON)
if(WITH_NEWS)
- message(STATUS "Enabling version check connecting to remmina.org")
- add_definitions(-DWITH_NEWS)
- set(RMNEWS_ENABLE_NEWS 1)
+ message(STATUS "Enabling version check connecting to remmina.org")
+ add_definitions(-DWITH_NEWS)
+ set(RMNEWS_ENABLE_NEWS 1)
else()
- message(STATUS "Disabling version check connecting to remmina.org")
- set(RMNEWS_ENABLE_NEWS 0)
+ message(STATUS "Disabling version check connecting to remmina.org")
+ set(RMNEWS_ENABLE_NEWS 0)
endif()
option(WITH_MANPAGES "Build with MANPAGES" ON)
if(WITH_MANPAGES)
- message(STATUS "Enabling man pages.")
- add_definitions(-DWITH_MANPAGES)
+ message(STATUS "Enabling man pages.")
+ add_definitions(-DWITH_MANPAGES)
else()
- message(STATUS "Man pages disabled")
+ message(STATUS "Man pages disabled")
endif()
if(GCRYPT_FOUND)
- add_definitions(-DHAVE_LIBGCRYPT)
+ add_definitions(-DHAVE_LIBGCRYPT)
endif()
-#avahi for discovery over mDNS/DNS-SD daemon
+# avahi for discovery over mDNS/DNS-SD daemon
if(UNIX AND NOT APPLE)
- find_suggested_package(Avahi)
- if(AVAHI_FOUND)
- message(STATUS "AVAHI_INCLUDE_DIRS=${AVAHI_INCLUDE_DIRS}")
- message(STATUS "AVAHI_LIBRARIES=${AVAHI_LIBRARIES}")
- add_definitions(-DHAVE_LIBAVAHI_UI)
- add_definitions(-DHAVE_LIBAVAHI_CLIENT)
- endif()
+ find_suggested_package(Avahi)
+ if(AVAHI_FOUND)
+ message(STATUS "AVAHI_INCLUDE_DIRS=${AVAHI_INCLUDE_DIRS}")
+ message(STATUS "AVAHI_LIBRARIES=${AVAHI_LIBRARIES}")
+ add_definitions(-DHAVE_LIBAVAHI_UI)
+ add_definitions(-DHAVE_LIBAVAHI_CLIENT)
+ endif()
endif()
option(WITH_ICON_CACHE "Generate the icon cache during install target" ON)
if(WITH_ICON_CACHE)
- message(STATUS "Icon cache will be generated")
- add_definitions(-DWITH_ICON_CACHE)
- find_program(XDG_ICON_RESOURCE NAMES xdg-icon-resource)
- if(XDG_ICON_RESOURCE)
- message(STATUS "Theme icon cache will be rebuilt")
- add_custom_target(desktop-icon COMMAND ${XDG_ICON_RESOURCE} forceupdate
- --theme hicolor)
- else()
- message(WARNING "Cannot update icon cache: xdg-icon-resource not found")
- endif()
+ message(STATUS "Icon cache will be generated")
+ add_definitions(-DWITH_ICON_CACHE)
+ find_program(XDG_ICON_RESOURCE NAMES xdg-icon-resource)
+ if(XDG_ICON_RESOURCE)
+ message(STATUS "Theme icon cache will be rebuilt")
+ add_custom_target(
+ desktop-icon
+ COMMAND ${XDG_ICON_RESOURCE} forceupdate --theme hicolor
+ COMMENT "Updating icon theme")
+ else()
+ message(WARNING "Cannot update icon cache: xdg-icon-resource not found")
+ endif()
else()
- message(STATUS "Icons cache won't be generated automatically")
+ message(STATUS "Icons cache won't be generated automatically")
endif()
option(WITH_UPDATE_DESKTOP_DB
- "Generate desktop files MIME types cache database" ON)
+ "Generate desktop files MIME types cache database" ON)
if(WITH_UPDATE_DESKTOP_DB)
- message(STATUS "Desktop MIME types cache database enabled")
- add_definitions(-DWITH_UPDATE_DESKTOP_DB)
+ message(STATUS "Desktop MIME types cache database enabled")
+ add_definitions(-DWITH_UPDATE_DESKTOP_DB)
else()
- message(STATUS "Desktop MIME types cache database won't be generated")
+ message(STATUS "Desktop MIME types cache database won't be generated")
endif()
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/config.h.in
- ${CMAKE_CURRENT_BINARY_DIR}/generated/config.h)
+ ${CMAKE_CURRENT_BINARY_DIR}/generated/config.h)
set(REMMINA_BUILD_CONFIG_LIST "")
get_cmake_property(res VARIABLES)
foreach(var ${res})
- if(var MATCHES "^WITH_*|^HAVE_*")
- list(APPEND REMMINA_BUILD_CONFIG_LIST "${var}=${${var}}")
- endif()
+ if(var MATCHES "^WITH_*|^HAVE_*")
+ list(APPEND REMMINA_BUILD_CONFIG_LIST "${var}=${${var}}")
+ endif()
endforeach()
string(REPLACE ";" " " REMMINA_BUILD_CONFIG "${REMMINA_BUILD_CONFIG_LIST}")
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/buildflags.h.in
- ${CMAKE_CURRENT_BINARY_DIR}/generated/buildflags.h)
+ ${CMAKE_CURRENT_BINARY_DIR}/generated/buildflags.h)
include_directories(${CMAKE_CURRENT_BINARY_DIR}/generated/)
# Configure RPATH
@@ -557,19 +571,18 @@ set(CMAKE_BUILD_WITH_INSTALL_RPATH FALSE)
set(CMAKE_INSTALL_RPATH_USE_LINK_PATH TRUE)
set(CMAKE_BUILD_RPATH_USE_ORIGIN TRUE)
if(NOT FREEBSD)
- set(CMAKE_INSTALL_RPATH "\$ORIGIN/../${CMAKE_INSTALL_LIBDIR}:\$ORIGIN/..")
+ set(CMAKE_INSTALL_RPATH "\$ORIGIN/../${CMAKE_INSTALL_LIBDIR}:\$ORIGIN/..")
endif()
if(GTK3_FOUND)
- #pkg_check_modules(gio REQUIRED gio-2.0)
- #pkg_check_modules(gio-unix REQUIRED gio-unix-2.0)
- add_subdirectory(src)
- add_subdirectory(data)
- add_subdirectory(plugins)
- add_subdirectory(plugins/secret)
+ # pkg_check_modules(gio REQUIRED gio-2.0) pkg_check_modules(gio-unix REQUIRED
+ # gio-unix-2.0)
+ add_subdirectory(src)
+ add_subdirectory(data)
+ add_subdirectory(plugins)
+ add_subdirectory(plugins/secret)
endif()
if(WITH_TRANSLATIONS)
- add_subdirectory(po)
+ add_subdirectory(po)
endif()
-