forked from rbfx/sample-project
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCMakeLists.txt
78 lines (63 loc) · 2.93 KB
/
CMakeLists.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
cmake_minimum_required(VERSION 3.14)
project (SampleProject)
set (PROJECT_UWP_GUID "D84454DA-854B-3661-9EDA-0B587569493A")
# C++17 is required for this project.
set (CMAKE_CXX_STANDARD 17)
# Setup output directories.
set (CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib)
set (CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin)
set (CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin)
# It is possible to use pre-built SDK or build the Framework from source.
# In your project, you can choose either option or keep both.
set (REBELFORK_SDK "" CACHE STRING "Path to pre-built SDK")
if ("${REBELFORK_SDK}" STREQUAL "")
# Include the Framework to build.
add_subdirectory (../rbfx ${CMAKE_BINARY_DIR}/3rdParty/rbfx)
# Set path to engine resources.
set (REBELFORK_BIN_DIR "${CMAKE_SOURCE_DIR}/../rbfx/bin")
set (REBELFORK_CMAKE_DIR "${CMAKE_SOURCE_DIR}/../rbfx/CMake")
else ()
# Include pre-built SDK.
# CMAKE_FIND_ROOT_PATH is required for Web builds because EMSDK ignores CMAKE_PREFIX_PATH by default.
set (CMAKE_PREFIX_PATH ${REBELFORK_SDK}/share)
list (APPEND CMAKE_FIND_ROOT_PATH ${REBELFORK_SDK}/share)
find_package (Urho3D REQUIRED)
# Set path to engine resources.
set (REBELFORK_BIN_DIR "${REBELFORK_SDK}/bin")
set (REBELFORK_CMAKE_DIR "${REBELFORK_SDK}/share/CMake")
endif ()
# Include common build scripts.
include (${REBELFORK_CMAKE_DIR}/Modules/UrhoCommon.cmake)
# Add plugins (optional).
include_directories (${CMAKE_SOURCE_DIR}/Plugins)
add_subdirectory (${CMAKE_SOURCE_DIR}/Plugins/Core.SamplePlugin)
# List all plugins used by the application.
set (APP_PLUGIN_NAME "App.Main")
set (APP_PLUGIN_LIST "Plugin.Core.SamplePlugin;${APP_PLUGIN_NAME}")
# Add main application library with all user code.
add_subdirectory (${CMAKE_SOURCE_DIR}/Source/Application)
# Add custom editor linked with user code.
# With dynamic linking, pre-built editor can be used.
add_subdirectory (${CMAKE_SOURCE_DIR}/Source/Editor)
# Add custom player.
add_subdirectory (${CMAKE_SOURCE_DIR}/Source/Launcher)
# Package resources from Project directory.
if (WEB OR MOBILE)
create_pak("${CMAKE_SOURCE_DIR}/Project/Data" "${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/Data.pak")
create_pak("${REBELFORK_BIN_DIR}/CoreData" "${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/CoreData.pak")
endif ()
# Link resources to Player for Web.
if (WEB)
web_executable (${CMAKE_PROJECT_NAME})
package_resources_web(
FILES "${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/Data.pak"
"${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/CoreData.pak"
RELATIVE_DIR "${CMAKE_RUNTIME_OUTPUT_DIRECTORY}"
OUTPUT "Resources.js"
INSTALL_TO "${CMAKE_RUNTIME_OUTPUT_DIRECTORY}"
)
web_link_resources(${CMAKE_PROJECT_NAME} Resources.js)
target_link_libraries(${CMAKE_PROJECT_NAME} PRIVATE "--shell-file ${REBELFORK_BIN_DIR}/shell.html")
endif ()
# Generate Visual Studio props file for csproj.
rbfx_configure_cmake_props()