author | unc0rr |
Sat, 15 Aug 2009 09:34:31 +0000 | |
changeset 2312 | 3b59f1251ead |
parent 2261 | 57e99c908e7c |
child 2336 | 66c751f7a28e |
permissions | -rw-r--r-- |
555 | 1 |
# Configure for Qt4 |
1415
6fbfee0e113a
Allow build without net game server: introduce -DWITH_SERVER configuration parameter
unc0rr
parents:
1374
diff
changeset
|
2 |
set(QT_MIN_VERSION "4.4.0") |
260 | 3 |
|
502
bc178daca088
Fix build with CMake & gcc 4.1.2 on my system (treating #include <QtGui> as including directory)
unc0rr
parents:
495
diff
changeset
|
4 |
set(QT_USE_QTCORE TRUE) |
bc178daca088
Fix build with CMake & gcc 4.1.2 on my system (treating #include <QtGui> as including directory)
unc0rr
parents:
495
diff
changeset
|
5 |
set(QT_USE_QTGUI TRUE) |
494 | 6 |
set(QT_USE_QTNETWORK TRUE) |
7 |
set(QT_USE_QTSVG TRUE) |
|
495 | 8 |
set(QT_USE_QTXML TRUE) |
2012 | 9 |
# set(QT_USE_QTOPENGL TRUE) |
494 | 10 |
set(QT_USE_QTMAIN TRUE) |
11 |
||
184 | 12 |
find_package(Qt4 REQUIRED) |
1159 | 13 |
include(${QT_USE_FILE}) |
184 | 14 |
|
1878
b3b277d2b891
own md5 function, no qca2 dependancy (patch by nemo with Qt adaptation by me)
unc0rr
parents:
1843
diff
changeset
|
15 |
#find_package(QCA2 REQUIRED) |
b3b277d2b891
own md5 function, no qca2 dependancy (patch by nemo with Qt adaptation by me)
unc0rr
parents:
1843
diff
changeset
|
16 |
#include_directories(${QCA2_INCLUDE_DIR}) |
1843 | 17 |
|
555 | 18 |
# Configure for SDL |
19 |
find_package(SDL REQUIRED) |
|
20 |
||
2239
d7b5c65f7544
move C and C++ optimization flags in the main CMakeLists.txt
koda
parents:
2230
diff
changeset
|
21 |
include_directories(.) |
707 | 22 |
include_directories(${SDL_INCLUDE_DIR}) |
1159 | 23 |
if(UNIX) |
24 |
include_directories("/usr/local/include") # HACK: in freebsd cannot find iconv.h included via SDL.h |
|
25 |
endif(UNIX) |
|
555 | 26 |
|
1904 | 27 |
|
184 | 28 |
if(WIN32 AND NOT UNIX) |
29 |
set(HEDGEWARS_BINDIR ".") |
|
267 | 30 |
set(HEDGEWARS_DATADIR "../share/") |
184 | 31 |
else(WIN32 AND NOT UNIX) |
32 |
set(HEDGEWARS_BINDIR ${CMAKE_INSTALL_PREFIX}) |
|
266 | 33 |
if(DEFINED DATA_INSTALL_DIR) |
265 | 34 |
set(HEDGEWARS_DATADIR ${DATA_INSTALL_DIR}) |
266 | 35 |
else(DEFINED DATA_INSTALL_DIR) |
265 | 36 |
set(HEDGEWARS_DATADIR ${CMAKE_INSTALL_PREFIX}/share/) |
266 | 37 |
endif(DEFINED DATA_INSTALL_DIR) |
184 | 38 |
endif(WIN32 AND NOT UNIX) |
39 |
||
2239
d7b5c65f7544
move C and C++ optimization flags in the main CMakeLists.txt
koda
parents:
2230
diff
changeset
|
40 |
|
2219
07f5345ecae7
additional variable (BUNDLE) to make a standalone Mac application
koda
parents:
2218
diff
changeset
|
41 |
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/hwconsts.cpp.in ${CMAKE_CURRENT_BINARY_DIR}/hwconsts.cpp) |
184 | 42 |
|
781 | 43 |
set(hwfr_src |
184 | 44 |
game.cpp |
45 |
main.cpp |
|
781 | 46 |
hwform.cpp |
184 | 47 |
team.cpp |
1907 | 48 |
namegen.cpp |
184 | 49 |
teamselect.cpp |
50 |
teamselhelper.cpp |
|
51 |
frameTeam.cpp |
|
52 |
vertScrollArea.cpp |
|
53 |
gameuiconfig.cpp |
|
54 |
ui_hwform.cpp |
|
55 |
gamecfgwidget.cpp |
|
56 |
pages.cpp |
|
57 |
SquareLabel.cpp |
|
1236 | 58 |
hats.cpp |
184 | 59 |
hedgehogerWidget.cpp |
60 |
hwmap.cpp |
|
61 |
mapContainer.cpp |
|
187 | 62 |
tcpBase.cpp |
239 | 63 |
about.cpp |
297 | 64 |
proto.cpp |
314 | 65 |
fpsedit.cpp |
66 |
netserver.cpp |
|
412 | 67 |
newnetclient.cpp |
68 |
netudpserver.cpp |
|
461 | 69 |
netudpwidget.cpp |
633 | 70 |
netregister.cpp |
632
5e09ae25729f
Half implement possibility for different backends of servers list
unc0rr
parents:
625
diff
changeset
|
71 |
netserverslist.cpp |
539
6a9bf1852bbc
Ability to choose which info is shown above hedgehogs
unc0rr
parents:
502
diff
changeset
|
72 |
chatwidget.cpp |
555 | 73 |
binds.cpp |
579 | 74 |
SDLs.cpp |
75 |
playrecordpage.cpp |
|
781 | 76 |
${CMAKE_CURRENT_BINARY_DIR}/hwconsts.cpp |
612
333d095319de
abstract class for items container (hedgehogs num, bullets, etc.)
displacer
parents:
597
diff
changeset
|
77 |
selectWeapon.cpp |
880
f9efe907828f
Add win32 resource compilation under mingw (used sim-im srcs as example)
unc0rr
parents:
781
diff
changeset
|
78 |
itemNum.cpp |
653
4f44fc06ca45
Class to ask host/port to connect to ('Specify' button on PageNet)
unc0rr
parents:
633
diff
changeset
|
79 |
input_ip.cpp |
1192 | 80 |
igbox.cpp |
1621 | 81 |
weaponItem.cpp |
82 |
statsPage.cpp |
|
1878
b3b277d2b891
own md5 function, no qca2 dependancy (patch by nemo with Qt adaptation by me)
unc0rr
parents:
1843
diff
changeset
|
83 |
misc.cpp |
1881 | 84 |
ammoSchemeModel.cpp |
1932 | 85 |
togglebutton.cpp |
2012 | 86 |
bgwidget.cpp |
1621 | 87 |
) |
184 | 88 |
|
880
f9efe907828f
Add win32 resource compilation under mingw (used sim-im srcs as example)
unc0rr
parents:
781
diff
changeset
|
89 |
if(MINGW) |
f9efe907828f
Add win32 resource compilation under mingw (used sim-im srcs as example)
unc0rr
parents:
781
diff
changeset
|
90 |
# resource compilation for mingw |
f9efe907828f
Add win32 resource compilation under mingw (used sim-im srcs as example)
unc0rr
parents:
781
diff
changeset
|
91 |
add_custom_command(OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/hedgewars_rc.o |
1574 | 92 |
COMMAND windres -I ${CMAKE_CURRENT_SOURCE_DIR} |
1039 | 93 |
-i ${CMAKE_CURRENT_SOURCE_DIR}/hedgewars.rc |
880
f9efe907828f
Add win32 resource compilation under mingw (used sim-im srcs as example)
unc0rr
parents:
781
diff
changeset
|
94 |
-o ${CMAKE_CURRENT_BINARY_DIR}/hedgewars_rc.o) |
f9efe907828f
Add win32 resource compilation under mingw (used sim-im srcs as example)
unc0rr
parents:
781
diff
changeset
|
95 |
set(hwfr_src ${hwfr_src} ${CMAKE_CURRENT_BINARY_DIR}/hedgewars_rc.o) |
f9efe907828f
Add win32 resource compilation under mingw (used sim-im srcs as example)
unc0rr
parents:
781
diff
changeset
|
96 |
else(MINGW) |
1042 | 97 |
set(hwfr_src ${hwfr_src} hedgewars.rc) |
880
f9efe907828f
Add win32 resource compilation under mingw (used sim-im srcs as example)
unc0rr
parents:
781
diff
changeset
|
98 |
endif(MINGW) |
184 | 99 |
|
100 |
set(hwfr_moc_hdrs |
|
101 |
game.h |
|
1236 | 102 |
hats.h |
184 | 103 |
hwform.h |
104 |
teamselect.h |
|
105 |
teamselhelper.h |
|
106 |
frameTeam.h |
|
107 |
vertScrollArea.h |
|
108 |
gameuiconfig.h |
|
109 |
gamecfgwidget.h |
|
110 |
pages.h |
|
111 |
SquareLabel.h |
|
112 |
hedgehogerWidget.h |
|
113 |
hwmap.h |
|
114 |
mapContainer.h |
|
187 | 115 |
tcpBase.h |
208 | 116 |
about.h |
297 | 117 |
proto.h |
314 | 118 |
fpsedit.h |
119 |
netserver.h |
|
412 | 120 |
newnetclient.h |
121 |
netudpserver.h |
|
461 | 122 |
netudpwidget.h |
633 | 123 |
netregister.h |
632
5e09ae25729f
Half implement possibility for different backends of servers list
unc0rr
parents:
625
diff
changeset
|
124 |
netserverslist.h |
555 | 125 |
chatwidget.h |
579 | 126 |
SDLs.h |
597
ec5f057ab268
kdevelop project add, initial weapons scheme button
displacer
parents:
592
diff
changeset
|
127 |
playrecordpage.h |
612
333d095319de
abstract class for items container (hedgehogs num, bullets, etc.)
displacer
parents:
597
diff
changeset
|
128 |
selectWeapon.h |
880
f9efe907828f
Add win32 resource compilation under mingw (used sim-im srcs as example)
unc0rr
parents:
781
diff
changeset
|
129 |
itemNum.h |
653
4f44fc06ca45
Class to ask host/port to connect to ('Specify' button on PageNet)
unc0rr
parents:
633
diff
changeset
|
130 |
input_ip.h |
1192 | 131 |
igbox.h |
1621 | 132 |
weaponItem.h |
133 |
statsPage.h |
|
1878
b3b277d2b891
own md5 function, no qca2 dependancy (patch by nemo with Qt adaptation by me)
unc0rr
parents:
1843
diff
changeset
|
134 |
misc.h |
1881 | 135 |
ammoSchemeModel.h |
1932 | 136 |
togglebutton.h |
2012 | 137 |
bgwidget.h |
1621 | 138 |
) |
184 | 139 |
|
2261 | 140 |
if(APPLE) |
141 |
find_package(Sparkle REQUIRED) |
|
142 |
set(hwfr_src ${hwfr_src} AutoUpdater.cpp CocoaInitializer.mm SparkleAutoUpdater.mm) |
|
143 |
#set(hwfr_moc_hdrs ${hwfr_moc_hdrs} AutoUpdater.h CocoaInitializer.h SparkleAutoUpdater.h) |
|
144 |
endif(APPLE) |
|
145 |
||
477 | 146 |
set(hwfr_hdrs |
147 |
binds.h |
|
148 |
ui_hwform.h |
|
149 |
predefteams.h |
|
150 |
KB.h |
|
579 | 151 |
hwconsts.h |
477 | 152 |
) |
184 | 153 |
|
2218
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
154 |
set(hwfr_rez hedgewars.qrc) |
184 | 155 |
|
156 |
qt4_add_resources(hwfr_rez_src |
|
157 |
${hwfr_rez}) |
|
158 |
||
159 |
qt4_wrap_cpp(hwfr_moc_srcs |
|
160 |
${hwfr_moc_hdrs}) |
|
161 |
||
162 |
add_executable(hedgewars WIN32 |
|
163 |
${hwfr_src} |
|
164 |
${hwfr_moc_srcs} |
|
477 | 165 |
${hwfr_hdrs} |
184 | 166 |
${hwfr_rez_src}) |
2191 | 167 |
|
2218
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
168 |
|
555 | 169 |
set(HW_LINK_LIBS |
170 |
${QT_LIBRARIES} |
|
171 |
${SDL_LIBRARY} |
|
2200
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
172 |
openalbridge |
2191 | 173 |
) |
184 | 174 |
|
2230
d6963f72d21a
once again, trying to restore windows compatibility from nemo's experiments
koda
parents:
2229
diff
changeset
|
175 |
#openalbridge is linked statically in unix, dynamically in windows; for static we need to explicitly link dependencies -- if we ever change this remember that in windows library order counts |
d6963f72d21a
once again, trying to restore windows compatibility from nemo's experiments
koda
parents:
2229
diff
changeset
|
176 |
if(NOT WIN32 AND NOT APPLE) |
2200
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
177 |
set(HW_LINK_LIBS |
2230
d6963f72d21a
once again, trying to restore windows compatibility from nemo's experiments
koda
parents:
2229
diff
changeset
|
178 |
${HW_LINK_LIBS} |
2200
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
179 |
${OPENAL_LIBRARY} |
2230
d6963f72d21a
once again, trying to restore windows compatibility from nemo's experiments
koda
parents:
2229
diff
changeset
|
180 |
${OGG_LIBRARY} |
2229
081081a61a16
patch for loading sprites on two columns (helps embedded and lowpower machines). must deal with amGirder.png
koda
parents:
2219
diff
changeset
|
181 |
${VORBIS_LIBRARY} |
2218
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
182 |
${VORBISFILE_LIBRARY} |
2200
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
183 |
) |
2230
d6963f72d21a
once again, trying to restore windows compatibility from nemo's experiments
koda
parents:
2229
diff
changeset
|
184 |
endif() |
d6963f72d21a
once again, trying to restore windows compatibility from nemo's experiments
koda
parents:
2229
diff
changeset
|
185 |
#no vorbisfile required for MacOS X |
2218
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
186 |
if(APPLE) |
2200
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
187 |
set(HW_LINK_LIBS |
2218
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
188 |
${OPENAL_LIBRARY} |
2230
d6963f72d21a
once again, trying to restore windows compatibility from nemo's experiments
koda
parents:
2229
diff
changeset
|
189 |
${OGG_LIBRARY} |
2218
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
190 |
${VORBIS_LIBRARY} |
2200
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
191 |
${HW_LINK_LIBS} |
2261 | 192 |
${SPARKLE_LIBRARY} |
2200
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
193 |
) |
2218
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
194 |
endif(APPLE) |
2200
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
195 |
|
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
196 |
|
184 | 197 |
if(WIN32 AND NOT UNIX) |
555 | 198 |
if(NOT SDL_LIBRARY) |
199 |
set(HW_LINK_LIBS |
|
200 |
${HW_LINK_LIBS} |
|
201 |
SDL |
|
202 |
) |
|
203 |
endif(NOT SDL_LIBRARY) |
|
204 |
||
495 | 205 |
set(HW_LINK_LIBS |
206 |
${HW_LINK_LIBS} |
|
207 |
ole32 |
|
1043 | 208 |
oleaut32 |
495 | 209 |
winspool |
555 | 210 |
uuid |
211 |
) |
|
495 | 212 |
endif(WIN32 AND NOT UNIX) |
184 | 213 |
|
2218
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
214 |
|
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
215 |
target_link_libraries(hedgewars ${HW_LINK_LIBS}) |
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
216 |
|
495 | 217 |
|
2015 | 218 |
install(PROGRAMS "${EXECUTABLE_OUTPUT_PATH}/hedgewars${CMAKE_EXECUTABLE_SUFFIX}" DESTINATION ${target_dir}) |
2218
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
219 |