author | nemo |
Tue, 07 Jul 2009 01:36:56 +0000 | |
changeset 2234 | 17f7a5882aca |
parent 2230 | d6963f72d21a |
child 2239 | d7b5c65f7544 |
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 |
||
707 | 21 |
include_directories(${SDL_INCLUDE_DIR}) |
2191 | 22 |
|
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 |
|
27 |
# Done |
|
494 | 28 |
include_directories(.) |
184 | 29 |
|
2203
6bd39d75e0dd
-Added support for Release and Debug for CMAKE_BUILD_TYPE
koda
parents:
2200
diff
changeset
|
30 |
set(CMAKE_CXX_FLAGS "-Wall -pipe") |
6bd39d75e0dd
-Added support for Release and Debug for CMAKE_BUILD_TYPE
koda
parents:
2200
diff
changeset
|
31 |
set(CMAKE_CXX_FLAGS_RELEASE "-w -O2 -fomit-frame-pointer") |
6bd39d75e0dd
-Added support for Release and Debug for CMAKE_BUILD_TYPE
koda
parents:
2200
diff
changeset
|
32 |
set(CMAKE_CXX_FLAGS_DEBUG "-O0 -g") |
1904 | 33 |
|
184 | 34 |
if(WIN32 AND NOT UNIX) |
35 |
set(HEDGEWARS_BINDIR ".") |
|
267 | 36 |
set(HEDGEWARS_DATADIR "../share/") |
184 | 37 |
else(WIN32 AND NOT UNIX) |
38 |
set(HEDGEWARS_BINDIR ${CMAKE_INSTALL_PREFIX}) |
|
266 | 39 |
if(DEFINED DATA_INSTALL_DIR) |
265 | 40 |
set(HEDGEWARS_DATADIR ${DATA_INSTALL_DIR}) |
266 | 41 |
else(DEFINED DATA_INSTALL_DIR) |
265 | 42 |
set(HEDGEWARS_DATADIR ${CMAKE_INSTALL_PREFIX}/share/) |
266 | 43 |
endif(DEFINED DATA_INSTALL_DIR) |
184 | 44 |
endif(WIN32 AND NOT UNIX) |
45 |
||
2219
07f5345ecae7
additional variable (BUNDLE) to make a standalone Mac application
koda
parents:
2218
diff
changeset
|
46 |
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/hwconsts.cpp.in ${CMAKE_CURRENT_BINARY_DIR}/hwconsts.cpp) |
184 | 47 |
|
781 | 48 |
set(hwfr_src |
184 | 49 |
game.cpp |
50 |
main.cpp |
|
781 | 51 |
hwform.cpp |
184 | 52 |
team.cpp |
1907 | 53 |
namegen.cpp |
184 | 54 |
teamselect.cpp |
55 |
teamselhelper.cpp |
|
56 |
frameTeam.cpp |
|
57 |
vertScrollArea.cpp |
|
58 |
gameuiconfig.cpp |
|
59 |
ui_hwform.cpp |
|
60 |
gamecfgwidget.cpp |
|
61 |
pages.cpp |
|
62 |
SquareLabel.cpp |
|
1236 | 63 |
hats.cpp |
184 | 64 |
hedgehogerWidget.cpp |
65 |
hwmap.cpp |
|
66 |
mapContainer.cpp |
|
187 | 67 |
tcpBase.cpp |
239 | 68 |
about.cpp |
297 | 69 |
proto.cpp |
314 | 70 |
fpsedit.cpp |
71 |
netserver.cpp |
|
412 | 72 |
newnetclient.cpp |
73 |
netudpserver.cpp |
|
461 | 74 |
netudpwidget.cpp |
633 | 75 |
netregister.cpp |
632
5e09ae25729f
Half implement possibility for different backends of servers list
unc0rr
parents:
625
diff
changeset
|
76 |
netserverslist.cpp |
539
6a9bf1852bbc
Ability to choose which info is shown above hedgehogs
unc0rr
parents:
502
diff
changeset
|
77 |
chatwidget.cpp |
555 | 78 |
binds.cpp |
579 | 79 |
SDLs.cpp |
80 |
playrecordpage.cpp |
|
781 | 81 |
${CMAKE_CURRENT_BINARY_DIR}/hwconsts.cpp |
612
333d095319de
abstract class for items container (hedgehogs num, bullets, etc.)
displacer
parents:
597
diff
changeset
|
82 |
selectWeapon.cpp |
880
f9efe907828f
Add win32 resource compilation under mingw (used sim-im srcs as example)
unc0rr
parents:
781
diff
changeset
|
83 |
itemNum.cpp |
653
4f44fc06ca45
Class to ask host/port to connect to ('Specify' button on PageNet)
unc0rr
parents:
633
diff
changeset
|
84 |
input_ip.cpp |
1192 | 85 |
igbox.cpp |
1621 | 86 |
weaponItem.cpp |
87 |
statsPage.cpp |
|
1878
b3b277d2b891
own md5 function, no qca2 dependancy (patch by nemo with Qt adaptation by me)
unc0rr
parents:
1843
diff
changeset
|
88 |
misc.cpp |
1881 | 89 |
ammoSchemeModel.cpp |
1932 | 90 |
togglebutton.cpp |
2012 | 91 |
bgwidget.cpp |
1621 | 92 |
) |
184 | 93 |
|
880
f9efe907828f
Add win32 resource compilation under mingw (used sim-im srcs as example)
unc0rr
parents:
781
diff
changeset
|
94 |
if(MINGW) |
f9efe907828f
Add win32 resource compilation under mingw (used sim-im srcs as example)
unc0rr
parents:
781
diff
changeset
|
95 |
# resource compilation for mingw |
f9efe907828f
Add win32 resource compilation under mingw (used sim-im srcs as example)
unc0rr
parents:
781
diff
changeset
|
96 |
add_custom_command(OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/hedgewars_rc.o |
1574 | 97 |
COMMAND windres -I ${CMAKE_CURRENT_SOURCE_DIR} |
1039 | 98 |
-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
|
99 |
-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
|
100 |
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
|
101 |
else(MINGW) |
1042 | 102 |
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
|
103 |
endif(MINGW) |
184 | 104 |
|
105 |
set(hwfr_moc_hdrs |
|
106 |
game.h |
|
1236 | 107 |
hats.h |
184 | 108 |
hwform.h |
109 |
teamselect.h |
|
110 |
teamselhelper.h |
|
111 |
frameTeam.h |
|
112 |
vertScrollArea.h |
|
113 |
gameuiconfig.h |
|
114 |
gamecfgwidget.h |
|
115 |
pages.h |
|
116 |
SquareLabel.h |
|
117 |
hedgehogerWidget.h |
|
118 |
hwmap.h |
|
119 |
mapContainer.h |
|
187 | 120 |
tcpBase.h |
208 | 121 |
about.h |
297 | 122 |
proto.h |
314 | 123 |
fpsedit.h |
124 |
netserver.h |
|
412 | 125 |
newnetclient.h |
126 |
netudpserver.h |
|
461 | 127 |
netudpwidget.h |
633 | 128 |
netregister.h |
632
5e09ae25729f
Half implement possibility for different backends of servers list
unc0rr
parents:
625
diff
changeset
|
129 |
netserverslist.h |
555 | 130 |
chatwidget.h |
579 | 131 |
SDLs.h |
597
ec5f057ab268
kdevelop project add, initial weapons scheme button
displacer
parents:
592
diff
changeset
|
132 |
playrecordpage.h |
612
333d095319de
abstract class for items container (hedgehogs num, bullets, etc.)
displacer
parents:
597
diff
changeset
|
133 |
selectWeapon.h |
880
f9efe907828f
Add win32 resource compilation under mingw (used sim-im srcs as example)
unc0rr
parents:
781
diff
changeset
|
134 |
itemNum.h |
653
4f44fc06ca45
Class to ask host/port to connect to ('Specify' button on PageNet)
unc0rr
parents:
633
diff
changeset
|
135 |
input_ip.h |
1192 | 136 |
igbox.h |
1621 | 137 |
weaponItem.h |
138 |
statsPage.h |
|
1878
b3b277d2b891
own md5 function, no qca2 dependancy (patch by nemo with Qt adaptation by me)
unc0rr
parents:
1843
diff
changeset
|
139 |
misc.h |
1881 | 140 |
ammoSchemeModel.h |
1932 | 141 |
togglebutton.h |
2012 | 142 |
bgwidget.h |
1621 | 143 |
) |
184 | 144 |
|
477 | 145 |
set(hwfr_hdrs |
146 |
binds.h |
|
147 |
ui_hwform.h |
|
148 |
predefteams.h |
|
149 |
KB.h |
|
579 | 150 |
hwconsts.h |
477 | 151 |
) |
184 | 152 |
|
2218
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
153 |
set(hwfr_rez hedgewars.qrc) |
184 | 154 |
|
155 |
qt4_add_resources(hwfr_rez_src |
|
156 |
${hwfr_rez}) |
|
157 |
||
158 |
qt4_wrap_cpp(hwfr_moc_srcs |
|
159 |
${hwfr_moc_hdrs}) |
|
160 |
||
161 |
add_executable(hedgewars WIN32 |
|
162 |
${hwfr_src} |
|
163 |
${hwfr_moc_srcs} |
|
477 | 164 |
${hwfr_hdrs} |
184 | 165 |
${hwfr_rez_src}) |
2191 | 166 |
|
2218
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
167 |
|
555 | 168 |
set(HW_LINK_LIBS |
169 |
${QT_LIBRARIES} |
|
170 |
${SDL_LIBRARY} |
|
2200
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
171 |
openalbridge |
2191 | 172 |
) |
184 | 173 |
|
2230
d6963f72d21a
once again, trying to restore windows compatibility from nemo's experiments
koda
parents:
2229
diff
changeset
|
174 |
#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
|
175 |
if(NOT WIN32 AND NOT APPLE) |
2200
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
176 |
set(HW_LINK_LIBS |
2230
d6963f72d21a
once again, trying to restore windows compatibility from nemo's experiments
koda
parents:
2229
diff
changeset
|
177 |
${HW_LINK_LIBS} |
2200
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
178 |
${OPENAL_LIBRARY} |
2230
d6963f72d21a
once again, trying to restore windows compatibility from nemo's experiments
koda
parents:
2229
diff
changeset
|
179 |
${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
|
180 |
${VORBIS_LIBRARY} |
2218
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
181 |
${VORBISFILE_LIBRARY} |
2200
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
182 |
) |
2230
d6963f72d21a
once again, trying to restore windows compatibility from nemo's experiments
koda
parents:
2229
diff
changeset
|
183 |
endif() |
d6963f72d21a
once again, trying to restore windows compatibility from nemo's experiments
koda
parents:
2229
diff
changeset
|
184 |
#no vorbisfile required for MacOS X |
2218
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
185 |
if(APPLE) |
2200
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
186 |
set(HW_LINK_LIBS |
2218
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
187 |
${OPENAL_LIBRARY} |
2230
d6963f72d21a
once again, trying to restore windows compatibility from nemo's experiments
koda
parents:
2229
diff
changeset
|
188 |
${OGG_LIBRARY} |
2218
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
189 |
${VORBIS_LIBRARY} |
2200
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
190 |
${HW_LINK_LIBS} |
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
191 |
) |
2218
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
192 |
endif(APPLE) |
2200
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
193 |
|
8192be6e3aef
koda/Smaxx changes to openal for crossplatform building
nemo
parents:
2191
diff
changeset
|
194 |
|
184 | 195 |
if(WIN32 AND NOT UNIX) |
555 | 196 |
if(NOT SDL_LIBRARY) |
197 |
set(HW_LINK_LIBS |
|
198 |
${HW_LINK_LIBS} |
|
199 |
SDL |
|
200 |
) |
|
201 |
endif(NOT SDL_LIBRARY) |
|
202 |
||
495 | 203 |
set(HW_LINK_LIBS |
204 |
${HW_LINK_LIBS} |
|
205 |
ole32 |
|
1043 | 206 |
oleaut32 |
495 | 207 |
winspool |
555 | 208 |
uuid |
209 |
) |
|
495 | 210 |
endif(WIN32 AND NOT UNIX) |
184 | 211 |
|
2218
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
212 |
|
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
213 |
target_link_libraries(hedgewars ${HW_LINK_LIBS}) |
59a9bebc4988
-Smaxx' solution for compiling frontend with static libs in windows
koda
parents:
2212
diff
changeset
|
214 |
|
495 | 215 |
|
2015 | 216 |
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
|
217 |