author | nemo |
Wed, 22 Dec 2010 00:48:06 -0500 | |
changeset 4613 | f58ff1827763 |
parent 4568 | f85243bf890e |
child 4677 | 10848c80efec |
child 4697 | c27bea52efac |
permissions | -rw-r--r-- |
184 | 1 |
project(hedgewars) |
2 |
||
1461
87e5a6c3882c
Ping clients every 30 seconds, should help with ghosts on server
unc0rr
parents:
1459
diff
changeset
|
3 |
cmake_minimum_required(VERSION 2.6.0 FATAL_ERROR) |
3510
23145a950eae
Update repository checking code to reflect our recent Mercurial switch
koda
parents:
3495
diff
changeset
|
4 |
cmake_policy(SET CMP0003 NEW) |
184 | 5 |
|
3510
23145a950eae
Update repository checking code to reflect our recent Mercurial switch
koda
parents:
3495
diff
changeset
|
6 |
IF(POLICY CMP0012) |
4336 | 7 |
cmake_policy(SET CMP0012 NEW) |
3510
23145a950eae
Update repository checking code to reflect our recent Mercurial switch
koda
parents:
3495
diff
changeset
|
8 |
ENDIF() |
1107 | 9 |
|
4336 | 10 |
#detect Mercurial revision (if present) |
11 |
set(version_suffix "-dev") #UNSET THIS VARIABLE AT RELEASE TIME |
|
3074 | 12 |
IF(version_suffix MATCHES "-dev") |
4336 | 13 |
set(HW_DEV true) |
14 |
IF (EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/.hg) |
|
15 |
FIND_PROGRAM(HGCOMMAND hg) |
|
16 |
IF(HGCOMMAND) |
|
17 |
exec_program(${HGCOMMAND} |
|
18 |
ARGS identify -in ${CMAKE_CURRENT_SOURCE_DIR} |
|
19 |
OUTPUT_VARIABLE version_suffix |
|
20 |
) |
|
21 |
STRING(REGEX REPLACE "([0-9a-zA-Z]+)(.*) ([0-9]+)(.*)" "\\3:\\1" version_suffix ${version_suffix}) |
|
22 |
MESSAGE(STATUS "Building revision ${version_suffix}") |
|
4460
bdace1e2f8aa
write some version information inside the application
koda
parents:
4360
diff
changeset
|
23 |
set(version_suffix "-${version_suffix}") |
4336 | 24 |
ENDIF() |
25 |
ENDIF() |
|
3074 | 26 |
ELSE() |
4336 | 27 |
set(HW_DEV false) |
2672 | 28 |
ENDIF() |
29 |
||
1843 | 30 |
set(CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/cmake_modules) |
1107 | 31 |
|
907 | 32 |
set(CPACK_PACKAGE_VERSION_MAJOR "0") |
33 |
set(CPACK_PACKAGE_VERSION_MINOR "9") |
|
4336 | 34 |
set(CPACK_PACKAGE_VERSION_PATCH "15${version_suffix}") |
907 | 35 |
|
2641 | 36 |
#forbid in-tree building |
37 |
#IF (${CMAKE_SOURCE_DIR} MATCHES ${CMAKE_BINARY_DIR}) |
|
38 |
# MESSAGE(STATUS "Please do an out-of-tree build:") |
|
39 |
# MESSAGE(STATUS "rm CMakeCache.txt; mkdir build; cd build; cmake ..; make") |
|
40 |
# MESSAGE(FATAL_ERROR "In-tree-build detected!") |
|
41 |
#ENDIF (${CMAKE_SOURCE_DIR} MATCHES ${CMAKE_BINARY_DIR}) |
|
42 |
||
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
|
43 |
#set some safe values |
a6b4f351d400
now engine can be optionally built as library, there's an example wrapper of how to use it
koda
parents:
3407
diff
changeset
|
44 |
IF(NOT WITH_SERVER) |
4336 | 45 |
SET(WITH_SERVER 0) |
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
|
46 |
ENDIF(NOT WITH_SERVER) |
a6b4f351d400
now engine can be optionally built as library, there's an example wrapper of how to use it
koda
parents:
3407
diff
changeset
|
47 |
IF(NOT BUILD_ENGINE_LIBRARY) |
4336 | 48 |
SET(BUILD_ENGINE_LIBRARY 0) |
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
|
49 |
ENDIF(NOT BUILD_ENGINE_LIBRARY) |
a6b4f351d400
now engine can be optionally built as library, there's an example wrapper of how to use it
koda
parents:
3407
diff
changeset
|
50 |
|
2641 | 51 |
|
2015 | 52 |
if(APPLE) |
4336 | 53 |
set(CMAKE_FIND_FRAMEWORK "FIRST") |
3697 | 54 |
|
4336 | 55 |
#paths for creating the bundle |
56 |
set(bundle_name Hedgewars.app) |
|
57 |
set(CMAKE_INSTALL_PREFIX ${bundle_name}/Contents/MacOS/) |
|
58 |
set(DATA_INSTALL_DIR "../Resources/") |
|
59 |
set(target_dir ".") |
|
3697 | 60 |
|
4336 | 61 |
#what system are we building for |
62 |
set(minimum_macosx $ENV{MACOSX_DEPLOYMENT_TARGET}) |
|
3697 | 63 |
|
4336 | 64 |
#detect on which system are we |
65 |
EXEC_PROGRAM("/usr/bin/sw_vers" OUTPUT_VARIABLE MACOSX_VERSION_TMP) |
|
66 |
STRING(REGEX MATCH "[0-9]+\\.[0-9]+\\.[0-9]+" MACOSX_VERSION_TMP "${MACOSX_VERSION_TMP}") |
|
67 |
STRING(REGEX REPLACE "([0-9]+.[0-9]+).[0-9]+" "\\1" current_macosx_version ${MACOSX_VERSION_TMP}) |
|
2641 | 68 |
|
4336 | 69 |
if(NOT minimum_macosx) |
70 |
#if nothing is set, we deploy only for the current system |
|
71 |
set(minimum_macosx ${current_macosx_version}) |
|
72 |
endif() |
|
2641 | 73 |
|
4336 | 74 |
if (minimum_macosx LESS "10.4") |
75 |
set(FATAL "Hedgewars is not supported for pre-10.4 systems") |
|
76 |
endif() |
|
2929 | 77 |
|
4336 | 78 |
set(CMAKE_OSX_ARCHITECTURES "i386;ppc7400") |
3199 | 79 |
|
2822 | 80 |
|
4336 | 81 |
#create universal binaries only when it's time to bundle the application, also build server |
82 |
IF(BUNDLE) |
|
83 |
set(WITH_SERVER true) |
|
84 |
if(NOT minimum_macosx MATCHES "10.6") |
|
85 |
set(CMAKE_C_COMPILER "gcc-4.0") |
|
86 |
set(CMAKE_CXX_COMPILER "g++-4.0") |
|
87 |
else() |
|
88 |
if(current_macosx_version MATCHES "10.6") |
|
89 |
set(CMAKE_OSX_ARCHITECTURES "x86_64") |
|
90 |
endif() |
|
91 |
endif() |
|
92 |
ELSE() |
|
93 |
if(current_macosx_version MATCHES "10.6") |
|
94 |
set(CMAKE_OSX_ARCHITECTURES "x86_64") |
|
95 |
endif() |
|
96 |
ENDIF() |
|
2641 | 97 |
|
4336 | 98 |
message(STATUS "Target system: Mac OS X ${minimum_macosx} ${CMAKE_OSX_ARCHITECTURES}") |
2641 | 99 |
|
4336 | 100 |
if(minimum_macosx MATCHES "10.4") |
101 |
set(CMAKE_OSX_SYSROOT "/Developer/SDKs/MacOSX10.4u.sdk/") |
|
102 |
if(current_macosx_version MATCHES "10.4") |
|
103 |
find_package(SDL_mixer REQUIRED) |
|
104 |
set(pascal_compiler_flags_cmn "-k-dylib_file @loader_path/Frameworks/smpeg.framework/Versions/A/smpeg:${SDLMIXER_LIBRARY}/Versions/A/Frameworks/smpeg.framework/Versions/A/smpeg" "-k-dylib_file @loader_path/Frameworks/mikmod.framework/Versions/A/mikmod:${SDLMIXER_LIBRARY}/Versions/A/Frameworks/mikmod.framework/Versions/A/mikmod" ${pascal_compiler_flags_cmn}) |
|
105 |
set(CMAKE_C_FLAGS "-dylib_file @loader_path/Frameworks/smpeg.framework/Versions/A/smpeg:${SDLMIXER_LIBRARY}/Versions/A/Frameworks/smpeg.framework/Versions/A/smpeg -dylib_file @loader_path/Frameworks/mikmod.framework/Versions/A/mikmod:${SDLMIXER_LIBRARY}/Versions/A/Frameworks/mikmod.framework/Versions/A/mikmod") |
|
106 |
endif() |
|
107 |
else() |
|
108 |
set(CMAKE_OSX_SYSROOT "/Developer/SDKs/MacOSX${minimum_macosx}.sdk/") |
|
109 |
endif() |
|
2641 | 110 |
|
4336 | 111 |
#1.set deployment target; 2.link with libsdlmain.a (when building an executable); 3.link with liblua.a (which requires readline) |
112 |
set(pascal_compiler_flags_cmn "-k-macosx_version_min" "-k${minimum_macosx}" "-XR${CMAKE_OSX_SYSROOT}" ${pascal_compiler_flags_cmn}) |
|
113 |
if(NOT BUILD_ENGINE_LIBRARY) |
|
114 |
set(pascal_compiler_flags_cmn "-k${CMAKE_BINARY_DIR}/bin/libSDLmain.a" ${pascal_compiler_flags_cmn}) |
|
115 |
endif() |
|
116 |
set(pascal_compiler_flags_cmn "-k${CMAKE_BINARY_DIR}/bin/liblua.a" "-k-lreadline" ${pascal_compiler_flags_cmn}) |
|
2203
6bd39d75e0dd
-Added support for Release and Debug for CMAKE_BUILD_TYPE
koda
parents:
2200
diff
changeset
|
117 |
else(APPLE) |
4336 | 118 |
set(target_dir "bin") |
2015 | 119 |
endif(APPLE) |
120 |
||
2406 | 121 |
|
2606
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
122 |
#this snippet sets "Release" mode by default |
2641 | 123 |
#IF (NOT CMAKE_BUILD_TYPE) |
124 |
# SET(CMAKE_BUILD_TYPE "Release") |
|
125 |
#ENDIF (NOT CMAKE_BUILD_TYPE) |
|
2606
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
126 |
if (NOT CMAKE_BUILD_TYPE) |
4336 | 127 |
set (CMAKE_BUILD_TYPE RELEASE CACHE STRING "Choose the type of build, options are: None Debug Release." FORCE) |
2606
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
128 |
endif (NOT CMAKE_BUILD_TYPE) |
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
129 |
|
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
130 |
if(CMAKE_BUILD_TYPE MATCHES RELEASE OR CMAKE_BUILD_TYPE MATCHES "Release") |
4336 | 131 |
message(STATUS "Building Release") |
132 |
set(Optz true) |
|
2406 | 133 |
else() |
4336 | 134 |
message(STATUS "Building Debug") |
135 |
#set(CMAKE_VERBOSE_MAKEFILE true) |
|
136 |
set(Optz false) |
|
2406 | 137 |
endif() |
138 |
||
139 |
||
2606
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
140 |
#set default flags values for all the project |
3338
dee9beba85cc
patch by raptor (polished by me) to allow tiger/xcode24 compilation
koda
parents:
3306
diff
changeset
|
141 |
set(CMAKE_C_FLAGS "-pipe ${CMAKE_C_FLAGS}") |
dee9beba85cc
patch by raptor (polished by me) to allow tiger/xcode24 compilation
koda
parents:
3306
diff
changeset
|
142 |
set(CMAKE_C_FLAGS_RELEASE "-w -O2 -fomit-frame-pointer ${CMAKE_C_FLAGS_RELEASE}") |
dee9beba85cc
patch by raptor (polished by me) to allow tiger/xcode24 compilation
koda
parents:
3306
diff
changeset
|
143 |
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
|
144 |
set(CMAKE_CXX_FLAGS ${CMAKE_C_FLAGS}) |
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
145 |
set(CMAKE_CXX_FLAGS_RELEASE ${CMAKE_C_FLAGS_RELEASE}) |
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
146 |
set(CMAKE_CXX_FLAGS_DEBUG ${CMAKE_C_FLAGS_DEBUG}) |
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
147 |
|
3407 | 148 |
set(pascal_compiler_flags_cmn "-B" "-FE../bin" "-Cs2000000" "-vewn" ${pascal_compiler_flags_cmn}) |
2606
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
149 |
|
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
150 |
if(Optz) |
3677 | 151 |
# set(pascal_compiler_flags_cmn "-O3" "-OpPENTIUM4" "-CfSSE3" "-Xs" "-Si" ${pascal_compiler_flags_cmn}) |
4336 | 152 |
set(pascal_compiler_flags_cmn "-O2" "-Xs" "-Si" ${pascal_compiler_flags_cmn}) |
153 |
set(haskell_compiler_flags_cmn "-O2" "-w") |
|
2606
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
154 |
else(Optz) |
4336 | 155 |
set(pascal_compiler_flags_cmn "-O-" "-g" "-gh" "-gl" "-dDEBUGFILE" ${pascal_compiler_flags_cmn}) |
156 |
set(haskell_compiler_flags_cmn "-Wall" "-debug" "-dcore-lint") |
|
2606
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
157 |
endif(Optz) |
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
158 |
|
ed687a8d081f
updated build files for macosx and optimization system
koda
parents:
2573
diff
changeset
|
159 |
|
266 | 160 |
if(DEFINED DATA_INSTALL_DIR) |
4336 | 161 |
set(SHAREPATH ${DATA_INSTALL_DIR}/hedgewars/) |
2652 | 162 |
else() |
4336 | 163 |
set(SHAREPATH share/hedgewars/) |
2652 | 164 |
endif() |
220 | 165 |
set(EXECUTABLE_OUTPUT_PATH ${PROJECT_BINARY_DIR}/bin) |
184 | 166 |
|
907 | 167 |
set(HEDGEWARS_VERSION "${CPACK_PACKAGE_VERSION_MAJOR}.${CPACK_PACKAGE_VERSION_MINOR}.${CPACK_PACKAGE_VERSION_PATCH}") |
4336 | 168 |
set(HEDGEWARS_PROTO_VER 34) |
271 | 169 |
|
1415
6fbfee0e113a
Allow build without net game server: introduce -DWITH_SERVER configuration parameter
unc0rr
parents:
1370
diff
changeset
|
170 |
if(WITH_SERVER) |
4336 | 171 |
message(STATUS "Server is going to be built! Make sure you have GHC installed") |
172 |
set(HAVE_NETSERVER true) |
|
173 |
add_subdirectory(gameServer) |
|
1415
6fbfee0e113a
Allow build without net game server: introduce -DWITH_SERVER configuration parameter
unc0rr
parents:
1370
diff
changeset
|
174 |
else(WITH_SERVER) |
4336 | 175 |
set(HAVE_NETSERVER false) |
1415
6fbfee0e113a
Allow build without net game server: introduce -DWITH_SERVER configuration parameter
unc0rr
parents:
1370
diff
changeset
|
176 |
endif(WITH_SERVER) |
6fbfee0e113a
Allow build without net game server: introduce -DWITH_SERVER configuration parameter
unc0rr
parents:
1370
diff
changeset
|
177 |
|
3525 | 178 |
add_subdirectory(misc/liblua) |
184 | 179 |
add_subdirectory(hedgewars) |
3539 | 180 |
#add_subdirectory(misc/libopenalbridge) |
3510
23145a950eae
Update repository checking code to reflect our recent Mercurial switch
koda
parents:
3495
diff
changeset
|
181 |
if(NOT BUILD_ENGINE_LIBRARY) |
4336 | 182 |
add_subdirectory(bin) |
183 |
add_subdirectory(QTfrontend) |
|
184 |
add_subdirectory(share) |
|
185 |
add_subdirectory(tools) |
|
3510
23145a950eae
Update repository checking code to reflect our recent Mercurial switch
koda
parents:
3495
diff
changeset
|
186 |
endif() |
2203
6bd39d75e0dd
-Added support for Release and Debug for CMAKE_BUILD_TYPE
koda
parents:
2200
diff
changeset
|
187 |
|
584
f381705f1aeb
Some stuff to get good results from make 'package_source'
unc0rr
parents:
546
diff
changeset
|
188 |
# CPack vars |
f381705f1aeb
Some stuff to get good results from make 'package_source'
unc0rr
parents:
546
diff
changeset
|
189 |
|
3338
dee9beba85cc
patch by raptor (polished by me) to allow tiger/xcode24 compilation
koda
parents:
3306
diff
changeset
|
190 |
set(CPACK_PACKAGE_DESCRIPTION_SUMMARY "Hedgewars, a free turn-based strategy") |
2827 | 191 |
set(CPACK_PACKAGE_VENDOR "Hedgewars Project") |
907 | 192 |
set(CPACK_PACKAGE_FILE_NAME "hedgewars-${HEDGEWARS_VERSION}") |
193 |
set(CPACK_SOURCE_PACKAGE_FILE_NAME "hedgewars-src-${HEDGEWARS_VERSION}") |
|
1459 | 194 |
set(CPACK_SOURCE_GENERATOR "TBZ2") |
1173
70b0acd4548c
Revert accidental nsis installer generator regression
unc0rr
parents:
1159
diff
changeset
|
195 |
set(CPACK_PACKAGE_EXECUTABLES "hedgewars" "hedgewars") |
458 | 196 |
set(CPACK_RESOURCE_FILE_LICENSE "${CMAKE_CURRENT_SOURCE_DIR}/COPYING") |
907 | 197 |
set(CPACK_PACKAGE_INSTALL_DIRECTORY "Hedgewars ${HEDGEWARS_VERSION}") |
184 | 198 |
|
199 |
if(WIN32 AND NOT UNIX) |
|
4336 | 200 |
set(CPACK_NSIS_DISPLAY_NAME "Hedgewars") |
201 |
set(CPACK_NSIS_HELP_LINK "http://www.hedgewars.org/") |
|
202 |
set(CPACK_NSIS_URL_INFO_ABOUT "http://www.hedgewars.org/") |
|
203 |
set(CPACK_NSIS_CONTACT "unC0Rr@gmail.com") |
|
204 |
set(CPACK_NSIS_MODIFY_PATH OFF) |
|
205 |
set(CPACK_GENERATOR "ZIP;NSIS") |
|
206 |
set(CPACK_PACKAGE_INSTALL_REGISTRY_KEY "hedgewars") |
|
184 | 207 |
else(WIN32 AND NOT UNIX) |
4336 | 208 |
set(CPACK_STRIP_FILES "bin/hedgewars;bin/hwengine") |
184 | 209 |
endif(WIN32 AND NOT UNIX) |
210 |
||
584
f381705f1aeb
Some stuff to get good results from make 'package_source'
unc0rr
parents:
546
diff
changeset
|
211 |
set(CPACK_SOURCE_IGNORE_FILES |
4336 | 212 |
"~" |
213 |
"\\\\.hg" |
|
214 |
"\\\\.svn" |
|
215 |
"\\\\.exe$" |
|
216 |
"\\\\.a$" |
|
217 |
"\\\\.dll$" |
|
218 |
"\\\\.xcf$" |
|
219 |
"\\\\.cxx$" |
|
220 |
"\\\\.db$" |
|
221 |
"\\\\.dof$" |
|
222 |
"\\\\.layout$" |
|
223 |
"\\\\.zip$" |
|
224 |
"\\\\.gz$" |
|
225 |
"\\\\.bz2$" |
|
226 |
"\\\\.tmp$" |
|
227 |
"\\\\.core$" |
|
228 |
"\\\\.sh$" |
|
229 |
"\\\\.sifz$" |
|
230 |
"\\\\.svg$" |
|
231 |
"\\\\.svgz$" |
|
232 |
"\\\\.ppu$" |
|
233 |
"\\\\.psd$" |
|
234 |
"\\\\.o$" |
|
235 |
"Makefile" |
|
236 |
"Doxyfile" |
|
237 |
"CMakeFiles" |
|
238 |
"debug" |
|
239 |
"release$" |
|
240 |
"Debug$" |
|
241 |
"Release$" |
|
242 |
"proto.inc$" |
|
243 |
"hwconsts.cpp$" |
|
244 |
"playlist.inc$" |
|
245 |
"CPack" |
|
246 |
"cmake_install.cmake$" |
|
247 |
"config.inc$" |
|
248 |
"hwengine.desktop$" |
|
4276
3ba228dcc6d7
Ban .svg, .psd, .sifz from being present in 'make package_source' output
unc0rr
parents:
4274
diff
changeset
|
249 |
# "^${CMAKE_CURRENT_SOURCE_DIR}/misc/libopenalbridge" |
4336 | 250 |
"^${CMAKE_CURRENT_SOURCE_DIR}/project_files/HedgewarsMobile/" |
251 |
"^${CMAKE_CURRENT_SOURCE_DIR}/bin/[a-z]" |
|
252 |
"^${CMAKE_CURRENT_SOURCE_DIR}/tools/templates" |
|
253 |
"^${CMAKE_CURRENT_SOURCE_DIR}/doc" |
|
254 |
"^${CMAKE_CURRENT_SOURCE_DIR}/templates" |
|
255 |
"^${CMAKE_CURRENT_SOURCE_DIR}/Graphics" |
|
256 |
"^${CMAKE_CURRENT_SOURCE_DIR}/realtest" |
|
257 |
"^${CMAKE_CURRENT_SOURCE_DIR}/tmp" |
|
258 |
"^${CMAKE_CURRENT_SOURCE_DIR}/utils" |
|
259 |
"^${CMAKE_CURRENT_SOURCE_DIR}/share/hedgewars/Data/Maps/test" |
|
260 |
"^${CMAKE_CURRENT_SOURCE_DIR}/share/hedgewars/Data/Themes/ethereal" |
|
261 |
"^${CMAKE_CURRENT_SOURCE_DIR}/install_manifest.txt" |
|
262 |
"^${CMAKE_CURRENT_SOURCE_DIR}/CMakeCache.txt" |
|
263 |
"^${CMAKE_CURRENT_SOURCE_DIR}/hedgewars\\\\." |
|
584
f381705f1aeb
Some stuff to get good results from make 'package_source'
unc0rr
parents:
546
diff
changeset
|
264 |
) |
f381705f1aeb
Some stuff to get good results from make 'package_source'
unc0rr
parents:
546
diff
changeset
|
265 |
|
184 | 266 |
include(CPack) |