blob: 52a3cdf9cc648264cfb9f33b8a2ac33dc3ac148c [file] [log] [blame]
Jan Kundrátd9d26a92018-02-22 12:49:21 +01001project(netconf-cli LANGUAGES CXX)
2cmake_minimum_required(VERSION 3.0)
3set(CMAKE_CXX_STANDARD 14)
4set(CMAKE_CXX_STANDARD_REQUIRED ON)
Jan Kundrátd47f6552018-03-02 13:40:11 +01005
6include(GNUInstallDirs)
7
8# Set a default build type if none was specified. This was shamelessly stolen
9# from VTK's cmake setup because these guys produce both CMake and a project that
10# manipulates this variable, and the web is full of posts where people say that
11# it is apparently evil to just set the build type in a way an earlier version of
12# this patch did. Oh, and the location of this check/update matters, apparently.
13#
14# Yes, this is just plain crazy.
15if(NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CONFIGURATION_TYPES)
16 message(STATUS "Setting build type to 'RelWithDebInfo' as none was specified.")
17 set(CMAKE_BUILD_TYPE RelWithDebInfo CACHE STRING "Choose the type of build." FORCE)
18 # Set the possible values of build type for cmake-gui
19 set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS "Debug" "Release" "MinSizeRel" "RelWithDebInfo")
20endif()
21
22# -Werror is not a default for sanity reasons (one cannot know what warnings a future compiler
23# might bring along), but it's a default in debug mode. The idea is that developers should care
24# about a warning-free build, and that this is easier than messing with yet another configure option.
25set(CMAKE_CXX_FLAGS_DEBUG "-Werror ${CMAKE_CXX_FLAGS_DEBUG}")
26
27# I don't want to duplicate the compiler's optimizations
28set(CMAKE_CXX_FLAGS "-O2 ${CMAKE_CXX_FLAGS}")
29
30# Build warnings are useful tools (and this project should be warning-free anyway), enable them on all
31# configurations. They are warnings, not errors.
32set(CMAKE_CXX_FLAGS "-Wall -Wextra -pedantic ${CMAKE_CXX_FLAGS}")
33
Jan Kundrát608818b2018-03-02 13:43:53 +010034find_package(Doxygen)
35option(WITH_DOCS "Create and install internal documentation (needs Doxygen)" ${DOXYGEN_FOUND})
36
Jan Kundrátd47f6552018-03-02 13:40:11 +010037find_package(docopt REQUIRED)
38find_package(spdlog REQUIRED)
Jan Kundrát608818b2018-03-02 13:43:53 +010039
Jan Kundrát5c805212018-03-02 13:57:12 +010040include(CTest)
41if(BUILD_TESTING)
42 enable_testing()
43 find_path(TROMPELOEIL_PATH trompeloeil.hpp PATH_SUFFIXES trompeloeil/)
44 if("${TROMPELOEIL_PATH}" STREQUAL "TROMPELOEIL_PATH-NOTFOUND")
45 message(FATAL_ERROR "Cannot find the \"trompeloeil.hpp\" file provided by <https://github.com/rollbear/trompeloeil>. "
46 "Please set TROMPELOEIL_PATH to where it is available.")
47 endif()
48
49 find_path(CATCH_PATH catch.hpp PATH_SUFFIXES catch/)
50 if("${CATCH_PATH}" STREQUAL "CATCH_PATH-NOTFOUND")
51 message(FATAL_ERROR "Cannot find the \"catch.hpp\" file provided by <http://catch-lib.net/>. "
52 "Please set CATCH_PATH to where it is available.")
53 endif()
54
55 add_library(TestCatchIntegration STATIC
56 tests/catch_integration.cpp
57 tests/trompeloeil_catch.h
58 )
59 target_include_directories(TestCatchIntegration SYSTEM PUBLIC ${TROMPELOEIL_PATH} ${CATCH_PATH})
60 target_include_directories(TestCatchIntegration PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/tests/ ${CMAKE_CURRENT_SOURCE_DIR}/src/)
61 target_link_libraries(TestCatchIntegration spdlog::spdlog)
62
63 macro(cli_test fname)
64 set(test_${fname}_SOURCES tests/${fname}.cpp)
65 add_executable(test_${fname} ${test_${fname}_SOURCES})
66 target_link_libraries(test_${fname} TestCatchIntegration)
67 if(NOT CMAKE_CROSSCOMPILING)
68 add_test(test_${fname} test_${fname})
69 endif()
70 target_include_directories(test_${fname} PRIVATE ${CMAKE_CURRENT_BINARY_DIR})
71 target_link_libraries(test_${fname} TestCatchIntegration)
72 endmacro()
73endif()
74
Jan Kundrát608818b2018-03-02 13:43:53 +010075if(WITH_DOCS)
76 set(doxyfile_in ${CMAKE_CURRENT_SOURCE_DIR}/Doxyfile.in)
77 set(doxyfile ${CMAKE_CURRENT_BINARY_DIR}/Doxyfile)
78 configure_file(${doxyfile_in} ${doxyfile} @ONLY)
79 add_custom_target(doc
80 COMMAND ${DOXYGEN_EXECUTABLE} ${doxyfile}
81 WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
82 COMMENT "Generating API documentation with Doxygen"
83 VERBATIM
84 SOURCES ${doxyfile_in}
85 )
86endif()