diff --git a/CMakeLists.txt b/CMakeLists.txt new file mode 100644 index 0000000..e7691d8 --- /dev/null +++ b/CMakeLists.txt @@ -0,0 +1,66 @@ +############################################ +# # +# Improvements and feedbacks are welcome # +# # +# This file is released under GPL >= 3 # +# # +############################################ + + +cmake_minimum_required( VERSION 2.8 ) + + +#### general package setup + +project( tdeio-ftps ) +set( VERSION R14.1.0 ) + + +#### include essential cmake modules + +include( FindPkgConfig ) +include( CheckIncludeFile ) +include( CheckLibraryExists ) +include( CheckCSourceCompiles ) +include( CheckCXXSourceCompiles ) + + +#### include our cmake modules + +set( CMAKE_MODULE_PATH "${CMAKE_SOURCE_DIR}/cmake/modules" ) +include( TDEMacros ) + + +##### setup install paths + +include( TDESetupPaths ) +tde_setup_paths( ) + + +##### optional stuff + +option( WITH_GCC_VISIBILITY "Enable fvisibility and fvisibility-inlines-hidden" OFF ) + + +##### configure checks + +include( ConfigureChecks.cmake ) + + +###### global compiler settings + +add_definitions( -DHAVE_CONFIG_H ) + +set( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${TQT_CXX_FLAGS}" ) +set( CMAKE_SHARED_LINKER_FLAGS "-Wl,--no-undefined" ) +set( CMAKE_MODULE_LINKER_FLAGS "-Wl,--no-undefined" ) + + +##### directories + +add_subdirectory( tdeio_ftps ) + + +##### write configure files + +configure_file( config.h.cmake config.h @ONLY ) diff --git a/ConfigureChecks.cmake b/ConfigureChecks.cmake new file mode 100644 index 0000000..0c8966b --- /dev/null +++ b/ConfigureChecks.cmake @@ -0,0 +1,36 @@ +########################################### +# # +# Improvements and feedback are welcome # +# # +# This file is released under GPL >= 3 # +# # +########################################### + + +# required stuff +find_package( TQt ) +find_package( TDE ) + +tde_setup_architecture_flags( ) + +include(TestBigEndian) +test_big_endian(WORDS_BIGENDIAN) + + +##### check for gcc visibility support + +if( WITH_GCC_VISIBILITY ) + if( NOT UNIX ) + tde_message_fatal( "gcc visibility support was requested, but your system is not *NIX" ) + endif( NOT UNIX ) + set( __KDE_HAVE_GCC_VISIBILITY 1 ) + set( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fvisibility=hidden -fvisibility-inlines-hidden") + set( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fvisibility=hidden -fvisibility-inlines-hidden") +endif( WITH_GCC_VISIBILITY ) + + +#### check for headers + +check_include_file( "sys/select.h" HAVE_SYS_SELECT_H ) +check_include_file( "sys/time.h" HAVE_SYS_TIME_H ) +check_include_file( "time.h" TIME_WITH_SYS_TIME ) diff --git a/config.h.cmake b/config.h.cmake new file mode 100644 index 0000000..ff9b61c --- /dev/null +++ b/config.h.cmake @@ -0,0 +1,20 @@ +#define VERSION "@VERSION@" + +// Defined if you have fvisibility and fvisibility-inlines-hidden support. +#cmakedefine __KDE_HAVE_GCC_VISIBILITY 1 + +/* Define WORDS_BIGENDIAN to 1 if your processor stores words with the most + significant byte first (like Motorola and SPARC, unlike Intel). */ +#cmakedefine WORDS_BIGENDIAN @WORDS_BIGENDIAN@ + +// Defined to 1 if you have 'sys/time.h' header +#cmakedefine HAVE_SYS_TIME_H 1 + +// Defined to 1 if you have 'sys/select.h' header +#cmakedefine HAVE_SYS_SELECT_H 1 + +// Defined to 1 if you have 'time.h' header +#cmakedefine TIME_WITH_SYS_TIME 1 + +// We should have 'strtol, strtoll' in stdlib.h header or in cstdlib with c++ +#define HAVE_STRTOLL 1 diff --git a/tdeio_ftps/CMakeLists.txt b/tdeio_ftps/CMakeLists.txt new file mode 100644 index 0000000..e61038b --- /dev/null +++ b/tdeio_ftps/CMakeLists.txt @@ -0,0 +1,29 @@ +include_directories( + ${CMAKE_BINARY_DIR} + ${CMAKE_CURRENT_BINARY_DIR} + ${CMAKE_CURRENT_SOURCE_DIR} + ${TDE_INCLUDE_DIR} + ${TQT_INCLUDE_DIRS} +) + +link_directories( + ${TQT_LIBRARY_DIRS} + ${TDE_LIB_DIR} +) + + +##### tdeio_ftps (kpart) + +tde_add_kpart( tdeio_ftps AUTOMOC + SOURCES ftp.cc + LINK tdecore-shared tdeio-shared + DESTINATION ${PLUGIN_INSTALL_DIR} +) + + +##### other data + +install( + FILES ftps.protocol + DESTINATION ${SERVICES_INSTALL_DIR} +)