1 | dnl configure script for Lol Engine |
---|
2 | |
---|
3 | AC_INIT(lolengine, 0.0) |
---|
4 | AC_PREREQ(2.50) |
---|
5 | AC_CONFIG_AUX_DIR(.auto) |
---|
6 | AC_CANONICAL_SYSTEM |
---|
7 | AM_INIT_AUTOMAKE([subdir-objects no-define tar-ustar silent-rules]) |
---|
8 | dnl AM_MAINTAINER_MODE |
---|
9 | |
---|
10 | dnl Versioning of the separate software we ship |
---|
11 | LOLUNIT_VERSION=0.1 |
---|
12 | AC_SUBST(LOLUNIT_VERSION) |
---|
13 | LOLREMEZ_VERSION=0.2 |
---|
14 | AC_SUBST(LOLREMEZ_VERSION) |
---|
15 | |
---|
16 | AM_CONFIG_HEADER(config.h) |
---|
17 | |
---|
18 | AM_PROG_CC_C_O |
---|
19 | AC_PROG_CPP |
---|
20 | AC_PROG_CXX |
---|
21 | AC_PROG_CXXCPP |
---|
22 | AC_PROG_RANLIB |
---|
23 | |
---|
24 | AC_LIBTOOL_WIN32_DLL |
---|
25 | AM_PROG_LIBTOOL |
---|
26 | AC_LIBTOOL_CXX |
---|
27 | |
---|
28 | AC_C_CONST |
---|
29 | AC_C_INLINE |
---|
30 | |
---|
31 | dnl Ensure an error is thrown if pkg-config M4 files are not found. |
---|
32 | m4_pattern_allow([^PKG_CONFIG_LIBDIR$]) |
---|
33 | m4_pattern_forbid([^PKG_CHECK_MODULES$]) |
---|
34 | m4_pattern_forbid([^PKG_PROG_PKG_CONFIG$]) |
---|
35 | |
---|
36 | dnl Do not use PKG_CONFIG_LIBDIR when cross-compiling. |
---|
37 | if test "${build}" != "${host}" -a "${PKG_CONFIG_LIBDIR}" = ""; then |
---|
38 | export PKG_CONFIG_LIBDIR=/dev/null |
---|
39 | fi |
---|
40 | |
---|
41 | dnl AC_PROG_EGREP only exists in autoconf 2.54+, so we use AC_EGREP_CPP right |
---|
42 | dnl now otherwise it might be set in an obscure if statement. Same thing for |
---|
43 | dnl PKG_PROG_PKG_CONFIG which needs to be called first. |
---|
44 | AC_EGREP_CPP(yes, foo) |
---|
45 | PKG_PROG_PKG_CONFIG() |
---|
46 | |
---|
47 | AM_CONDITIONAL(USE_GLEW, test "${ac_cv_my_have_glew}" != "no") |
---|
48 | dnl conditional builds |
---|
49 | AC_ARG_ENABLE(debug, |
---|
50 | [ --enable-debug build debug versions of the game (default no)]) |
---|
51 | AC_ARG_ENABLE(release, |
---|
52 | [ --enable-release build final release of the game (default no)]) |
---|
53 | AC_ARG_ENABLE(experimental, |
---|
54 | [ --enable-experimental experimental build (default no)]) |
---|
55 | |
---|
56 | AC_CHECK_HEADERS(stdio.h stdarg.h inttypes.h endian.h stdint.h getopt.h) |
---|
57 | AC_CHECK_HEADERS(fastmath.h pthread.h libutil.h util.h pty.h glob.h) |
---|
58 | AC_CHECK_HEADERS(sys/ioctl.h sys/ptrace.h sys/stat.h sys/syscall.h sys/user.h) |
---|
59 | AC_CHECK_HEADERS(sys/wait.h) |
---|
60 | AC_CHECK_HEADERS(linux/kdev_t.h linux/major.h) |
---|
61 | AC_CHECK_HEADERS(security/pam_appl.h security/pam_misc.h) |
---|
62 | AC_CHECK_HEADERS(pam/pam_appl.h pam/pam_misc.h) |
---|
63 | |
---|
64 | if test "${enable_debug}" = "yes"; then |
---|
65 | AC_DEFINE(LOL_DEBUG, 1, Define to 1 to activate debug) |
---|
66 | OPT="-O" |
---|
67 | else |
---|
68 | OPT="-O3 -ffast-math -fno-strength-reduce -fomit-frame-pointer" |
---|
69 | fi |
---|
70 | |
---|
71 | if test "${enable_release}" = "yes"; then |
---|
72 | AC_DEFINE(LOL_RELEASE, 1, Define to 1 to activate final release) |
---|
73 | REL="" |
---|
74 | else |
---|
75 | REL="-g" |
---|
76 | fi |
---|
77 | |
---|
78 | if test "${enable_experimental}" = "yes"; then |
---|
79 | AC_DEFINE(LOL_EXPERIMENTAL, 1, Define to 1 to activate experimental build) |
---|
80 | fi |
---|
81 | |
---|
82 | dnl No exceptions |
---|
83 | CXXFLAGS="${CXXFLAGS} -fno-exceptions -fno-rtti" |
---|
84 | dnl Optimizations |
---|
85 | CXXFLAGS="${CXXFLAGS} ${REL} ${OPT}" |
---|
86 | dnl Code qui fait des warnings == code de porc == deux baffes dans ta gueule |
---|
87 | CXXFLAGS="${CXXFLAGS} -Wall -Wextra -Wpointer-arith -Wcast-align -Wcast-qual -Wshadow -Wsign-compare" |
---|
88 | |
---|
89 | AC_CHECK_LIB(m, sin, MATH_LIBS="${MATH_LIBS} -lm") |
---|
90 | AC_CHECK_LIB(pthread, main, LIBS="$LIBS -lpthread") |
---|
91 | AC_CHECK_LIB(util, forkpty, UTIL_LIBS="${UTIL_LIBS} -lutil") |
---|
92 | |
---|
93 | dnl Are we on the PS3? |
---|
94 | ac_cv_my_have_ps3="no" |
---|
95 | AC_CHECK_LIB(sysmodule_stub, cellSysmoduleLoadModule, |
---|
96 | [ac_cv_my_have_ps3="yes" |
---|
97 | LOL_LIBS="${LOL_LIBS} -lsysmodule_stub -lsysutil_stub -lresc_stub" |
---|
98 | dnl For PSGL |
---|
99 | AC_DEFINE(HAVE_GLES_2X, 1, Define to 1 if GLES 2.x is available) # FIXME: hack |
---|
100 | GL_LIBS="${GL_LIBS} -lPSGL -lgcm_cmd -lgcm_sys_stub" |
---|
101 | dnl This is the old way |
---|
102 | if test "x${CELLSDK}" != x -a "x${CELLSDK}" = x; then |
---|
103 | CELL_SDK="${CELLSDK}" |
---|
104 | fi |
---|
105 | if test "x${enable_debug}" = xyes; then |
---|
106 | GL_LIBS="${GL_LIBS} -L${CELL_SDK}/target/ppu/lib/PSGL/RSX/debug" |
---|
107 | elif test "x${enable_release}" = xyes; then |
---|
108 | GL_LIBS="${GL_LIBS} -L${CELL_SDK}/target/ppu/lib/PSGL/RSX/ultra-opt" |
---|
109 | else |
---|
110 | GL_LIBS="${GL_LIBS} -L${CELL_SDK}/target/ppu/lib/PSGL/RSX/opt" |
---|
111 | fi |
---|
112 | dnl For the runtime Cg compiler |
---|
113 | GL_LIBS="${GL_LIBS} -lcgc -lPSGLcgc" |
---|
114 | dnl For the PNG decoder |
---|
115 | LOL_LIBS="${LOL_LIBS} -lpngdec_stub" |
---|
116 | dnl For the pad library |
---|
117 | LOL_LIBS="${LOL_LIBS} -lio_stub -lusbd_stub -lpadfilter" |
---|
118 | dnl Disable this warning, it's too verbose with vector.h |
---|
119 | CXXFLAGS="${CXXFLAGS} -Wno-sign-compare" |
---|
120 | AC_PATH_PROG(MAKE_FSELF, make_fself, no)], |
---|
121 | [MAKE_FSELF=no]) |
---|
122 | AM_CONDITIONAL(USE_MAKE_FSELF, test "${MAKE_FSELF}" != "no") |
---|
123 | AM_CONDITIONAL(USE_PS3, test "${ac_cv_my_have_ps3}" != "no") |
---|
124 | |
---|
125 | |
---|
126 | dnl Are we building using MinGW? |
---|
127 | LIBS_save="$LIBS" |
---|
128 | LIBS="$LIBS -mwindows -mwin32" |
---|
129 | AC_MSG_CHECKING(for -mwindows -mwin32) |
---|
130 | AC_TRY_LINK([], [], |
---|
131 | [AC_MSG_RESULT(yes) |
---|
132 | CXXFLAGS="${CXXFLAGS} -mwindows -mwin32" |
---|
133 | LOL_LIBS="${LOL_LIBS} -uWinMain -u_WinMain@16"], |
---|
134 | [AC_MSG_RESULT(no)]) |
---|
135 | LIBS="$LIBS_save" |
---|
136 | |
---|
137 | |
---|
138 | dnl Are we on the Xbox 360? |
---|
139 | dnl Answer: NO! we don't know how to build for it anyway |
---|
140 | AM_CONDITIONAL(USE_X360, false) |
---|
141 | |
---|
142 | |
---|
143 | dnl Are we on a Direct3D 9 platform? |
---|
144 | #ac_cv_my_have_d3d9="no" |
---|
145 | #AC_CHECK_HEADERS(d3d9.h, [ac_cv_my_have_d3d9="yes"]) |
---|
146 | #if test "${ac_cv_my_have_d3d9}" != "no"; then |
---|
147 | # D3D_LIBS="${D3D_LIBS} -ld3d9 -ld3dx9 -lxinput" |
---|
148 | # AC_DEFINE(USE_D3D9, 1, Define to 1 to use DirectX 9) |
---|
149 | #fi |
---|
150 | #AM_CONDITIONAL(USE_D3D9, test "${ac_cv_my_have_d3d9}" != "no") |
---|
151 | |
---|
152 | |
---|
153 | dnl Find which version of OpenGL to use |
---|
154 | ac_cv_my_have_gl="no" |
---|
155 | ac_cv_my_stop_looking_for_gl="no" |
---|
156 | |
---|
157 | if test "x${ac_cv_my_stop_looking_for_gl}" = "xno"; then |
---|
158 | LIBS_save="$LIBS" |
---|
159 | LIBS="$LIBS -Wl,-framework -Wl,OpenGL" |
---|
160 | AC_MSG_CHECKING(for -framework OpenGL) |
---|
161 | AC_TRY_LINK([], [], |
---|
162 | [AC_MSG_RESULT(yes) |
---|
163 | GL_LIBS="${GL_LIBS} -framework OpenGL" |
---|
164 | CXXFLAGS="${CXXFLAGS} -ObjC++"], |
---|
165 | [AC_MSG_RESULT(no)]) |
---|
166 | LIBS="$LIBS_save" |
---|
167 | fi |
---|
168 | |
---|
169 | dnl Use the Raspberry Pi libraries? |
---|
170 | if test "x${ac_cv_my_stop_looking_for_gl}" = "xno"; then |
---|
171 | AC_CHECK_HEADERS(bcm_host.h, |
---|
172 | [AC_CHECK_LIB(vcos, main, |
---|
173 | [ac_cv_my_have_gl="yes" |
---|
174 | ac_cv_my_stop_looking_for_gl="yes" |
---|
175 | AC_DEFINE(HAVE_GLES_2X, 1, Define to 1 if GLES 2.x is available) |
---|
176 | dnl FIXME: -lEGL does not belong here but the configure test fails |
---|
177 | dnl when cross-compiling, so we add it manually here. |
---|
178 | GL_LIBS="${GL_LIBS} -lGLESv2 -lEGL -lvcos -lvchiq_arm -lbcm_host"])]) |
---|
179 | fi |
---|
180 | |
---|
181 | dnl Use the PS3 PSGL? |
---|
182 | if test "x${ac_cv_my_stop_looking_for_gl}" = "xno"; then |
---|
183 | AC_CHECK_HEADERS(PSGL/psgl.h, |
---|
184 | [ac_cv_my_have_gl="yes" |
---|
185 | ac_cv_my_stop_looking_for_gl="yes"]) |
---|
186 | fi |
---|
187 | |
---|
188 | if test "x${ac_cv_my_stop_looking_for_gl}" = "xno"; then |
---|
189 | PKG_CHECK_MODULES(GLES2, glesv2, |
---|
190 | [ac_cv_my_have_gl="yes" |
---|
191 | AC_DEFINE(HAVE_GLES_2X, 1, Define to 1 if GLES 2.x is available) |
---|
192 | GL_CFLAGS="${GL_CFLAGS} ${GLES2_CFLAGS}" |
---|
193 | GL_LIBS="${GL_LIBS} ${GLES2_LIBS}"], |
---|
194 | [:]) |
---|
195 | fi |
---|
196 | |
---|
197 | if test "x${ac_cv_my_stop_looking_for_gl}" = "xno"; then |
---|
198 | AC_CHECK_HEADER(GLES2/gl2.h, |
---|
199 | [ac_cv_my_have_gl="yes" |
---|
200 | AC_DEFINE(HAVE_GLES_2X, 1, Define to 1 if GLES 2.x is available) |
---|
201 | AC_CHECK_LIB(GLESv2, glEnable, |
---|
202 | [GL_LIBS="${GL_LIBS} -lGLESv2"])]) |
---|
203 | fi |
---|
204 | |
---|
205 | if test "x${ac_cv_my_stop_looking_for_gl}" = "xno"; then |
---|
206 | PKG_CHECK_MODULES(GL, gl, |
---|
207 | [ac_cv_my_have_gl="yes" |
---|
208 | AC_DEFINE(HAVE_GL_2X, 1, Define to 1 if GL 2.x is available)], |
---|
209 | [:]) |
---|
210 | fi |
---|
211 | |
---|
212 | if test "x${ac_cv_my_stop_looking_for_gl}" = "xno"; then |
---|
213 | AC_CHECK_LIB(GL, glEnable, |
---|
214 | [ac_cv_my_have_gl="yes" |
---|
215 | AC_DEFINE(HAVE_GL_2X, 1, Define to 1 if GL 2.x is available) # FIXME: hackish |
---|
216 | GL_LIBS="-lGL"]) |
---|
217 | fi |
---|
218 | |
---|
219 | if test "x${ac_cv_my_stop_looking_for_gl}" = "xno"; then |
---|
220 | AC_CHECK_HEADER(GL/gl.h, |
---|
221 | [LIBS_save="$LIBS" |
---|
222 | LIBS="$LIBS -lopengl32" |
---|
223 | AC_MSG_CHECKING(for glLoadIdentity in -lopengl32) |
---|
224 | AC_TRY_LINK([#include <GL/gl.h>], |
---|
225 | [glLoadIdentity();], |
---|
226 | [ac_cv_my_have_gl="yes" |
---|
227 | AC_DEFINE(HAVE_GL_2X, 1, Define to 1 if GL 2.x is available) # FIXME: hack |
---|
228 | AC_MSG_RESULT(yes) |
---|
229 | GL_LIBS="-lopengl32"], |
---|
230 | [AC_MSG_RESULT(no)]) |
---|
231 | LIBS="$LIBS_save"]) |
---|
232 | fi |
---|
233 | |
---|
234 | if test "${ac_cv_my_have_gl}" = "no"; then |
---|
235 | AC_MSG_ERROR([[No OpenGL or OpenGL ES implementation found]]) |
---|
236 | fi |
---|
237 | |
---|
238 | |
---|
239 | dnl Use Glew? |
---|
240 | ac_cv_my_have_glew="no" |
---|
241 | PKG_CHECK_MODULES(GLEW, glew, |
---|
242 | [ac_cv_my_have_glew="yes" |
---|
243 | GL_CFLAGS="${GLEW_CFLAGS} ${GL_CFLAGS}" |
---|
244 | GL_LIBS="${GLEW_LIBS} ${GL_LIBS}"], |
---|
245 | [:]) |
---|
246 | AC_CHECK_HEADER(glew.h, |
---|
247 | [LIBS_save="${LIBS}" |
---|
248 | LIBS="${LIBS} -lglew32 ${GL_LIBS}" |
---|
249 | AC_MSG_CHECKING(for glewInit in -lglew32) |
---|
250 | AC_TRY_LINK( |
---|
251 | [#include <glew.h>], |
---|
252 | [glewInit();], |
---|
253 | [ac_cv_my_have_glew="yes" |
---|
254 | GL_LIBS="-lglew32 ${GL_LIBS}" |
---|
255 | AC_MSG_RESULT(yes)], |
---|
256 | [AC_MSG_RESULT(no)]) |
---|
257 | LIBS="${LIBS_save}"]) |
---|
258 | if test "${ac_cv_my_have_glew}" != "no"; then |
---|
259 | AC_DEFINE(HAVE_GLES_2X, 1, Define to 1 if GLES 2.x is available) |
---|
260 | AC_DEFINE(USE_GLEW, 1, Define to 1 to use libglew) |
---|
261 | fi |
---|
262 | AM_CONDITIONAL(USE_GLEW, test "${ac_cv_my_have_glew}" != "no") |
---|
263 | |
---|
264 | dnl Poor man's GL feature detection if all else failed. |
---|
265 | save_LIBS="${LIBS}" |
---|
266 | LIBS="${LIBS} ${GL_LIBS} ${GLES2_LIBS}" |
---|
267 | AC_CHECK_FUNCS(glBegin) |
---|
268 | LIBS="${save_LIBS}" |
---|
269 | |
---|
270 | |
---|
271 | dnl Use SDL? (always required on Linux or Win32) |
---|
272 | ac_cv_my_have_sdl="no" |
---|
273 | ac_cv_my_have_sdl_image="no" |
---|
274 | ac_cv_my_have_sdl_mixer="no" |
---|
275 | dnl |
---|
276 | dnl First, try the proper pkg-config check |
---|
277 | PKG_CHECK_MODULES(SDL, sdl, [ac_cv_my_have_sdl="yes"], [:]) |
---|
278 | PKG_CHECK_MODULES(SDLMIXER, SDL_mixer, [ac_cv_my_have_sdl_mixer="yes"], [:]) |
---|
279 | PKG_CHECK_MODULES(SDLIMAGE, SDL_image, [ac_cv_my_have_sdl_image="yes"], [:]) |
---|
280 | dnl |
---|
281 | dnl Then the old sdl-config method |
---|
282 | if test "x${cross_compiling}" != xyes -a "${ac_cv_my_have_sdl}" != yes; then |
---|
283 | AC_PATH_PROG(SDL_CONFIG, sdl-config, no) |
---|
284 | if test "${SDL_CONFIG}" != "no"; then |
---|
285 | SDL_CFLAGS="${SDL_CFLAGS} `${SDL_CONFIG} --cflags`" |
---|
286 | SDL_LIBS="${SDL_LIBS} `${SDL_CONFIG} --libs`" |
---|
287 | ac_cv_my_have_sdl="yes" |
---|
288 | fi |
---|
289 | fi |
---|
290 | dnl |
---|
291 | dnl Maybe all this has failed, try direct inclusion |
---|
292 | save_CPPFLAGS="${CPPFLAGS}" |
---|
293 | save_LIBS="${LIBS}" |
---|
294 | CPPFLAGS="${CPPFLAGS} ${SDL_CFLAGS} ${SDLMIXER_CFLAGS} ${SDLIMAGE_CFLAGS}" |
---|
295 | LIBS="${LIBS} ${SDL_LIBS} ${SDLMIXER_LIBS} ${SDLIMAGE_LIBS}" |
---|
296 | AC_CHECK_HEADERS(SDL.h SDL/SDL.h, [ac_cv_my_have_sdl="yes"]) |
---|
297 | AC_CHECK_HEADERS(SDL_mixer.h SDL/SDL_mixer.h, [ac_cv_my_have_sdl_mixer="yes"]) |
---|
298 | AC_CHECK_HEADERS(SDL_image.h SDL/SDL_image.h, [ac_cv_my_have_sdl_image="yes"]) |
---|
299 | AC_CHECK_LIB(SDL, main, |
---|
300 | [SDL_LIBS="${SDL_LIBS} -lSDL"], |
---|
301 | [ac_cv_my_have_sdl="no"]) |
---|
302 | AC_CHECK_LIB(SDLmain, main, |
---|
303 | [SDL_LIBS="${SDL_LIBS} -lSDLmain -lSDL"]) |
---|
304 | AC_CHECK_LIB(SDL_mixer, main, |
---|
305 | [SDLMIXER_LIBS="${SDLMIXER_LIBS} -lSDL_mixer"], |
---|
306 | [ac_cv_my_have_sdl_mixer="no"]) |
---|
307 | AC_CHECK_LIB(SDL_image, main, |
---|
308 | [SDLIMAGE_LIBS="${SDLIMAGE_LIBS} -lSDL_image"], |
---|
309 | [ac_cv_my_have_sdl_image="no"]) |
---|
310 | SDL_CFLAGS="${SDL_CFLAGS} ${SDLMIXER_CFLAGS} ${SDLIMAGE_CFLAGS}" |
---|
311 | SDL_LIBS="${SDL_LIBS} ${SDLMIXER_LIBS} ${SDLIMAGE_LIBS}" |
---|
312 | CPPFLAGS="${save_CPPFLAGS}" |
---|
313 | LIBS="${save_LIBS}" |
---|
314 | if test "${ac_cv_my_have_sdl}" = "no"; then |
---|
315 | AC_MSG_WARN([SDL not found]) |
---|
316 | else |
---|
317 | AC_DEFINE(USE_SDL, 1, Define to 1 to use SDL) |
---|
318 | fi |
---|
319 | if test "${ac_cv_my_have_sdl_mixer}" = "no"; then |
---|
320 | AC_MSG_WARN([SDL_mixer not found]) |
---|
321 | else |
---|
322 | AC_DEFINE(USE_SDL_MIXER, 1, Define to 1 to use SDL_mixer) |
---|
323 | fi |
---|
324 | if test "${ac_cv_my_have_sdl_image}" = "no"; then |
---|
325 | AC_MSG_WARN([SDL_image not found]) |
---|
326 | else |
---|
327 | AC_DEFINE(USE_SDL_IMAGE, 1, Define to 1 to use SDL_image) |
---|
328 | fi |
---|
329 | AM_CONDITIONAL(USE_SDL, test "${ac_cv_my_have_sdl}" = "yes") |
---|
330 | AM_CONDITIONAL(USE_SDL_MIXER, test "${ac_cv_my_have_sdl_mixer}" = "yes") |
---|
331 | AM_CONDITIONAL(USE_SDL_IMAGE, test "${ac_cv_my_have_sdl_image}" = "yes") |
---|
332 | |
---|
333 | |
---|
334 | dnl Use Flex's FlexLexer.h or ours? |
---|
335 | ac_cv_my_have_flexlexer_h="no" |
---|
336 | AC_LANG_PUSH(C++) |
---|
337 | AC_CHECK_HEADERS(FlexLexer.h, [ac_cv_my_have_flexlexer_h="yes"]) |
---|
338 | AC_LANG_POP(C++) |
---|
339 | if test "x${ac_cv_my_have_flexlexer_h}" = "xno"; then |
---|
340 | LOL_CFLAGS="$LOL_CFLAGS -I\$(top_srcdir)/contrib/flex-2.5.35/include" |
---|
341 | fi |
---|
342 | |
---|
343 | |
---|
344 | dnl Use NativeClient? |
---|
345 | ac_cv_my_have_nacl="no" |
---|
346 | AC_LANG_PUSH(C++) |
---|
347 | AC_CHECK_HEADERS(ppapi/cpp/instance.h, |
---|
348 | [ac_cv_my_have_nacl="yes" |
---|
349 | dnl Disable this warning, it's too verbose with vector.h |
---|
350 | CXXFLAGS="${CXXFLAGS} -Wno-sign-compare"]) |
---|
351 | AC_LANG_POP(C++) |
---|
352 | AM_CONDITIONAL(USE_NACL, test "${ac_cv_my_have_nacl}" != "no") |
---|
353 | |
---|
354 | |
---|
355 | dnl Use Android? FIXME: super hacks! |
---|
356 | ac_cv_my_have_android="no" |
---|
357 | AC_CHECK_LIB(log, __android_log_vprint, |
---|
358 | [ac_cv_my_have_android="yes" |
---|
359 | LOL_LIBS="${LOL_LIBS} -llog -module"]) |
---|
360 | AM_CONDITIONAL(USE_ANDROID, test "${ac_cv_my_have_android}" != "no") |
---|
361 | |
---|
362 | |
---|
363 | dnl Use EGL? |
---|
364 | ac_cv_my_have_egl="no" |
---|
365 | PKG_CHECK_MODULES(EGL, egl, [ac_cv_my_have_egl="yes"], [:]) |
---|
366 | if test "${ac_cv_my_have_egl}" != "no"; then |
---|
367 | AC_DEFINE(USE_EGL, 1, Define to 1 to use libegl) |
---|
368 | EGL_LIBS="${EGL_LIBS} -lX11" |
---|
369 | fi |
---|
370 | AC_CHECK_LIB(EGL, main, |
---|
371 | [ac_cv_my_have_egl="yes" |
---|
372 | AC_DEFINE(USE_EGL, 1, Define to 1 to use libegl) |
---|
373 | EGL_LIBS="-lEGL"]) |
---|
374 | dnl Raspberry Pi is different, check for it with extra libs; also we |
---|
375 | dnl look for a different function to bypass autoconf caching |
---|
376 | AC_CHECK_LIB(EGL, eglGetDisplay, |
---|
377 | [ac_cv_my_have_egl="yes" |
---|
378 | AC_DEFINE(USE_EGL, 1, Define to 1 to use libegl) |
---|
379 | EGL_LIBS="-lEGL -lvcos -lvchiq_arm -lbcm_host -lGLESv2"], |
---|
380 | [:], |
---|
381 | [-lvcos -lvchiq_arm -lbcm_host -lGLESv2]) |
---|
382 | AM_CONDITIONAL(USE_EGL, test "${ac_cv_my_have_egl}" != "no") |
---|
383 | |
---|
384 | |
---|
385 | dnl Use libpng? (replacement for SDL_image) |
---|
386 | ac_cv_my_have_libpng="no" |
---|
387 | PKG_CHECK_MODULES(LIBPNG, libpng, [ac_cv_my_have_libpng="yes"], [:]) |
---|
388 | if test "${ac_cv_my_have_libpng}" != "no"; then |
---|
389 | AC_DEFINE(USE_LIBPNG, 1, Define to 1 to use libpng) |
---|
390 | fi |
---|
391 | AM_CONDITIONAL(USE_LIBPNG, test "${ac_cv_my_have_libpng}" != "no") |
---|
392 | |
---|
393 | |
---|
394 | dnl Use Windows GDI+? |
---|
395 | ac_cv_my_have_gdiplus="no" |
---|
396 | AC_LANG_PUSH(C++) |
---|
397 | AC_CHECK_HEADERS(gdiplus.h, |
---|
398 | [ac_cv_my_have_gdiplus="yes" |
---|
399 | LOL_LIBS="${LOL_LIBS} -lgdiplus"], |
---|
400 | [ac_cv_my_have_gdiplus="no"], |
---|
401 | [#include <algorithm> |
---|
402 | using std::min; |
---|
403 | using std::max; |
---|
404 | #include <windows.h>]) |
---|
405 | AC_LANG_POP(C++) |
---|
406 | if test "${ac_cv_my_have_gdiplus}" != "no"; then |
---|
407 | AC_DEFINE(USE_GDIPLUS, 1, Define to 1 to use GDI+) |
---|
408 | fi |
---|
409 | AM_CONDITIONAL(USE_GDIPLUS, test "${ac_cv_my_have_gdiplus}" = "yes") |
---|
410 | |
---|
411 | |
---|
412 | dnl Use libcaca? (required for font generation) |
---|
413 | ac_cv_my_have_caca="no" |
---|
414 | PKG_CHECK_MODULES(CACA, caca >= 0.99.beta17, [ac_cv_my_have_caca="yes"], [:]) |
---|
415 | if test "${ac_cv_my_have_caca}" != "no"; then |
---|
416 | AC_DEFINE(USE_CACA, 1, Define to 1 to use libcaca) |
---|
417 | fi |
---|
418 | AM_CONDITIONAL(USE_CACA, test "${ac_cv_my_have_caca}" != "no") |
---|
419 | |
---|
420 | |
---|
421 | dnl Use libpipi? (required for video recording) |
---|
422 | ac_cv_my_have_pipi="no" |
---|
423 | PKG_CHECK_MODULES(PIPI, pipi, [ac_cv_my_have_pipi="yes"], [:]) |
---|
424 | if test "${ac_cv_my_have_pipi}" != "no"; then |
---|
425 | AC_DEFINE(USE_PIPI, 1, Define to 1 to use libpipi) |
---|
426 | fi |
---|
427 | AM_CONDITIONAL(USE_PIPI, test "${ac_cv_my_have_pipi}" != "no") |
---|
428 | |
---|
429 | |
---|
430 | dnl Use GTK+? (required for the deushax editor) |
---|
431 | ac_cv_my_have_gtkgl="no" |
---|
432 | PKG_CHECK_MODULES(GTK, gtk+-2.0, [ac_cv_my_have_gtkgl="yes"], [:]) |
---|
433 | PKG_CHECK_MODULES(GTKGL, gtkgl-2.0, [:], [ac_cv_my_have_gtkgl="no"]) |
---|
434 | if test "${ac_cv_my_have_gtkgl}" != "no"; then |
---|
435 | AC_DEFINE(USE_GTKGL, 1, Define to 1 to use GtkGl) |
---|
436 | fi |
---|
437 | AM_CONDITIONAL(USE_GTKGL, test "${ac_cv_my_have_gtkgl}" != "no") |
---|
438 | |
---|
439 | |
---|
440 | dnl Can we build neercs? |
---|
441 | AM_CONDITIONAL(BUILD_NEERCS, test "${ac_cv_my_have_caca}" != "no" -a "${ac_cv_header_glob_h}" = "yes") |
---|
442 | |
---|
443 | |
---|
444 | dnl LolFx compilation rule |
---|
445 | LOLFX_BUILD='(echo "char const *"; echo "lolfx_$(notdir $(basename $(filter %.lolfx, $^))) ="; $(SED) '"'"'s/"/\\"/g'"'"' $(filter %.lolfx, $^) | $(SED) '"'"'s/\([[^\r]]*\).*/"\1\\n"/'"'"'; echo ";") | $(CXXCOMPILE) -xc++ -c - -o $@' |
---|
446 | AC_SUBST(LOLFX_BUILD) |
---|
447 | |
---|
448 | |
---|
449 | dnl Extra libraries we may need |
---|
450 | AC_SUBST(MATH_LIBS) |
---|
451 | AC_SUBST(PAM_LIBS) |
---|
452 | AC_SUBST(UTIL_LIBS) |
---|
453 | |
---|
454 | dnl How to use the Lol Engine inside this tree |
---|
455 | LOL_CFLAGS="$LOL_CFLAGS -I \$(top_srcdir)/src" |
---|
456 | LOL_CFLAGS="$LOL_CFLAGS $SDL_CFLAGS $GL_CFLAGS $EGL_CFLAGS $LIBPNG_CFLAGS" |
---|
457 | LOL_LIBS="$LOL_LIBS $SDL_LIBS $GL_LIBS $EGL_LIBS $LIBPNG_LIBS $D3D_LIBS" |
---|
458 | |
---|
459 | AC_SUBST(LOL_CFLAGS) |
---|
460 | AC_SUBST(LOL_LIBS) |
---|
461 | |
---|
462 | |
---|
463 | AC_CONFIG_FILES( |
---|
464 | [Makefile |
---|
465 | src/Makefile |
---|
466 | src/data/Makefile |
---|
467 | src/data/font/Makefile |
---|
468 | tutorial/Makefile |
---|
469 | test/Makefile |
---|
470 | test/math/Makefile |
---|
471 | test/sandbox/Makefile |
---|
472 | test/xolotl/Makefile |
---|
473 | build/Makefile |
---|
474 | binaries/Makefile |
---|
475 | people/Makefile |
---|
476 | games/Makefile |
---|
477 | tools/Makefile |
---|
478 | ]) |
---|
479 | AC_CONFIG_FILES( |
---|
480 | [games/monsterz/Makefile |
---|
481 | ]) |
---|
482 | AC_CONFIG_FILES( |
---|
483 | [games/deushax/Makefile |
---|
484 | games/deushax/art/Makefile |
---|
485 | games/deushax/art/test/Makefile |
---|
486 | games/deushax/gfx/Makefile |
---|
487 | games/deushax/maps/Makefile |
---|
488 | ]) |
---|
489 | AC_CONFIG_FILES( |
---|
490 | [games/mrpigeon/Makefile |
---|
491 | ]) |
---|
492 | AC_CONFIG_FILES( |
---|
493 | [games/orbital/Makefile |
---|
494 | ]) |
---|
495 | AC_CONFIG_FILES( |
---|
496 | [tools/neercs/Makefile |
---|
497 | ]) |
---|
498 | AC_CONFIG_FILES( |
---|
499 | [people/jnat/Makefile |
---|
500 | people/touky/Makefile |
---|
501 | ]) |
---|
502 | |
---|
503 | AC_OUTPUT |
---|
504 | |
---|