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:
-rw-r--r--CMakeLists.txt639
-rw-r--r--config.h.in2
-rw-r--r--plugins/vnc/vnc_plugin.c6
-rw-r--r--src/CMakeLists.txt442
4 files changed, 551 insertions, 538 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()
-
diff --git a/config.h.in b/config.h.in
index e59bf78aa..077f1339c 100644
--- a/config.h.in
+++ b/config.h.in
@@ -14,7 +14,7 @@
#define remmina "remmina"
#define REMMINA_APP_ID "${REMMINA_APP_ID}"
-#define VERSION "${REMMINA_VERSION}"
+#define VERSION "${Remmina_VERSION}"
#define REMMINA_GIT_REVISION "${REMMINA_GIT_REVISION}"
#define RMNEWS_ENABLE_NEWS ${RMNEWS_ENABLE_NEWS}
diff --git a/plugins/vnc/vnc_plugin.c b/plugins/vnc/vnc_plugin.c
index 408cfc0e7..88d85afa0 100644
--- a/plugins/vnc/vnc_plugin.c
+++ b/plugins/vnc/vnc_plugin.c
@@ -946,13 +946,13 @@ static gboolean vnc_encryption_disable_requested;
static void remmina_plugin_vnc_rfb_output(const char *format, ...)
{
TRACE_CALL(__func__);
- va_list args;
-
- va_start(args, format);
gchar *f, *p, *ff;
if (!rfbEnableClientLogging)
return;
+
+ va_list args;
+ va_start(args, format);
/* eliminate the last \n */
f = g_strdup(format);
if (f[strlen(f) - 1] == '\n') f[strlen(f) - 1] = '\0';
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
index 03270e54b..9d2051629 100644
--- a/src/CMakeLists.txt
+++ b/src/CMakeLists.txt
@@ -4,131 +4,126 @@
# Copyright (C) 2014-2015 Antenore Gatta, Fabio Castelli, Giovanni Panozzo
# Copyright (C) 2016-2021 Antenore Gatta, Giovanni Panozzo
#
-# This program is free software; you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2 of the License, or
-# (at your option) any later version.
+# This program is free software; you can redistribute it and/or modify it under
+# the terms of the GNU General Public License as published by the Free Software
+# Foundation; either version 2 of the License, or (at your option) any later
+# version.
#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
+# This program is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
+# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
+# details.
#
-# You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 51 Franklin Street, Fifth Floor,
-# Boston, MA 02110-1301, USA.
+# You should have received a copy of the GNU General Public License along with
+# this program; if not, write to the Free Software Foundation, Inc., 51 Franklin
+# Street, Fifth Floor, Boston, MA 02110-1301, USA.
#
-# In addition, as a special exception, the copyright holders give
-# permission to link the code of portions of this program with the
-# OpenSSL library under certain conditions as described in each
-# individual source file, and distribute linked combinations
-# including the two.
-# You must obey the GNU General Public License in all respects
-# for all of the code used other than OpenSSL. If you modify
-# file(s) with this exception, you may extend this exception to your
-# version of the file(s), but you are not obligated to do so. If you
-# do not wish to do so, delete this exception statement from your
-# version. If you delete this exception statement from all source
-# files in the program, then also delete it here.
+# In addition, as a special exception, the copyright holders give permission to
+# link the code of portions of this program with the OpenSSL library under
+# certain conditions as described in each individual source file, and distribute
+# linked combinations including the two. You must obey the GNU General Public
+# License in all respects for all of the code used other than OpenSSL. If you
+# modify file(s) with this exception, you may extend this exception to your
+# version of the file(s), but you are not obligated to do so. If you do not wish
+# to do so, delete this exception statement from your version. If you delete
+# this exception statement from all source files in the program, then also
+# delete it here.
-
-cmake_minimum_required(VERSION 3.0.0)
-
-list(APPEND REMMINA_SRCS
- "remmina_about.c"
- "remmina_about.h"
- "remmina_applet_menu.c"
- "remmina_applet_menu.h"
- "remmina_applet_menu_item.c"
- "remmina_applet_menu_item.h"
- "remmina_avahi.c"
- "remmina_avahi.h"
- "remmina.c"
- "remmina.h"
- "remmina_chat_window.c"
- "remmina_chat_window.h"
- "remmina_crypt.c"
- "remmina_crypt.h"
- "remmina_exec.c"
- "remmina_exec.h"
- "remmina_file.c"
- "remmina_file_editor.c"
- "remmina_file_editor.h"
- "remmina_file.h"
- "remmina_file_manager.c"
- "remmina_file_manager.h"
- "remmina_ftp_client.c"
- "remmina_ftp_client.h"
- "remmina_icon.c"
- "remmina_icon.h"
- "remmina_key_chooser.c"
- "remmina_key_chooser.h"
- "remmina_log.c"
- "remmina_log.h"
- "remmina_main.c"
- "remmina_main.h"
- "remmina_marshals.c"
- "remmina_marshals.h"
- "remmina_marshals.list"
- "remmina_masterthread_exec.c"
- "remmina_masterthread_exec.h"
- "remmina_message_panel.c"
- "remmina_message_panel.h"
- "remmina_plugin_manager.c"
- "remmina_plugin_manager.h"
- "remmina_plugin_native.c"
- "remmina_plugin_native.h"
- "remmina_ext_exec.c"
- "remmina_ext_exec.h"
- "remmina_pref.c"
- "remmina_pref_dialog.c"
- "remmina_pref_dialog.h"
- "remmina_pref.h"
- "remmina_protocol_widget.c"
- "remmina_protocol_widget.h"
- "remmina_public.c"
- "remmina_public.h"
- "remmina_scrolled_viewport.c"
- "remmina_scrolled_viewport.h"
- "remmina_sftp_client.c"
- "remmina_sftp_client.h"
- "remmina_sftp_plugin.c"
- "remmina_sftp_plugin.h"
- "remmina_sodium.c"
- "remmina_sodium.h"
- "remmina_ssh.c"
- "remmina_ssh.h"
- "remmina_ssh_plugin.c"
- "remmina_ssh_plugin.h"
- "remmina_string_array.c"
- "remmina_string_array.h"
- "remmina_string_list.c"
- "remmina_string_list.h"
- "remmina_unlock.c"
- "remmina_unlock.h"
- "remmina_utils.c"
- "remmina_utils.h"
- "remmina_widget_pool.c"
- "remmina_widget_pool.h"
- "remmina_external_tools.c"
- "remmina_external_tools.h"
- "remmina_sysinfo.h"
- "remmina_sysinfo.c"
- "rcw.c"
- "rcw.h"
- "rmnews.c"
- "rmnews.h"
- "remmina_mpchange.c"
- "remmina_mpchange.h"
- "remmina_scheduler.c"
- "remmina_scheduler.h"
- "remmina_stats.c"
- "remmina_stats.h"
- "remmina_stats_sender.c"
- "remmina_stats_sender.h"
- "resources.c"
- )
+list(
+ APPEND
+ REMMINA_SRCS
+ "remmina_about.c"
+ "remmina_about.h"
+ "remmina_applet_menu.c"
+ "remmina_applet_menu.h"
+ "remmina_applet_menu_item.c"
+ "remmina_applet_menu_item.h"
+ "remmina_avahi.c"
+ "remmina_avahi.h"
+ "remmina.c"
+ "remmina.h"
+ "remmina_chat_window.c"
+ "remmina_chat_window.h"
+ "remmina_crypt.c"
+ "remmina_crypt.h"
+ "remmina_exec.c"
+ "remmina_exec.h"
+ "remmina_file.c"
+ "remmina_file_editor.c"
+ "remmina_file_editor.h"
+ "remmina_file.h"
+ "remmina_file_manager.c"
+ "remmina_file_manager.h"
+ "remmina_ftp_client.c"
+ "remmina_ftp_client.h"
+ "remmina_icon.c"
+ "remmina_icon.h"
+ "remmina_key_chooser.c"
+ "remmina_key_chooser.h"
+ "remmina_log.c"
+ "remmina_log.h"
+ "remmina_main.c"
+ "remmina_main.h"
+ "remmina_marshals.c"
+ "remmina_marshals.h"
+ "remmina_marshals.list"
+ "remmina_masterthread_exec.c"
+ "remmina_masterthread_exec.h"
+ "remmina_message_panel.c"
+ "remmina_message_panel.h"
+ "remmina_plugin_manager.c"
+ "remmina_plugin_manager.h"
+ "remmina_plugin_native.c"
+ "remmina_plugin_native.h"
+ "remmina_ext_exec.c"
+ "remmina_ext_exec.h"
+ "remmina_pref.c"
+ "remmina_pref_dialog.c"
+ "remmina_pref_dialog.h"
+ "remmina_pref.h"
+ "remmina_protocol_widget.c"
+ "remmina_protocol_widget.h"
+ "remmina_public.c"
+ "remmina_public.h"
+ "remmina_scrolled_viewport.c"
+ "remmina_scrolled_viewport.h"
+ "remmina_sftp_client.c"
+ "remmina_sftp_client.h"
+ "remmina_sftp_plugin.c"
+ "remmina_sftp_plugin.h"
+ "remmina_sodium.c"
+ "remmina_sodium.h"
+ "remmina_ssh.c"
+ "remmina_ssh.h"
+ "remmina_ssh_plugin.c"
+ "remmina_ssh_plugin.h"
+ "remmina_string_array.c"
+ "remmina_string_array.h"
+ "remmina_string_list.c"
+ "remmina_string_list.h"
+ "remmina_unlock.c"
+ "remmina_unlock.h"
+ "remmina_utils.c"
+ "remmina_utils.h"
+ "remmina_widget_pool.c"
+ "remmina_widget_pool.h"
+ "remmina_external_tools.c"
+ "remmina_external_tools.h"
+ "remmina_sysinfo.h"
+ "remmina_sysinfo.c"
+ "rcw.c"
+ "rcw.h"
+ "rmnews.c"
+ "rmnews.h"
+ "remmina_mpchange.c"
+ "remmina_mpchange.h"
+ "remmina_scheduler.c"
+ "remmina_scheduler.h"
+ "remmina_stats.c"
+ "remmina_stats.h"
+ "remmina_stats_sender.c"
+ "remmina_stats_sender.h"
+ "resources.c")
set(RESOURCE_LIST
${CMAKE_CURRENT_SOURCE_DIR}/../data/ui/remmina_about.glade
@@ -142,63 +137,67 @@ set(RESOURCE_LIST
${CMAKE_CURRENT_SOURCE_DIR}/../data/ui/remmina_snap_info_dialog.glade
${CMAKE_CURRENT_SOURCE_DIR}/../data/ui/remmina_spinner.glade
${CMAKE_CURRENT_SOURCE_DIR}/../data/ui/remmina_string_list.glade
- ${CMAKE_CURRENT_SOURCE_DIR}/../data/ui/remmina_unlock.glade
- )
+ ${CMAKE_CURRENT_SOURCE_DIR}/../data/ui/remmina_unlock.glade)
option(WITH_PYTHONLIBS "Enable Python plugins support" OFF)
if(WITH_PYTHONLIBS)
- message(STATUS "Python plugins support enabled")
- find_suggested_package(PythonLibs)
- if(PythonLibs_FOUND)
- message(STATUS "Python libs found, Python support enabled")
- add_definitions(-DWITH_PYTHONLIBS)
- list(FIND REMMINA_SRCS "remmina_exec.c" SRCINDEX)
- message(DEBUG "remmina_exec.c found at index: " ${SRCINDEX})
- # Index calculated at "remmina_exec.c" position (43 as of today)
- list(INSERT REMMINA_SRCS ${SRCINDEX}
- "remmina_plugin_python.c"
- "remmina_plugin_python.h"
- "remmina_plugin_python_module.c"
- "remmina_plugin_python_module.h"
- "remmina_plugin_python_remmina.c"
- "remmina_plugin_python_remmina.h"
- "remmina_plugin_python_protocol_widget.c"
- "remmina_plugin_python_protocol_widget.h"
- "remmina_plugin_python_remmina_file.c"
- "remmina_plugin_python_remmina_file.h"
- )
- else()
- message(STATUS "Python plugins support enabled, but Python libs not found")
- endif()
+ message(STATUS "Python plugins support enabled")
+ find_suggested_package(PythonLibs)
+ if(PythonLibs_FOUND)
+ message(STATUS "Python libs found, Python support enabled")
+ add_definitions(-DWITH_PYTHONLIBS)
+ list(FIND REMMINA_SRCS "remmina_exec.c" SRCINDEX)
+ message(DEBUG "remmina_exec.c found at index: " ${SRCINDEX})
+ # Index calculated at "remmina_exec.c" position (43 as of today)
+ list(
+ INSERT
+ REMMINA_SRCS
+ ${SRCINDEX}
+ "remmina_plugin_python.c"
+ "remmina_plugin_python.h"
+ "remmina_plugin_python_module.c"
+ "remmina_plugin_python_module.h"
+ "remmina_plugin_python_remmina.c"
+ "remmina_plugin_python_remmina.h"
+ "remmina_plugin_python_protocol_widget.c"
+ "remmina_plugin_python_protocol_widget.h"
+ "remmina_plugin_python_remmina_file.c"
+ "remmina_plugin_python_remmina_file.h")
+ else()
+ message(STATUS "Python plugins support enabled, but Python libs not found")
+ endif()
else()
message(STATUS "Python plugins support disabled")
endif()
message(DEBUG "Source list set to: " ${REMMINA_SRCS})
-
-compile_gresources(RESOURCE_FILE
- XML_OUT
- TYPE EMBED_C
- PREFIX /org/remmina/Remmina/src
- SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}
- RESOURCES ${RESOURCE_LIST})
-
+compile_gresources(
+ RESOURCE_FILE
+ XML_OUT
+ TYPE
+ EMBED_C
+ PREFIX
+ /org/remmina/Remmina/src
+ SOURCE_DIR
+ ${CMAKE_CURRENT_SOURCE_DIR}
+ RESOURCES
+ ${RESOURCE_LIST})
add_custom_target(resource DEPENDS ${RESOURCE_FILE})
add_executable(remmina ${REMMINA_SRCS} ${RESOURCE_FILE})
add_dependencies(remmina resource)
-target_link_libraries(remmina ${GTK_LIBRARIES})
+target_link_libraries(remmina ${GTK_LIBRARIES} -rdynamic)
if(WITH_PYTHONLIBS)
- if(PythonLibs_FOUND)
- include_directories(${PYTHON_INCLUDE_DIRS})
- target_link_libraries(remmina ${PYTHON_LIBRARIES})
- endif()
+ if(PythonLibs_FOUND)
+ include_directories(${PYTHON_INCLUDE_DIRS})
+ target_link_libraries(remmina ${PYTHON_LIBRARIES})
+ endif()
endif()
if(WITH_MANPAGES)
- install(FILES remmina.1 DESTINATION ${CMAKE_INSTALL_FULL_MANDIR}/man1)
+ install(FILES remmina.1 DESTINATION ${CMAKE_INSTALL_FULL_MANDIR}/man1)
endif()
find_package(X11)
@@ -208,99 +207,100 @@ target_link_libraries(remmina ${X11_LIBRARIES})
target_link_libraries(remmina ${CMAKE_THREAD_LIBS_INIT})
if(Intl_FOUND)
- message(STATUS "${CMAKE_SYSTEM_NAME} detected, building with Intl")
- include_directories(${Intl_INCLUDE_DIRS})
- target_link_libraries(remmina ${Intl_LIBRARIES})
+ message(STATUS "${CMAKE_SYSTEM_NAME} detected, building with Intl")
+ include_directories(${Intl_INCLUDE_DIRS})
+ target_link_libraries(remmina ${Intl_LIBRARIES})
endif()
find_suggested_package(LIBSSH)
if(LIBSSH_FOUND)
- add_definitions(-DHAVE_LIBSSH)
- include_directories(${LIBSSH_INCLUDE_DIRS})
- target_link_libraries(remmina ${LIBSSH_LIBRARIES})
+ add_definitions(-DHAVE_LIBSSH)
+ include_directories(${LIBSSH_INCLUDE_DIRS})
+ target_link_libraries(remmina ${LIBSSH_LIBRARIES})
endif()
if(GCRYPT_FOUND)
- include_directories(${GCRYPT_INCLUDE_DIRS})
- target_link_libraries(remmina ${GCRYPT_LIBRARIES})
+ include_directories(${GCRYPT_INCLUDE_DIRS})
+ target_link_libraries(remmina ${GCRYPT_LIBRARIES})
endif()
if(AVAHI_FOUND)
- include_directories(${AVAHI_INCLUDE_DIRS})
- target_link_libraries(remmina ${AVAHI_LIBRARIES})
+ include_directories(${AVAHI_INCLUDE_DIRS})
+ target_link_libraries(remmina ${AVAHI_LIBRARIES})
endif()
if(OPENSSL_FOUND)
- include_directories(${OPENSSL_INCLUDE_DIRS})
- target_link_libraries(remmina ${OPENSSL_LIBRARIES})
+ include_directories(${OPENSSL_INCLUDE_DIRS})
+ target_link_libraries(remmina ${OPENSSL_LIBRARIES})
endif()
option(WITH_VTE "Build with support for VTE" ON)
if(GTK3_FOUND AND WITH_VTE)
- set(_VTE_VERSION_NUMS 2.91 2.90)
- foreach(__VTE_VERSION ${_VTE_VERSION_NUMS})
- set(_VTE_VERSION_NUM ${__VTE_VERSION})
- find_suggested_package(VTE)
- if(VTE_FOUND)
- break()
- endif()
- message(STATUS "VTE ${__VTE_VERSION} not found")
- endforeach()
+ set(_VTE_VERSION_NUMS 2.91 2.90)
+ foreach(__VTE_VERSION ${_VTE_VERSION_NUMS})
+ set(_VTE_VERSION_NUM ${__VTE_VERSION})
+ find_suggested_package(VTE)
+ if(VTE_FOUND)
+ break()
+ endif()
+ message(STATUS "VTE ${__VTE_VERSION} not found")
+ endforeach()
elseif(WITH_VTE)
- set(_VTE_VERSION_NUM)
- find_package(VTE)
+ set(_VTE_VERSION_NUM)
+ find_package(VTE)
endif()
if(VTE_FOUND)
- add_definitions(-DHAVE_LIBVTE)
- include_directories(${VTE_INCLUDE_DIRS})
- target_link_libraries(remmina ${VTE_LIBRARIES})
+ add_definitions(-DHAVE_LIBVTE)
+ include_directories(${VTE_INCLUDE_DIRS})
+ target_link_libraries(remmina ${VTE_LIBRARIES})
endif()
if(sodium_FOUND)
- message(STATUS "Sodium found")
- message(STATUS "Sodium include dirs ${sodium_INCLUDE_DIR}")
- include_directories(${sodium_INCLUDE_DIR})
- target_link_libraries(remmina sodium)
+ message(STATUS "Sodium found")
+ message(STATUS "Sodium include dirs ${sodium_INCLUDE_DIR}")
+ include_directories(${sodium_INCLUDE_DIR})
+ target_link_libraries(remmina sodium)
endif()
if(GTK3_FOUND)
- find_required_package(APPINDICATOR)
- if(APPINDICATOR_FOUND)
- add_definitions(-DHAVE_LIBAPPINDICATOR)
- include_directories(${APPINDICATOR_INCLUDE_DIRS})
- target_link_libraries(remmina ${APPINDICATOR_LIBRARIES})
- message(STATUS "AppIndicator library dirs ${APPINDICATOR_LIBRARIES}")
- message(STATUS "AppIndicator include dirs ${APPINDICATOR_INCLUDE_DIRS}")
- else()
- message(FATAL_ERROR "AppIndicator not found")
- endif()
- find_required_package(JSONGLIB)
- if(JSONGLIB_FOUND)
- include_directories(${JSONGLIB_INCLUDE_DIRS})
- target_link_libraries(remmina ${JSONGLIB_LIBRARIES})
- else()
- message(FATAL_ERROR "json-glib library not found")
- endif()
- find_required_package(LIBSOUP24)
- if(LIBSOUP24_FOUND)
- include_directories(${LIBSOUP24_INCLUDE_DIRS})
- target_link_libraries(remmina ${LIBSOUP24_LIBRARIES})
- else()
- message(FATAL_ERROR "libsoup 2.4 library not found")
- endif()
+ find_required_package(APPINDICATOR)
+ if(APPINDICATOR_FOUND)
+ add_definitions(-DHAVE_LIBAPPINDICATOR)
+ include_directories(${APPINDICATOR_INCLUDE_DIRS})
+ target_link_libraries(remmina ${APPINDICATOR_LIBRARIES})
+ message(STATUS "AppIndicator library dirs ${APPINDICATOR_LIBRARIES}")
+ message(STATUS "AppIndicator include dirs ${APPINDICATOR_INCLUDE_DIRS}")
+ else()
+ message(FATAL_ERROR "AppIndicator not found")
+ endif()
+ find_required_package(JSONGLIB)
+ if(JSONGLIB_FOUND)
+ include_directories(${JSONGLIB_INCLUDE_DIRS})
+ target_link_libraries(remmina ${JSONGLIB_LIBRARIES})
+ else()
+ message(FATAL_ERROR "json-glib library not found")
+ endif()
+ find_required_package(LIBSOUP24)
+ if(LIBSOUP24_FOUND)
+ include_directories(${LIBSOUP24_INCLUDE_DIRS})
+ target_link_libraries(remmina ${LIBSOUP24_LIBRARIES})
+ else()
+ message(FATAL_ERROR "libsoup 2.4 library not found")
+ endif()
endif()
include(FindPCRE2)
-if (NOT PCRE2_FOUND)
- message(FATAL_ERROR "libpcre2 library not found")
-endif ()
+if(NOT PCRE2_FOUND)
+ message(FATAL_ERROR "libpcre2 library not found")
+endif()
include_directories(${PCRE2_INCLUDE_DIRS})
add_subdirectory(external_tools)
install(TARGETS remmina DESTINATION ${CMAKE_INSTALL_BINDIR})
-install(DIRECTORY include/remmina/
- DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/remmina
- FILES_MATCHING PATTERN "*.h")
-
+install(
+ DIRECTORY include/remmina/
+ DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/remmina
+ FILES_MATCHING
+ PATTERN "*.h")