Move everything into a shared lib so unit test can access stuff.
This commit is contained in:
parent
e2d307da52
commit
47aa9f2948
55 changed files with 86 additions and 81 deletions
|
@ -1,5 +1,5 @@
|
|||
cmake_minimum_required(VERSION 3.2)
|
||||
project(mycurry CXX)
|
||||
project(mycurry_toplevel CXX)
|
||||
|
||||
list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake/include")
|
||||
|
||||
|
@ -7,12 +7,6 @@ include(TargetArch)
|
|||
include(FindPkgConfig)
|
||||
include(CTest)
|
||||
|
||||
set(common_gcc_flags "-Wall -Wextra -pedantic -Wconversion -ffast-math")
|
||||
set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} ${common_gcc_flags} -O0")
|
||||
set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} ${common_gcc_flags}")
|
||||
set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} ${common_gcc_flags} -O0")
|
||||
set(CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} ${common_gcc_flags}")
|
||||
|
||||
option(CURRY_FORCE_OPENGLES "Try to chose the openGL ES renderer if available. Enable this on Raspberry Pi" OFF)
|
||||
option(CURRY_RASPBERRY_PI "Compile for Raspberry Pi" OFF)
|
||||
|
||||
|
@ -35,9 +29,6 @@ if (CURRY_FORCE_OPENGLES OR CURRY_RASPBERRY_PI)
|
|||
endif(CURRY_RASPBERRY_PI)
|
||||
endif (CURRY_FORCE_OPENGLES OR CURRY_RASPBERRY_PI)
|
||||
|
||||
PKG_SEARCH_MODULE(SDL2 REQUIRED sdl2)
|
||||
PKG_SEARCH_MODULE(SDL2IMAGE REQUIRED SDL2_image>=2.0.0)
|
||||
find_package(PNG REQUIRED)
|
||||
find_package(Boost 1.55.0 REQUIRED)
|
||||
|
||||
if (CURRY_RASPBERRY_PI)
|
||||
|
@ -52,78 +43,23 @@ if (CURRY_RASPBERRY_PI)
|
|||
)
|
||||
endif (CURRY_RASPBERRY_PI)
|
||||
|
||||
add_executable(${PROJECT_NAME}
|
||||
src/csvloader.cpp
|
||||
src/main.cpp
|
||||
src/sdlmain.cpp
|
||||
src/ingamescene.cpp
|
||||
src/sizenotifiable.cpp
|
||||
src/sizeratio.cpp
|
||||
src/gamescenebase.cpp
|
||||
src/worldgrid.cpp
|
||||
src/worldviewport.cpp
|
||||
src/inputbag.cpp
|
||||
src/tileiterator.cpp
|
||||
src/texture.cpp
|
||||
src/movingobject.cpp
|
||||
src/character.cpp
|
||||
src/rect_to_sdl.cpp
|
||||
src/worldsizenotifiable.cpp
|
||||
src/worlditems.cpp
|
||||
src/moveable.cpp
|
||||
src/fsgn.cpp
|
||||
src/grid_raytrace.cpp
|
||||
)
|
||||
|
||||
target_include_directories(${PROJECT_NAME} SYSTEM
|
||||
PRIVATE ${SDL2_INCLUDE_DIR}
|
||||
PRIVATE ${SDL2IMAGE_INCLUDE_DIRS}
|
||||
PRIVATE ${PNG_INCLUDE_DIRS}
|
||||
PRIVATE ${Boost_INCLUDE_DIRS}
|
||||
PRIVATE lib/tree-2.81/src
|
||||
)
|
||||
target_include_directories(${PROJECT_NAME}
|
||||
PRIVATE src
|
||||
PRIVATE lib/vectorwrapper/include
|
||||
PRIVATE lib/DeathHandler
|
||||
PRIVATE ${CMAKE_CURRENT_BINARY_DIR}
|
||||
)
|
||||
|
||||
target_link_libraries(${PROJECT_NAME}
|
||||
PRIVATE ${SDL2_LIBRARIES}
|
||||
PRIVATE ${SDL2IMAGE_LIBRARIES}
|
||||
PRIVATE ${PNG_LIBRARIES}
|
||||
)
|
||||
|
||||
if (CURRY_RASPBERRY_PI)
|
||||
target_link_libraries(${PROJECT_NAME}
|
||||
PRIVATE bcm_host
|
||||
)
|
||||
endif(CURRY_RASPBERRY_PI)
|
||||
|
||||
target_compile_features(${PROJECT_NAME}
|
||||
PRIVATE cxx_nullptr
|
||||
PRIVATE cxx_range_for
|
||||
PRIVATE cxx_lambdas
|
||||
PRIVATE cxx_decltype_auto
|
||||
PRIVATE cxx_defaulted_functions
|
||||
PRIVATE cxx_deleted_functions
|
||||
PRIVATE cxx_auto_type
|
||||
PRIVATE cxx_defaulted_move_initializers
|
||||
PRIVATE cxx_noexcept
|
||||
PRIVATE cxx_rvalue_references
|
||||
)
|
||||
configure_file(src/${PROJECT_NAME}Config.h.in ${CMAKE_BINARY_DIR}/${PROJECT_NAME}Config.h)
|
||||
|
||||
target_compile_definitions(${PROJECT_NAME}
|
||||
PRIVATE ${PNG_DEFINITIONS}
|
||||
PRIVATE VWR_WITH_IMPLICIT_CONVERSIONS=1
|
||||
PRIVATE VWR_EXTRA_ACCESSORS
|
||||
)
|
||||
set(common_gcc_flags -Wall -Wextra -pedantic -Wconversion -ffast-math)
|
||||
|
||||
configure_file(src/${PROJECT_NAME}Config.h.in ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}Config.h)
|
||||
add_library(${PROJECT_NAME} INTERFACE)
|
||||
target_compile_options(${PROJECT_NAME} INTERFACE ${common_gcc_flags})
|
||||
|
||||
add_subdirectory(src/gamelib)
|
||||
add_subdirectory(src/standalone)
|
||||
|
||||
if (BUILD_TESTING)
|
||||
set(CATCH_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/lib/Catch")
|
||||
set(MYCURRY_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/src")
|
||||
add_subdirectory(test/unit)
|
||||
endif()
|
||||
|
|
54
src/gamelib/CMakeLists.txt
Normal file
54
src/gamelib/CMakeLists.txt
Normal file
|
@ -0,0 +1,54 @@
|
|||
project(mycurry_gamelib CXX)
|
||||
|
||||
PKG_SEARCH_MODULE(SDL2 REQUIRED sdl2)
|
||||
PKG_SEARCH_MODULE(SDL2IMAGE REQUIRED SDL2_image>=2.0.0)
|
||||
find_package(PNG REQUIRED)
|
||||
|
||||
add_library(${PROJECT_NAME}
|
||||
csvloader.cpp
|
||||
sdlmain.cpp
|
||||
ingamescene.cpp
|
||||
sizenotifiable.cpp
|
||||
sizeratio.cpp
|
||||
gamescenebase.cpp
|
||||
worldgrid.cpp
|
||||
worldviewport.cpp
|
||||
inputbag.cpp
|
||||
tileiterator.cpp
|
||||
texture.cpp
|
||||
movingobject.cpp
|
||||
character.cpp
|
||||
rect_to_sdl.cpp
|
||||
worldsizenotifiable.cpp
|
||||
worlditems.cpp
|
||||
moveable.cpp
|
||||
fsgn.cpp
|
||||
grid_raytrace.cpp
|
||||
)
|
||||
set_property(TARGET ${PROJECT_NAME} PROPERTY CXX_STANDARD 14)
|
||||
set_property(TARGET ${PROJECT_NAME} PROPERTY CXX_STANDARD_REQUIRED ON)
|
||||
|
||||
target_include_directories(${PROJECT_NAME} SYSTEM
|
||||
PRIVATE ${SDL2_INCLUDE_DIR}
|
||||
PRIVATE ${SDL2IMAGE_INCLUDE_DIRS}
|
||||
PRIVATE ${PNG_INCLUDE_DIRS}
|
||||
PRIVATE ${Boost_INCLUDE_DIRS}
|
||||
PRIVATE ${CMAKE_SOURCE_DIR}/lib/tree-2.81/src
|
||||
)
|
||||
target_include_directories(${PROJECT_NAME}
|
||||
PUBLIC ${CMAKE_SOURCE_DIR}/lib/vectorwrapper/include
|
||||
PRIVATE ${CMAKE_BINARY_DIR}
|
||||
)
|
||||
|
||||
target_link_libraries(${PROJECT_NAME}
|
||||
PRIVATE ${SDL2_LIBRARIES}
|
||||
PRIVATE ${SDL2IMAGE_LIBRARIES}
|
||||
PRIVATE ${PNG_LIBRARIES}
|
||||
PUBLIC mycurry_toplevel
|
||||
)
|
||||
|
||||
target_compile_definitions(${PROJECT_NAME}
|
||||
PRIVATE ${PNG_DEFINITIONS}
|
||||
PUBLIC VWR_WITH_IMPLICIT_CONVERSIONS=1
|
||||
PUBLIC VWR_EXTRA_ACCESSORS
|
||||
)
|
|
@ -19,7 +19,7 @@
|
|||
|
||||
#include "ingamescene.hpp"
|
||||
#include "sdlmain.hpp"
|
||||
#include "mycurryConfig.h"
|
||||
#include "mycurry_toplevelConfig.h"
|
||||
#include "key.hpp"
|
||||
#include "inputbag.hpp"
|
||||
#include "movingobject.hpp"
|
17
src/standalone/CMakeLists.txt
Normal file
17
src/standalone/CMakeLists.txt
Normal file
|
@ -0,0 +1,17 @@
|
|||
project(mycurry CXX)
|
||||
|
||||
add_executable(${PROJECT_NAME}
|
||||
main.cpp
|
||||
)
|
||||
set_property(TARGET ${PROJECT_NAME} PROPERTY CXX_STANDARD 14)
|
||||
set_property(TARGET ${PROJECT_NAME} PROPERTY CXX_STANDARD_REQUIRED ON)
|
||||
|
||||
target_include_directories(${PROJECT_NAME}
|
||||
PRIVATE "${CMAKE_SOURCE_DIR}/src/gamelib"
|
||||
PRIVATE ${CMAKE_BINARY_DIR}
|
||||
PRIVATE ${CMAKE_SOURCE_DIR}/lib/DeathHandler
|
||||
)
|
||||
|
||||
target_link_libraries(${PROJECT_NAME}
|
||||
PRIVATE mycurry_gamelib
|
||||
)
|
|
@ -1,15 +1,11 @@
|
|||
project(mycurry_unit_test CXX)
|
||||
|
||||
set(CMAKE_CXX_STANDARD 14)
|
||||
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||
|
||||
add_executable(${PROJECT_NAME}
|
||||
main.cpp
|
||||
${MYCURRY_SOURCE_DIR}/grid_raytrace.cpp
|
||||
grid_raytrace.cpp
|
||||
${MYCURRY_SOURCE_DIR}/worldgrid.cpp
|
||||
${MYCURRY_SOURCE_DIR}/fsgn.cpp
|
||||
)
|
||||
set_property(TARGET ${PROJECT_NAME} PROPERTY CXX_STANDARD 14)
|
||||
set_property(TARGET ${PROJECT_NAME} PROPERTY CXX_STANDARD_REQUIRED ON)
|
||||
|
||||
target_compile_definitions(${PROJECT_NAME}
|
||||
PRIVATE VWR_WITH_IMPLICIT_CONVERSIONS=1
|
||||
|
@ -18,7 +14,7 @@ target_compile_definitions(${PROJECT_NAME}
|
|||
|
||||
target_include_directories(${PROJECT_NAME}
|
||||
PRIVATE ${CATCH_SOURCE_DIR}/single_include
|
||||
PRIVATE ${MYCURRY_SOURCE_DIR}
|
||||
PRIVATE ${CMAKE_SOURCE_DIR}/src/gamelib
|
||||
PRIVATE ${CMAKE_SOURCE_DIR}/lib/vectorwrapper/include
|
||||
PRIVATE ${CMAKE_SOURCE_DIR}/lib/tree-2.81/src
|
||||
)
|
||||
|
@ -29,4 +25,6 @@ add_test(
|
|||
COMMAND ${PROJECT_NAME}
|
||||
)
|
||||
|
||||
|
||||
target_link_libraries(${PROJECT_NAME}
|
||||
PRIVATE mycurry_gamelib
|
||||
)
|
||||
|
|
Loading…
Reference in a new issue