author | koda |
Fri, 09 Nov 2012 14:32:54 +0000 | |
branch | webgl |
changeset 7997 | 7dff08baf9e3 |
parent 7995 | 889ad929cc81 |
child 7999 | bb503cd46516 |
permissions | -rw-r--r-- |
184 | 1 |
project(hedgewars) |
2 |
||
5407 | 3 |
|
4 |
#initialise cmake environment |
|
1461
87e5a6c3882c
Ping clients every 30 seconds, should help with ghosts on server
unc0rr
parents:
1459
diff
changeset
|
5 |
cmake_minimum_required(VERSION 2.6.0 FATAL_ERROR) |
5169 | 6 |
FOREACH(policy CMP0003 CMP0012) |
7220 | 7 |
IF(POLICY ${policy}) |
8 |
CMAKE_POLICY(SET ${policy} NEW) |
|
9 |
ENDIF() |
|
5169 | 10 |
ENDFOREACH() |
5407 | 11 |
set(CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/cmake_modules) |
5405 | 12 |
|
1107 | 13 |
|
4252 | 14 |
#detect Mercurial revision (if present) |
7927 | 15 |
set(version_suffix "") #UNSET THIS VARIABLE AT RELEASE TIME |
4903 | 16 |
set(HGCHANGED "") |
3074 | 17 |
IF(version_suffix MATCHES "-dev") |
7220 | 18 |
set(HW_DEV true) |
7709
631852904cee
only accept RELASE and DEBUG build type configuration
koda
parents:
7705
diff
changeset
|
19 |
set(default_build_type "DEBUG") |
631852904cee
only accept RELASE and DEBUG build type configuration
koda
parents:
7705
diff
changeset
|
20 |
IF(EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/.hg) |
7220 | 21 |
FIND_PROGRAM(HGCOMMAND hg) |
22 |
IF(HGCOMMAND) |
|
23 |
exec_program(${HGCOMMAND} |
|
24 |
ARGS identify -in ${CMAKE_CURRENT_SOURCE_DIR} |
|
25 |
OUTPUT_VARIABLE version_suffix |
|
26 |
) |
|
27 |
STRING(REGEX REPLACE "[^+]" "" HGCHANGED ${version_suffix}) |
|
28 |
STRING(REGEX REPLACE "([0-9a-zA-Z]+)(.*) ([0-9]+)(.*)" "\\3-\\1" version_suffix ${version_suffix}) |
|
29 |
IF (HGCHANGED) |
|
30 |
MESSAGE(STATUS "Building revision ${version_suffix} (SOURCE CODE MODIFIED)") |
|
31 |
ELSE() |
|
32 |
MESSAGE(STATUS "Building revision ${version_suffix}") |
|
33 |
ENDIF() |
|
34 |
set(version_suffix "-${version_suffix}") |
|
35 |
ENDIF() |
|
36 |
ENDIF() |
|
3074 | 37 |
ELSE() |
7220 | 38 |
set(HW_DEV false) |
7709
631852904cee
only accept RELASE and DEBUG build type configuration
koda
parents:
7705
diff
changeset
|
39 |
set(default_build_type "RELEASE") |
2672 | 40 |
ENDIF() |
41 |
||
1107 | 42 |
|
5405 | 43 |
#versioning |
5407 | 44 |
set(CPACK_PACKAGE_VERSION_MAJOR 0) |
45 |
set(CPACK_PACKAGE_VERSION_MINOR 9) |
|
7927 | 46 |
set(CPACK_PACKAGE_VERSION_PATCH 18${version_suffix}) |
47 |
set(HEDGEWARS_PROTO_VER 43) |
|
5407 | 48 |
set(HEDGEWARS_VERSION "${CPACK_PACKAGE_VERSION_MAJOR}.${CPACK_PACKAGE_VERSION_MINOR}.${CPACK_PACKAGE_VERSION_PATCH}") |
5405 | 49 |
|
907 | 50 |
|
7718
97ba379164ec
use cmake OPTION for arguments and further cleanup on CMakeFiles
koda
parents:
7709
diff
changeset
|
51 |
#set some default values |
97ba379164ec
use cmake OPTION for arguments and further cleanup on CMakeFiles
koda
parents:
7709
diff
changeset
|
52 |
option(NOSERVER "Disable gameServer build [default: auto]" OFF) |
97ba379164ec
use cmake OPTION for arguments and further cleanup on CMakeFiles
koda
parents:
7709
diff
changeset
|
53 |
option(NOPNG "Disable screenshoot compression [default: auto]" OFF) |
97ba379164ec
use cmake OPTION for arguments and further cleanup on CMakeFiles
koda
parents:
7709
diff
changeset
|
54 |
option(NOVIDEOREC "Disable video recording [default: auto]" OFF) |
97ba379164ec
use cmake OPTION for arguments and further cleanup on CMakeFiles
koda
parents:
7709
diff
changeset
|
55 |
|
97ba379164ec
use cmake OPTION for arguments and further cleanup on CMakeFiles
koda
parents:
7709
diff
changeset
|
56 |
option(ANDROID "Enable Android build [default: off]" OFF) |
7993 | 57 |
option(WEBGL "Enable WebGL build (implies NOPASCAL) [default: off]" OFF) |
7995
889ad929cc81
rename BUILD_ENGINE_LIBRARY to LIBENGINE option, so that no _ are used for cmake options
koda
parents:
7993
diff
changeset
|
58 |
option(LIBENGINE "Enable hwengine library [default: off]" OFF) |
889ad929cc81
rename BUILD_ENGINE_LIBRARY to LIBENGINE option, so that no _ are used for cmake options
koda
parents:
7993
diff
changeset
|
59 |
|
7993 | 60 |
option(NOPASCAL "Compile hwengine as native C [default: off]" ${WEBGL}) |
7933 | 61 |
option(NOAUTOUPDATE "Disable OS X Sparkle update checking" OFF) |
7718
97ba379164ec
use cmake OPTION for arguments and further cleanup on CMakeFiles
koda
parents:
7709
diff
changeset
|
62 |
option(CROSSAPPLE "Enable OSX when not on OSX [default: off]" OFF) |
97ba379164ec
use cmake OPTION for arguments and further cleanup on CMakeFiles
koda
parents:
7709
diff
changeset
|
63 |
|
3495
a6b4f351d400
now engine can be optionally built as library, there's an example wrapper of how to use it
koda
parents:
3407
diff
changeset
|
64 |
|
5405 | 65 |
#bundle .app setup |
7256 | 66 |
if(APPLE OR CROSSAPPLE) |
7220 | 67 |
#paths for creating the bundle |
68 |
set(bundle_name Hedgewars.app) |
|
69 |
set(frameworks_dir ${bundle_name}/Contents/Frameworks/) |
|
70 |
set(CMAKE_INSTALL_PREFIX ${bundle_name}/Contents/MacOS/) |
|
71 |
set(DATA_INSTALL_DIR "../Resources/") |
|
72 |
set(target_dir ".") |
|
7256 | 73 |
set(minimum_macosx_version "10.6") |
7718
97ba379164ec
use cmake OPTION for arguments and further cleanup on CMakeFiles
koda
parents:
7709
diff
changeset
|
74 |
else() |
97ba379164ec
use cmake OPTION for arguments and further cleanup on CMakeFiles
koda
parents:
7709
diff
changeset
|
75 |
set(target_dir "bin") |
7256 | 76 |
endif() |
77 |
||
78 |
if(APPLE) |
|
79 |
set(CMAKE_FIND_FRAMEWORK "FIRST") |
|
3697 | 80 |
|
7220 | 81 |
#what system are we building for |
82 |
set(minimum_macosx_version $ENV{MACOSX_DEPLOYMENT_TARGET}) |
|
3697 | 83 |
|
7220 | 84 |
#detect on which system we are: if sw_vers cannot be found for any reason (re)use minimum_macosx_version |
85 |
find_program(sw_vers sw_vers) |
|
86 |
if(sw_vers) |
|
87 |
exec_program(${sw_vers} ARGS "-productVersion" OUTPUT_VARIABLE current_macosx_version) |
|
88 |
string(REGEX REPLACE "([0-9]+.[0-9]+).[0-9]+" "\\1" current_macosx_version ${current_macosx_version}) |
|
89 |
else() |
|
90 |
if(NOT minimum_macosx_version) |
|
91 |
message(FATAL_ERROR "sw_vers not found! Need explicit MACOSX_DEPLOYMENT_TARGET variable set") |
|
7114
e0110a1229b7
add NOPNG to cmake to explicitly disable PNG dependency
koda
parents:
7113
diff
changeset
|
92 |
else() |
7220 | 93 |
set(current_macosx_version ${minimum_macosx_version}) |
94 |
endif() |
|
95 |
endif() |
|
2641 | 96 |
|
7220 | 97 |
#if nothing is set, we deploy only for the current system |
98 |
if(NOT minimum_macosx_version) |
|
99 |
set(minimum_macosx_version ${current_macosx_version}) |
|
100 |
endif() |
|
2641 | 101 |
|
7220 | 102 |
#lower systems don't have enough processing power anyways |
103 |
if (minimum_macosx_version LESS "10.4") |
|
104 |
message(FATAL_ERROR "Hedgewars is not supported on Mac OS X pre-10.4") |
|
105 |
endif() |
|
2929 | 106 |
|
7220 | 107 |
#workaround for http://playcontrol.net/ewing/jibberjabber/big_behind-the-scenes_chang.html#SDL_mixer (Update 2) |
108 |
if(current_macosx_version MATCHES "10.4") |
|
109 |
find_package(SDL_mixer REQUIRED) |
|
110 |
set(DYLIB_SMPEG "-dylib_file @loader_path/Frameworks/smpeg.framework/Versions/A/smpeg:${SDLMIXER_LIBRARY}/Versions/A/Frameworks/smpeg.framework/Versions/A/smpeg") |
|
111 |
set(DYLIB_MIKMOD "-dylib_file @loader_path/Frameworks/mikmod.framework/Versions/A/mikmod:${SDLMIXER_LIBRARY}/Versions/A/Frameworks/mikmod.framework/Versions/A/mikmod") |
|
112 |
set(pascal_flags "-k${DYLIB_SMPEG}" "-k${DYLIB_MIKMOD}" ${pascal_flags}) |
|
113 |
set(CMAKE_C_FLAGS "${DYLIB_SMPEG}" "${DYLIB_MIKMOD}" ${CMAKE_C_FLAGS}) |
|
114 |
endif() |
|
7114
e0110a1229b7
add NOPNG to cmake to explicitly disable PNG dependency
koda
parents:
7113
diff
changeset
|
115 |
|
7220 | 116 |
#CMAKE_OSX_ARCHITECTURES and CMAKE_OSX_SYSROOT need to be set for universal binary and correct linking |
117 |
if(NOT CMAKE_OSX_ARCHITECTURES) |
|
118 |
if(current_macosx_version LESS "10.6") |
|
119 |
if(${CMAKE_SYSTEM_PROCESSOR} MATCHES "powerpc*") |
|
120 |
set(CMAKE_OSX_ARCHITECTURES "ppc7400") |
|
121 |
else() |
|
122 |
set(CMAKE_OSX_ARCHITECTURES "i386") |
|
123 |
endif() |
|
124 |
else() |
|
125 |
set(CMAKE_OSX_ARCHITECTURES "x86_64") |
|
126 |
endif() |
|
127 |
endif() |
|
5053 | 128 |
|
7220 | 129 |
#CMAKE_OSX_SYSROOT is set at the system version we are supposed to build on |
130 |
#we need to provide the correct one when host and target differ |
|
131 |
if(NOT ${minimum_macosx_version} MATCHES ${current_macosx_version}) |
|
132 |
if(minimum_macosx_version MATCHES "10.4") |
|
133 |
set(CMAKE_OSX_SYSROOT "/Developer/SDKs/MacOSX10.4u.sdk/") |
|
134 |
set(CMAKE_C_COMPILER "gcc-4.0") |
|
135 |
set(CMAKE_CXX_COMPILER "g++-4.0") |
|
136 |
else() |
|
137 |
string(REGEX REPLACE "([0-9]+.[0-9]+).[0-9]+" "\\1" sdk_version ${minimum_macosx_version}) |
|
138 |
set(CMAKE_OSX_SYSROOT "/Developer/SDKs/MacOSX${sdk_version}.sdk/") |
|
139 |
endif() |
|
140 |
endif() |
|
2641 | 141 |
|
7220 | 142 |
#add user framework directory, other paths can be passed via FPFLAGS |
143 |
set(pascal_flags "-Ff~/Library/Frameworks" ${pascal_flags}) |
|
144 |
#set deployment target |
|
145 |
set(pascal_flags "-k-macosx_version_min" "-k${minimum_macosx_version}" "-XR${CMAKE_OSX_SYSROOT}" ${pascal_flags}) |
|
5188 | 146 |
|
7220 | 147 |
message(STATUS "Build system: Mac OS X ${current_macosx_version} with GCC:${CMAKE_C_COMPILER}") |
148 |
message(STATUS "Target system: Mac OS X ${minimum_macosx_version} for architecture(s):${CMAKE_OSX_ARCHITECTURES}") |
|
2015 | 149 |
endif(APPLE) |
150 |
||
2406 | 151 |
|
7705
15f5d3cd35c6
force a DEBUG build when HW_DEV is true, some CMakeLists.txt cleanup/commenting
koda
parents:
7704
diff
changeset
|
152 |
#when build type is not specified, assume Debug/Release according to build version information |
7709
631852904cee
only accept RELASE and DEBUG build type configuration
koda
parents:
7705
diff
changeset
|
153 |
if (CMAKE_BUILD_TYPE) |
631852904cee
only accept RELASE and DEBUG build type configuration
koda
parents:
7705
diff
changeset
|
154 |
string (TOUPPER ${CMAKE_BUILD_TYPE} CMAKE_BUILD_TYPE) |
631852904cee
only accept RELASE and DEBUG build type configuration
koda
parents:
7705
diff
changeset
|
155 |
if ( NOT( (CMAKE_BUILD_TYPE MATCHES "RELEASE") OR (CMAKE_BUILD_TYPE MATCHES "DEBUG") ) ) |
631852904cee
only accept RELASE and DEBUG build type configuration
koda
parents:
7705
diff
changeset
|
156 |
set (CMAKE_BUILD_TYPE ${default_build_type} CACHE STRING "Only 'Debug' or 'Release' options are allowed." FORCE) |
631852904cee
only accept RELASE and DEBUG build type configuration
koda
parents:
7705
diff
changeset
|
157 |
message (STATUS "Unknown build type, using default (${default_build_type})") |
631852904cee
only accept RELASE and DEBUG build type configuration
koda
parents:
7705
diff
changeset
|
158 |
endif () |
631852904cee
only accept RELASE and DEBUG build type configuration
koda
parents:
7705
diff
changeset
|
159 |
else (CMAKE_BUILD_TYPE) |
631852904cee
only accept RELASE and DEBUG build type configuration
koda
parents:
7705
diff
changeset
|
160 |
set (CMAKE_BUILD_TYPE ${default_build_type} CACHE STRING "Choose the build type, options are: Debug Release." FORCE) |
631852904cee
only accept RELASE and DEBUG build type configuration
koda
parents:
7705
diff
changeset
|
161 |
endif (CMAKE_BUILD_TYPE) |
2606
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
162 |
|
2406 | 163 |
|
7030
09984acadece
invert LUA symbol meaning and avoid hints when compiling without it
koda
parents:
7029
diff
changeset
|
164 |
#set default flags values for all projects |
3338
dee9beba85cc
patch by raptor (polished by me) to allow tiger/xcode24 compilation
koda
parents:
3306
diff
changeset
|
165 |
set(CMAKE_C_FLAGS "-pipe ${CMAKE_C_FLAGS}") |
6538
5a1f49d84d95
testing, let's try -Os optimisation for frontend and engine; small cleanup and typos
koda
parents:
6537
diff
changeset
|
166 |
set(CMAKE_C_FLAGS_RELEASE "-w -Os -fomit-frame-pointer ${CMAKE_C_FLAGS_RELEASE}") |
3338
dee9beba85cc
patch by raptor (polished by me) to allow tiger/xcode24 compilation
koda
parents:
3306
diff
changeset
|
167 |
set(CMAKE_C_FLAGS_DEBUG "-Wall -O0 -g -DDEBUG ${CMAKE_C_FLAGS_DEBUG}") |
2606
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
168 |
set(CMAKE_CXX_FLAGS ${CMAKE_C_FLAGS}) |
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
169 |
set(CMAKE_CXX_FLAGS_RELEASE ${CMAKE_C_FLAGS_RELEASE}) |
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
170 |
set(CMAKE_CXX_FLAGS_DEBUG ${CMAKE_C_FLAGS_DEBUG}) |
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
171 |
|
7397
833fc211ca2d
allow FPFLAGS and GHFLAGS only in cmakes able to support them
koda
parents:
7264
diff
changeset
|
172 |
#parse additional parameters |
833fc211ca2d
allow FPFLAGS and GHFLAGS only in cmakes able to support them
koda
parents:
7264
diff
changeset
|
173 |
if(FPFLAGS OR GHFLAGS) |
833fc211ca2d
allow FPFLAGS and GHFLAGS only in cmakes able to support them
koda
parents:
7264
diff
changeset
|
174 |
math(EXPR cmake_version "${CMAKE_MAJOR_VERSION}*10000 + ${CMAKE_MINOR_VERSION}*100 + ${CMAKE_PATCH_VERSION}") |
833fc211ca2d
allow FPFLAGS and GHFLAGS only in cmakes able to support them
koda
parents:
7264
diff
changeset
|
175 |
if(cmake_version LESS "020800") |
7705
15f5d3cd35c6
force a DEBUG build when HW_DEV is true, some CMakeLists.txt cleanup/commenting
koda
parents:
7704
diff
changeset
|
176 |
message(STATUS "FPFLAGS and GHFLAGS are available only when using CMake >= 2.8") |
7397
833fc211ca2d
allow FPFLAGS and GHFLAGS only in cmakes able to support them
koda
parents:
7264
diff
changeset
|
177 |
else() |
7705
15f5d3cd35c6
force a DEBUG build when HW_DEV is true, some CMakeLists.txt cleanup/commenting
koda
parents:
7704
diff
changeset
|
178 |
separate_arguments(fpflags_parsed UNIX_COMMAND ${FPFLAGS}) |
15f5d3cd35c6
force a DEBUG build when HW_DEV is true, some CMakeLists.txt cleanup/commenting
koda
parents:
7704
diff
changeset
|
179 |
separate_arguments(ghflags_parsed UNIX_COMMAND ${GHFLAGS}) |
7397
833fc211ca2d
allow FPFLAGS and GHFLAGS only in cmakes able to support them
koda
parents:
7264
diff
changeset
|
180 |
endif() |
833fc211ca2d
allow FPFLAGS and GHFLAGS only in cmakes able to support them
koda
parents:
7264
diff
changeset
|
181 |
endif() |
833fc211ca2d
allow FPFLAGS and GHFLAGS only in cmakes able to support them
koda
parents:
7264
diff
changeset
|
182 |
|
7816 | 183 |
set(pascal_flags ${fpflags_parsed} "-vm4079,4080,4081" "-B" "-FE../bin" "-Cs2000000" "-vewnq" "-dDEBUGFILE" ${pascal_flags}) |
7705
15f5d3cd35c6
force a DEBUG build when HW_DEV is true, some CMakeLists.txt cleanup/commenting
koda
parents:
7704
diff
changeset
|
184 |
set(haskell_flags "-O2" ${ghflags_parsed} ${haskell_flags}) |
2606
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
185 |
|
7705
15f5d3cd35c6
force a DEBUG build when HW_DEV is true, some CMakeLists.txt cleanup/commenting
koda
parents:
7704
diff
changeset
|
186 |
#get BUILD_TYPE and enable/disable optimisation |
7709
631852904cee
only accept RELASE and DEBUG build type configuration
koda
parents:
7705
diff
changeset
|
187 |
if(CMAKE_BUILD_TYPE MATCHES "DEBUG") |
631852904cee
only accept RELASE and DEBUG build type configuration
koda
parents:
7705
diff
changeset
|
188 |
message(STATUS "Building Debug flavour") |
7820 | 189 |
set(pascal_flags "-O-" "-g" "-gl" "-gv" ${pascal_flags}) |
7705
15f5d3cd35c6
force a DEBUG build when HW_DEV is true, some CMakeLists.txt cleanup/commenting
koda
parents:
7704
diff
changeset
|
190 |
set(haskell_flags "-Wall" "-debug" "-dcore-lint" "-fno-warn-unused-do-bind" ${haskell_flags}) |
15f5d3cd35c6
force a DEBUG build when HW_DEV is true, some CMakeLists.txt cleanup/commenting
koda
parents:
7704
diff
changeset
|
191 |
else() |
7709
631852904cee
only accept RELASE and DEBUG build type configuration
koda
parents:
7705
diff
changeset
|
192 |
message(STATUS "Building Release flavour") |
7220 | 193 |
# set(pascal_flags "-O3" "-OpPENTIUM4" "-CfSSE3" "-Xs" "-Si" ${pascal_flags}) |
194 |
set(pascal_flags "-Os" "-Ooregvar" "-Xs" "-Si" ${pascal_flags}) |
|
195 |
set(haskell_flags "-w" "-fno-warn-unused-do-bind" ${haskell_flags}) |
|
7705
15f5d3cd35c6
force a DEBUG build when HW_DEV is true, some CMakeLists.txt cleanup/commenting
koda
parents:
7704
diff
changeset
|
196 |
endif() |
2606
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
197 |
|
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
198 |
|
7705
15f5d3cd35c6
force a DEBUG build when HW_DEV is true, some CMakeLists.txt cleanup/commenting
koda
parents:
7704
diff
changeset
|
199 |
#finish setting paths |
266 | 200 |
if(DEFINED DATA_INSTALL_DIR) |
7220 | 201 |
set(SHAREPATH ${DATA_INSTALL_DIR}/hedgewars/) |
2652 | 202 |
else() |
7220 | 203 |
set(SHAREPATH share/hedgewars/) |
2652 | 204 |
endif() |
220 | 205 |
set(EXECUTABLE_OUTPUT_PATH ${PROJECT_BINARY_DIR}/bin) |
7718
97ba379164ec
use cmake OPTION for arguments and further cleanup on CMakeFiles
koda
parents:
7709
diff
changeset
|
206 |
set(LIBRARY_OUTPUT_PATH ${EXECUTABLE_OUTPUT_PATH}) |
184 | 207 |
|
271 | 208 |
|
7993 | 209 |
#Haskell compiler discovery (for server and engine in c) |
210 |
if((NOT NOSERVER) OR NOPASCAL) |
|
7220 | 211 |
if(GHC) |
212 |
set(ghc_executable ${GHC}) |
|
213 |
else() |
|
214 |
find_program(ghc_executable ghc) |
|
215 |
endif() |
|
5053 | 216 |
|
7220 | 217 |
if(ghc_executable) |
7973 | 218 |
exec_program(${ghc_executable} ARGS "-V" OUTPUT_VARIABLE ghc_version_long) |
219 |
string(REGEX REPLACE ".*([0-9]+\\.[0-9]+\\.[0-9]+)" "\\1" ghc_version "${ghc_version_long}") |
|
220 |
message(STATUS "Found GHC: ${ghc_executable} (version ${ghc_version})") |
|
7220 | 221 |
else() |
7973 | 222 |
message(STATUS "Could NOT find GHC, needed by gameServer and pas2c") |
7220 | 223 |
endif() |
7973 | 224 |
endif() |
225 |
||
226 |
||
227 |
#check gameServer |
|
228 |
if((ghc_executable) AND (NOT NOSERVER) AND (NOT WEBGL)) |
|
229 |
set(HAVE_NETSERVER true) |
|
230 |
add_subdirectory(gameServer) |
|
7223 | 231 |
else() |
7973 | 232 |
message(STATUS "Skipping gameServer target") |
7220 | 233 |
set(HAVE_NETSERVER false) |
7223 | 234 |
endif() |
1415
6fbfee0e113a
Allow build without net game server: introduce -DWITH_SERVER configuration parameter
unc0rr
parents:
1370
diff
changeset
|
235 |
|
7705
15f5d3cd35c6
force a DEBUG build when HW_DEV is true, some CMakeLists.txt cleanup/commenting
koda
parents:
7704
diff
changeset
|
236 |
|
15f5d3cd35c6
force a DEBUG build when HW_DEV is true, some CMakeLists.txt cleanup/commenting
koda
parents:
7704
diff
changeset
|
237 |
#lua discovery |
7031
d5ea24399a48
when Lua is not found, fallback to compiling the one that comes bundled in our sources
koda
parents:
7030
diff
changeset
|
238 |
find_package(Lua) |
7973 | 239 |
if(LUA_FOUND AND (NOT WEBGL)) |
7817
6cc558a69b58
countless small optimisation for cmake, output messages are now coherent (mostly) and the options get fully respected (eg. skipping library search if not activated)
koda
parents:
7816
diff
changeset
|
240 |
message(STATUS "Found LUA: ${LUA_DEFAULT}") |
7223 | 241 |
else() |
7993 | 242 |
message(STATUS "Using internal LUA library") |
7220 | 243 |
add_subdirectory(misc/liblua) |
7223 | 244 |
#linking with liblua.a requires system readline -- this works everywhere, right? |
7704
b25add2fdfa6
slight tweak to lua linking (that will break everything, i'm sure)
koda
parents:
7397
diff
changeset
|
245 |
set(pascal_flags "-k${EXECUTABLE_OUTPUT_PATH}/lib${LUA_LIBRARY}.a" "-k-lreadline" ${pascal_flags}) |
7031
d5ea24399a48
when Lua is not found, fallback to compiling the one that comes bundled in our sources
koda
parents:
7030
diff
changeset
|
246 |
endif() |
7223 | 247 |
|
7705
15f5d3cd35c6
force a DEBUG build when HW_DEV is true, some CMakeLists.txt cleanup/commenting
koda
parents:
7704
diff
changeset
|
248 |
|
7993 | 249 |
if(NOPASCAL) |
7973 | 250 |
if (NOT ghc_executable) |
7993 | 251 |
message(FATAL_ERROR "A Haskell compiler is required to build engine in C") |
7973 | 252 |
endif() |
253 |
#pascal to c converter |
|
254 |
add_subdirectory(tools/pas2c) |
|
255 |
else() |
|
7993 | 256 |
#main pascal engine |
7973 | 257 |
add_subdirectory(hedgewars) |
7993 | 258 |
endif() |
5053 | 259 |
|
7993 | 260 |
if(WEBGL) |
261 |
#WEBGL deps |
|
262 |
else() |
|
7973 | 263 |
#Android related build scripts |
264 |
if(ANDROID) |
|
265 |
add_subdirectory(project_files/Android-build) |
|
266 |
endif() |
|
267 |
||
7995
889ad929cc81
rename BUILD_ENGINE_LIBRARY to LIBENGINE option, so that no _ are used for cmake options
koda
parents:
7993
diff
changeset
|
268 |
#TODO: when ANDROID, LIBENGINE should be set |
889ad929cc81
rename BUILD_ENGINE_LIBRARY to LIBENGINE option, so that no _ are used for cmake options
koda
parents:
7993
diff
changeset
|
269 |
if(NOT (LIBENGINE OR ANDROID)) |
7973 | 270 |
add_subdirectory(bin) |
271 |
add_subdirectory(misc/quazip) |
|
272 |
add_subdirectory(QTfrontend) |
|
273 |
add_subdirectory(share) |
|
274 |
add_subdirectory(tools) |
|
275 |
endif() |
|
6025
cac1d5601d7c
reviewed the build system and parts of the previous merge, performed some code cleanup
koda
parents:
6023
diff
changeset
|
276 |
endif() |
5381
8f95038f3f75
Removed protocol check, using CMake now to setup the building scripts using Templates/* removed old scripts
Xeli
parents:
5223
diff
changeset
|
277 |
|
2203
6bd39d75e0dd
-Added support for Release and Debug for CMAKE_BUILD_TYPE
koda
parents:
2200
diff
changeset
|
278 |
|
584
f381705f1aeb
Some stuff to get good results from make 'package_source'
unc0rr
parents:
546
diff
changeset
|
279 |
|
5405 | 280 |
# CPack variables |
3338
dee9beba85cc
patch by raptor (polished by me) to allow tiger/xcode24 compilation
koda
parents:
3306
diff
changeset
|
281 |
set(CPACK_PACKAGE_DESCRIPTION_SUMMARY "Hedgewars, a free turn-based strategy") |
2827 | 282 |
set(CPACK_PACKAGE_VENDOR "Hedgewars Project") |
907 | 283 |
set(CPACK_PACKAGE_FILE_NAME "hedgewars-${HEDGEWARS_VERSION}") |
284 |
set(CPACK_SOURCE_PACKAGE_FILE_NAME "hedgewars-src-${HEDGEWARS_VERSION}") |
|
1459 | 285 |
set(CPACK_SOURCE_GENERATOR "TBZ2") |
1173
70b0acd4548c
Revert accidental nsis installer generator regression
unc0rr
parents:
1159
diff
changeset
|
286 |
set(CPACK_PACKAGE_EXECUTABLES "hedgewars" "hedgewars") |
458 | 287 |
set(CPACK_RESOURCE_FILE_LICENSE "${CMAKE_CURRENT_SOURCE_DIR}/COPYING") |
907 | 288 |
set(CPACK_PACKAGE_INSTALL_DIRECTORY "Hedgewars ${HEDGEWARS_VERSION}") |
184 | 289 |
|
290 |
if(WIN32 AND NOT UNIX) |
|
7220 | 291 |
set(CPACK_NSIS_DISPLAY_NAME "Hedgewars") |
292 |
set(CPACK_NSIS_HELP_LINK "http://www.hedgewars.org/") |
|
293 |
set(CPACK_NSIS_URL_INFO_ABOUT "http://www.hedgewars.org/") |
|
294 |
set(CPACK_NSIS_CONTACT "unC0Rr@gmail.com") |
|
295 |
set(CPACK_NSIS_MODIFY_PATH OFF) |
|
296 |
set(CPACK_GENERATOR "ZIP;NSIS") |
|
297 |
set(CPACK_PACKAGE_INSTALL_REGISTRY_KEY "hedgewars") |
|
184 | 298 |
else(WIN32 AND NOT UNIX) |
7220 | 299 |
set(CPACK_STRIP_FILES "bin/hedgewars;bin/hwengine") |
184 | 300 |
endif(WIN32 AND NOT UNIX) |
301 |
||
584
f381705f1aeb
Some stuff to get good results from make 'package_source'
unc0rr
parents:
546
diff
changeset
|
302 |
set(CPACK_SOURCE_IGNORE_FILES |
7220 | 303 |
"~" |
304 |
"\\\\.hg" |
|
305 |
"\\\\.svn" |
|
306 |
"\\\\.exe$" |
|
307 |
"\\\\.a$" |
|
308 |
"\\\\.dll$" |
|
309 |
"\\\\.xcf$" |
|
310 |
"\\\\.cxx$" |
|
311 |
"\\\\.db$" |
|
312 |
"\\\\.dof$" |
|
313 |
"\\\\.layout$" |
|
314 |
"\\\\.zip$" |
|
315 |
"\\\\.gz$" |
|
316 |
"\\\\.bz2$" |
|
317 |
"\\\\.tmp$" |
|
318 |
"\\\\.core$" |
|
319 |
"\\\\.sh$" |
|
320 |
"\\\\.sifz$" |
|
321 |
"\\\\.svg$" |
|
322 |
"\\\\.svgz$" |
|
323 |
"\\\\.ppu$" |
|
324 |
"\\\\.psd$" |
|
325 |
"\\\\.o$" |
|
326 |
"Makefile" |
|
327 |
"Doxyfile" |
|
328 |
"CMakeFiles" |
|
329 |
"debug" |
|
330 |
"release$" |
|
331 |
"Debug$" |
|
332 |
"Release$" |
|
333 |
"proto\\\\.inc$" |
|
334 |
"hwconsts\\\\.cpp$" |
|
335 |
"playlist\\\\.inc$" |
|
336 |
"CPack" |
|
337 |
"cmake_install\\\\.cmake$" |
|
338 |
"config\\\\.inc$" |
|
339 |
"hwengine\\\\.desktop$" |
|
340 |
"CMakeCache\\\\.txt$" |
|
341 |
# "^${CMAKE_CURRENT_SOURCE_DIR}/misc/libopenalbridge" |
|
342 |
# "^${CMAKE_CURRENT_SOURCE_DIR}/misc/libfreetype" |
|
343 |
"^${CMAKE_CURRENT_SOURCE_DIR}/misc/liblua" |
|
344 |
# "^${CMAKE_CURRENT_SOURCE_DIR}/misc/libtremor" |
|
345 |
"^${CMAKE_CURRENT_SOURCE_DIR}/project_files/HedgewarsMobile/" |
|
346 |
"^${CMAKE_CURRENT_SOURCE_DIR}/bin/[a-z]" |
|
347 |
"^${CMAKE_CURRENT_SOURCE_DIR}/tools/templates" |
|
348 |
"^${CMAKE_CURRENT_SOURCE_DIR}/doc" |
|
349 |
"^${CMAKE_CURRENT_SOURCE_DIR}/templates" |
|
350 |
"^${CMAKE_CURRENT_SOURCE_DIR}/Graphics" |
|
351 |
"^${CMAKE_CURRENT_SOURCE_DIR}/realtest" |
|
352 |
"^${CMAKE_CURRENT_SOURCE_DIR}/tmp" |
|
353 |
"^${CMAKE_CURRENT_SOURCE_DIR}/utils" |
|
354 |
"^${CMAKE_CURRENT_SOURCE_DIR}/share/hedgewars/Data/Maps/test" |
|
355 |
"^${CMAKE_CURRENT_SOURCE_DIR}/share/hedgewars/Data/Themes/ethereal" |
|
356 |
"^${CMAKE_CURRENT_SOURCE_DIR}/install_manifest.txt" |
|
357 |
"^${CMAKE_CURRENT_SOURCE_DIR}/CMakeCache.txt" |
|
358 |
"^${CMAKE_CURRENT_SOURCE_DIR}/hedgewars\\\\." |
|
584
f381705f1aeb
Some stuff to get good results from make 'package_source'
unc0rr
parents:
546
diff
changeset
|
359 |
) |
f381705f1aeb
Some stuff to get good results from make 'package_source'
unc0rr
parents:
546
diff
changeset
|
360 |
|
184 | 361 |
include(CPack) |
5407 | 362 |