summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--smtk-import/CMakeLists.txt144
1 files changed, 142 insertions, 2 deletions
diff --git a/smtk-import/CMakeLists.txt b/smtk-import/CMakeLists.txt
index c49eeac3f..3b631be8d 100644
--- a/smtk-import/CMakeLists.txt
+++ b/smtk-import/CMakeLists.txt
@@ -1,12 +1,152 @@
+# Modified from Subsurface's CMakeLists.txt
+
+project(smtk2ssrf)
+cmake_minimum_required(VERSION 2.8.11)
+
+set(CMAKE_AUTOMOC ON)
set(CMAKE_AUTOUIC ON)
set(CMAKE_INCLUDE_CURRENT_DIR ON)
+set(CMAKE_BUILD_TYPE "Release")
+
+set(SSRF_PATH ../)
+set(CMAKE_MODULE_PATH ${SSRF_PATH}cmake/Modules)
+include(${CMAKE_MODULE_PATH}/MacroOutOfSourceBuild.cmake)
+include(${CMAKE_MODULE_PATH}/cmake_variables_helper.cmake)
+if(CMAKE_SYSTEM_NAME STREQUAL "Windows")
+ include(${CMAKE_MODULE_PATH}/HandleVersionGeneration.cmake)
+endif()
+
+MACRO_ENSURE_OUT_OF_SOURCE_BUILD(
+ "We don't support building in source, please create a build folder elsewhere and remember to run git clean -xdf to remove temporary files created by CMake."
+)
+
+# Find needed packages and Qt5 components. Most of them needed by Subsurface
+find_package(PkgConfig)
+include(${SSRF_PATH}cmake/Modules/pkgconfig_helper.cmake)
+pkg_config_library(LIBXML libxml-2.0 REQUIRED)
+pkg_config_library(LIBSQLITE3 sqlite3 REQUIRED)
+pkg_config_library(LIBXSLT libxslt REQUIRED)
+pkg_config_library(LIBZIP libzip REQUIRED)
+pkg_config_library(LIBUSB libusb-1.0 QUIET)
+pkg_config_library(GLIB2 glib-2.0 REQUIRED)
+pkg_config_library(LIBGIT2 libgit2 REQUIRED)
+pkg_config_library(LIBMDB libmdb REQUIRED)
+pkg_config_library(LIBDC libdivecomputer REQUIRED)
+
+find_package(Qt5 REQUIRED COMPONENTS Core
+ Concurrent
+ Widgets
+ Network
+ Svg
+ Test
+ LinguistTools
+ Positioning
+ Bluetooth)
+
+set(QT_LIBRARIES Qt5::Core
+ Qt5::Concurrent
+ Qt5::Widgets
+ Qt5::Network
+ Qt5::Svg
+ Qt5::Positioning
+ Qt5::Bluetooth)
+
+set(QT5_INCLUDE_PATH ${Qt5_INCLUDE_DIRS} ${Qt5Widgets_INCLUDE_DIRS} ${Qt5Core_INCLUDE_DIRS})
+qt5_add_resources(SUBSURFACE_RESOURCES ${SSRF_PATH}subsurface.qrc)
+
+include_directories(${SSRF_PATH} ${QT5_INCLUDE_PATH} ${LIBMDB_INCLUDEDIR} ${LIBDIVECOMPUTER_INCLUDEDIR})
+
+# Check for libsubsurface_corelib.a
+# A previous build of subsurface is needed (windows and linux)
+message(STATUS "Checking for Subsurface core library")
+if(CMAKE_SYSTEM_NAME STREQUAL "Windows")
+ find_library(SSRF_CORELIB
+ NAMES subsurface_corelib
+ PATHS ${CMAKE_BINARY_DIR}/../subsurface/core
+ )
+elseif(CMAKE_SYSTEM_NAME STREQUAL "Linux")
+ find_library(SSRF_CORELIB
+ NAMES subsurface_corelib
+ PATHS ${SSRF_PATH}build/core
+ )
+endif()
+
+if(NOT DEFINED SSRF_CORELIB OR SSRF_CORELIB STREQUAL "SSRF_CORELIB-NOTFOUND")
+ message(FATAL_ERROR " libsubsurface_corelib.a not found. Did you build Subsurface previously?")
+else()
+ message(STATUS " Found ${SSRF_CORELIB}")
+endif()
+
+# Set compiler flags and definitions
+set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=gnu99")
+set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11 -fPIC")
+
+if(CMAKE_SYSTEM_NAME STREQUAL "Linux")
+ set(SMTK_LINK_LIBRARIES ${SMTK_LINK_LIBRARIES} -lssh2 -lz -lpthread)
+elseif(CMAKE_SYSTEM_NAME STREQUAL "Windows")
+ set(SMTK_LINK_LIBRARIES ${SMTK_LINK_LIBRARIES} -lwsock32 -lws2_32 -lole32 -limm32 -lwinmm)
+ remove_definitions(-DUNICODE)
+ add_definitions(-mwindows -D_WIN32)
+endif()
+
+set(SMTK_LINK_LIBRARIES ${SMTK_LINK_LIBRARIES} ${LIBMDB_LIBRARIES} ${LIBDIVECOMPUTER_LIBRARIES})
+
set(SMTK_IMPORT_SRCS
smartrak.c
smrtk2ssrfc_window.ui
smrtk2ssrfc_window.h
smrtk2ssrfc_window.cpp
)
-
+set(SMTK_LINK_LIBRARIES ${SMTK_LINK_LIBRARIES} ${SUBSURFACE_LINK_LIBRARIES} ${SSRF_CORELIB} ${QT_LIBRARIES})
source_group("SmartTrak Import libs" FILES ${SMTK_IMPORT_SRCS})
+set(SMTK_IMPORT_TARGET smtk2ssrf)
add_library(smtk_import STATIC ${SMTK_IMPORT_SRCS})
-target_link_libraries(smtk_import subsurface_corelib ${SUBSURFACE_LINK_LIBRARIES})
+add_executable(${SMTK_IMPORT_TARGET} smtk_standalone.cpp ${SUBSURFACE_RESOURCES})
+
+if(CMAKE_SYSTEM_NAME STREQUAL "Windows")
+ add_custom_command(
+ OUTPUT ${CMAKE_BINARY_DIR}/qt.conf
+ COMMAND echo \"[Paths]\" > ${CMAKE_BINARY_DIR}/qt.conf \; echo \"Prefix=.\" >> ${CMAKE_BINARY_DIR}/qt.conf
+ )
+ add_custom_target(
+ generate_qtconf
+ DEPENDS ${CMAKE_BINARY_DIR}/qt.conf
+ )
+ add_dependencies(${SMTK_IMPORT_TARGET} generate_qtconf)
+endif()
+
+target_link_libraries(${SMTK_IMPORT_TARGET} smtk_import ${SMTK_LINK_LIBRARIES})
+
+# Install instructions
+if (CMAKE_SYSTEM_NAME STREQUAL "Linux")
+ install(TARGETS ${SMTK_IMPORT_TARGET} DESTINATION bin)
+elseif(CMAKE_SYSTEM_NAME STREQUAL "Windows")
+ set(WINDOWSSTAGING ${CMAKE_BINARY_DIR}/staging)
+ install(FILES ${SSRF_PATH}gpl-2.0.txt ${SSRF_PATH}packaging/windows/subsurface.ico DESTINATION ${WINDOWSSTAGING})
+ install(TARGETS ${SMTK_IMPORT_TARGET} DESTINATION ${WINDOWSSTAGING})
+ install(FILES ${CMAKE_BINARY_DIR}/qt.conf DESTINATION ${WINDOWSSTAGING})
+ if(NOT DEFINED MAKENSIS)
+ set(MAKENSIS makensis)
+ endif()
+
+ # this ensures that smtk2ssrf.exe has been built before this is run
+ install(CODE "execute_process(COMMAND ${CMAKE_COMMAND} -DCMAKE_C_COMPILER=${CMAKE_C_COMPILER} -DSMTK_IMPORT_TARGET=${SMTK_IMPORT_TARGET} -DSMTK_IMPORT_SRCS=${SMTK_IMPORT_SRCS} -DSTAGING=${WINDOWSSTAGING} -P ${CMAKE_SOURCE_DIR}/cmake/Modules/dlllist.cmake)")
+
+ # create the smtk2ssrf-x.y.z.exe installer - this needs to depend
+ # on the install target but cmake doesn't allow that, so we depend
+ # on the fake target instead
+ add_custom_target(
+ fake_install
+ COMMAND "${CMAKE_COMMAND}" --build . --target install
+ DEPENDS ${SMTK_IMPORT_TARGET}
+ )
+
+ add_custom_target(
+ installer
+ COMMAND ${MAKENSIS} ${WINDOWSSTAGING}/smtk-import.nsi
+ DEPENDS fake_install
+ )
+endif()
+
+# useful for debugging CMake issues
+# printll_variables()