Unbreak eet examples(they need Eina).
[profile/ivi/eet.git] / configure.ac
1 ##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##
2 ##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##
3 m4_define([v_maj], [1])
4 m4_define([v_min], [6])
5 m4_define([v_mic], [99])
6 m4_define([v_rev], m4_esyscmd([(svnversion "${SVN_REPO_PATH:-.}" | grep -v '\(export\|Unversioned directory\)' || echo 0) | awk -F : '{printf("%s\n", $1);}' | tr -d ' :MSP\n']))
7 m4_if(v_rev, [0], [m4_define([v_rev], m4_esyscmd([git log 2> /dev/null | (grep -m1 git-svn-id || echo 0) | sed -e 's/.*@\([0-9]*\).*/\1/' | tr -d '\n']))])
8 ##--   When released, remove the dnl on the below line
9 dnl m4_undefine([v_rev])
10 ##--   When doing snapshots - change soname. remove dnl on below line
11 dnl m4_define([relname], [ver-pre-svn-05])
12 dnl m4_define([v_rel], [-release relname])
13 ##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##
14 m4_ifdef([v_rev], [m4_define([v_ver], [v_maj.v_min.v_mic.v_rev])], [m4_define([v_ver], [v_maj.v_min.v_mic])])
15 m4_define([lt_cur], m4_eval(v_maj + v_min))
16 m4_define([lt_rev], v_mic)
17 m4_define([lt_age], v_min)
18 ##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##
19 ##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##
20
21 AC_INIT([eet], [v_ver], [enlightenment-devel@lists.sourceforge.net])
22 AC_PREREQ([2.52])
23 AC_CONFIG_SRCDIR([configure.ac])
24 AC_CONFIG_MACRO_DIR([m4])
25
26 AC_CONFIG_HEADERS([config.h])
27 AH_TOP([
28 #ifndef EFL_CONFIG_H__
29 #define EFL_CONFIG_H__
30 ])
31 AH_BOTTOM([
32 #endif /* EFL_CONFIG_H__ */
33 ])
34
35 AM_INIT_AUTOMAKE([1.6 dist-bzip2])
36 m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
37
38 AC_GNU_SOURCE
39
40 AC_LIBTOOL_WIN32_DLL
41 define([AC_LIBTOOL_LANG_CXX_CONFIG], [:])dnl
42 define([AC_LIBTOOL_LANG_F77_CONFIG], [:])dnl
43 AC_PROG_LIBTOOL
44
45 ##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##
46 ##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##
47 m4_ifdef([v_rev], , [m4_define([v_rev], [0])])
48 m4_ifdef([v_rel], , [m4_define([v_rel], [])])
49 AC_DEFINE_UNQUOTED(VMAJ, [v_maj], [Major version])
50 AC_DEFINE_UNQUOTED(VMIN, [v_min], [Minor version])
51 AC_DEFINE_UNQUOTED(VMIC, [v_mic], [Micro version])
52 AC_DEFINE_UNQUOTED(VREV, [v_rev], [Revison])
53 version_info="lt_cur:lt_rev:lt_age"
54 release_info="v_rel"
55 AC_SUBST(version_info)
56 AC_SUBST(release_info)
57 ##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##
58 ##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##--##
59 VMAJ=v_maj
60 AC_SUBST(VMAJ)
61
62
63 ### Needed information
64
65 AC_CANONICAL_BUILD
66 AC_CANONICAL_HOST
67
68 ### Default options with respect to host
69
70 requirements_pc_eet=""
71 requirements_libs_eet=""
72
73 ### Additional options to configure
74
75 EFL_ENABLE_BIN([eet])
76
77 # Old eet file format support
78
79 AC_ARG_ENABLE(old-eet-file-format,
80    [AC_HELP_STRING(
81       [--disable-old-eet-file-format],
82       [disable old eet file format support @<:@default=enabled@:>@])],
83    [
84     if test "x${enableval}" = "xyes" ; then
85        old_eet_file_format="yes"
86     else
87        old_eet_file_format="no"
88     fi
89    ],
90    [old_eet_file_format="yes"])
91
92 AC_MSG_CHECKING([whether to support old eet file format])
93 AC_MSG_RESULT([${old_eet_file_format}])
94
95 if test "x${old_eet_file_format}" = "xyes" ; then
96    AC_DEFINE(EET_OLD_EET_FILE_FORMAT, 1, [support old eet file format])
97 else
98    AC_DEFINE(EET_OLD_EET_FILE_FORMAT, 0, [support old eet file format])
99 fi
100
101 # Openssl support
102
103 AC_ARG_ENABLE([openssl],
104    [AC_HELP_STRING([--disable-openssl], [disable openssl eet support @<:@default=auto@:>@])],
105    [
106     if test "x${enableval}" = "xyes" ; then
107        want_openssl="yes"
108     else
109        want_openssl="no"
110     fi
111    ],
112    [want_openssl="auto"])
113
114 AC_MSG_CHECKING([whether to use OpenSSL])
115 AC_MSG_RESULT([${want_openssl}])
116
117 # Cryptography support
118
119 AC_ARG_ENABLE([cipher],
120    [AC_HELP_STRING([--disable-cipher], [disable cipher support for eet API @<:@default=yes@:>@])],
121    [
122     if test "x${enableval}" = "xyes" ; then
123        want_cipher="yes"
124     else
125        want_cipher="no"
126     fi
127    ],
128    [want_cipher="yes"])
129
130 AC_MSG_CHECKING([whether to use cipher])
131 AC_MSG_RESULT([${want_cipher}])
132
133 AC_ARG_ENABLE([signature],
134    [AC_HELP_STRING([--disable-signature], [disable signature file support for eet @<:@default=yes@:>@])],
135    [
136     if test "x${enableval}" = "xyes" ; then
137        want_signature="yes"
138     else
139        want_signature="no"
140     fi
141    ],
142    [want_signature="yes"])
143
144 AC_MSG_CHECKING([whether to use signature])
145 AC_MSG_RESULT([${want_signature}])
146
147 # Assert or fail.
148
149 AC_ARG_ENABLE([assert],
150    [AC_HELP_STRING([--enable-assert], [enable assert, @<:@default=no@:>@])],
151    [
152     if test "x${enableval}" = "xyes" ; then
153        prefer_assert="yes"
154     else
155        prefer_assert="no"
156     fi
157    ],
158    [prefer_assert="no"])
159
160 # Examples
161
162 AC_ARG_ENABLE([install-examples],
163    [AC_HELP_STRING([--disable-install-examples],
164        [disable installing examples (compiled or just source). @<:@default=yes@:>@])],
165    [
166     if test "x${enableval}" = "xyes" ; then
167        install_examples="yes"
168     else
169        install_examples="no"
170     fi
171    ],
172    [install_examples="yes"])
173
174 AM_CONDITIONAL([INSTALL_EXAMPLES], [test "x${install_examples}" = "xyes"])
175
176 AC_ARG_ENABLE([build-examples],
177    [AC_HELP_STRING([--enable-build-examples],
178        [enable building examples @<:@default=yes@:>@])],
179    [
180     if test "x${enableval}" = "xyes" ; then
181        build_examples="yes"
182     else
183        build_examples="no"
184     fi
185    ],
186    [build_examples="no"])
187 AM_CONDITIONAL([BUILD_EXAMPLES], [test "x${build_examples}" = "xyes"])
188
189
190 ### Checks for programs
191 AC_PROG_CC
192
193 # pkg-config
194 PKG_PROG_PKG_CONFIG
195
196 # Check whether pkg-config supports Requires.private
197 if $PKG_CONFIG --atleast-pkgconfig-version 0.22; then
198    pkgconfig_requires_private="Requires.private"
199 else
200    pkgconfig_requires_private="Requires"
201 fi
202 AC_SUBST(pkgconfig_requires_private)
203
204
205 # doxygen program for documentation building
206
207 EFL_CHECK_DOXYGEN([build_doc="yes"], [build_doc="no"])
208
209 ### Checks for libraries
210
211 ## Compatibility layers
212
213 # Evil library for compilation on Windows
214
215 EFL_EET_BUILD=""
216 case "$host_os" in
217    mingw*)
218       PKG_CHECK_EXISTS([evil >= 1.1.0])
219       AC_DEFINE([HAVE_EVIL], [1], [Set to 1 if Evil package is installed])
220       requirements_pc_eet="evil ${requirements_pc_eet}"
221       EFL_EET_BUILD="-DEFL_EET_BUILD"
222    ;;
223 esac
224 AC_SUBST(EFL_EET_BUILD)
225
226 PKG_CHECK_MODULES(EINA, [eina >= 1.2.0])
227 requirement_eet="eina >= 1.2.0 ${requirement_eet}"
228
229 # Exotic library for copilation on Coyote
230
231 PKG_CHECK_EXISTS([exotic],
232    [
233     enable_exotic="yes"
234     AC_DEFINE([HAVE_EXOTIC_H], [1], [Define to 1 if you have Exotic.])
235     EINA_CONFIGURE_HAVE_EXOTIC="#define EINA_HAVE_EXOTIC"
236     requirements_pc_eina="exotic ${requirements_pc_eina}"
237    ],
238    [enable_exotic="no"])
239
240 ## Secure layer
241
242 # Gnutls library
243
244 AC_ARG_ENABLE([gnutls],
245    [AC_HELP_STRING([--disable-gnutls], [disable gnutls eet support @<:@default=auto@:>@])],
246    [
247     if test "x${enableval}" = "xyes" ; then
248        want_gnutls="yes"
249     else
250        want_gnutls="no"
251     fi
252    ],
253    [want_gnutls="auto"])
254
255 AC_MSG_CHECKING([whether to use Gnutls])
256 AC_MSG_RESULT([${want_gnutls}])
257
258 have_gnutls="no"
259 if test "x${want_gnutls}" = "xyes" || test "x${want_gnutls}" = "xauto" ; then
260    PKG_CHECK_MODULES([GNUTLS], [gnutls >= 1.7.6],
261       [
262        have_gnutls="yes"
263        want_openssl="no"
264        AC_DEFINE([HAVE_GNUTLS], [1], [Have Gnutls support])
265        requirements_pc_eet="gnutls >= 1.7.6 ${requirements_pc_eet}"
266       ],
267       [have_gnutls="no"])
268 fi
269
270 # libgcrypt
271
272 if test "x${have_gnutls}" = "xyes" ; then
273    AC_PATH_GENERIC([libgcrypt], [], [have_gnutls="yes"], [have_gnutls="no"])
274    if test "x${have_gnutls}" = "xyes" ; then
275       requirements_libs_eet="${LIBGCRYPT_LIBS} ${requirements_libs_eet}"
276    fi
277 fi
278
279 # Specific GNUTLS improvement
280
281 AC_ARG_ENABLE(new-gnutls-api,
282    [AC_HELP_STRING(
283       [--disable-new-gnutls-api],
284       [enable use of gnutls_x509_crt_verify_hash. @<:@default=yes@:>@])],
285    [
286     if test "x${enableval}" = "xyes" ; then
287        new_gnutls_api="yes"
288     else
289        new_gnutls_api="no"
290     fi
291    ],
292    [new_gnutls_api="yes"])
293
294 AC_MSG_CHECKING([whether to use gnutls_x509_crt_verify_hash])
295 AC_MSG_RESULT([${new_gnutls_api}])
296
297 if test "x${have_gnutls}" = "xyes" && test "x${new_gnutls_api}" = "xyes" ; then
298    CFLAGS_save="${CFLAGS}"
299    LIBS_save="${LIBS}"
300    CFLAGS="${GNUTLS_CFLAGS}"
301    LIBS="${GNUTLS_LIBS}"
302    AC_CHECK_LIB([gnutls], [gnutls_x509_crt_verify_hash],
303       [
304        AC_DEFINE([EET_USE_NEW_GNUTLS_API], [1], [use gnutls_x509_crt_verify_hash])
305        new_gnutls_api="yes"
306       ],
307       [new_gnutls_api="no"])
308    CFLAGS="${CFLAGS_save}"
309    LIBS="${LIBS_save}"
310 fi
311
312 use_gnutls_privkey_sign_data="no"
313 if test "x${have_gnutls}" = "xyes" ; then
314    CFLAGS_save="${CFLAGS}"
315    LIBS_save="${LIBS}"
316    CFLAGS="${GNUTLS_CFLAGS}"
317    LIBS="${GNUTLS_LIBS}"
318    AC_CHECK_LIB([gnutls], [gnutls_privkey_sign_data],
319       [
320        AC_DEFINE([EET_USE_NEW_PRIVKEY_SIGN_DATA], [1], [use gnutls_privkey_sign_data])
321        use_gnutls_privkey_sign_data="yes"
322       ],
323       [use_gnutls_privkey_sign_data="no"])
324    CFLAGS="${CFLAGS_save}"
325    LIBS="${LIBS_save}"
326 fi
327
328 AC_MSG_CHECKING([whether to use gnutls_privkey_sign_data])
329 AC_MSG_RESULT([${use_gnutls_privkey_sign_data}])
330
331 use_gnutls_pubkey_verify_hash="no"
332 if test "x${have_gnutls}" = "xyes" ; then
333    CFLAGS_save="${CFLAGS}"
334    LIBS_save="${LIBS}"
335    CFLAGS="${GNUTLS_CFLAGS}"
336    LIBS="${GNUTLS_LIBS}"
337    AC_CHECK_LIB([gnutls], [gnutls_pubkey_verify_hash],
338       [
339        AC_DEFINE([EET_USE_NEW_PUBKEY_VERIFY_HASH], [1], [use gnutls_pubkey_verify_hash])
340        use_gnutls_pubkey_verify_hash="yes"
341       ],
342       [use_gnutls_pubkey_verify_hash="no"])
343    CFLAGS="${CFLAGS_save}"
344    LIBS="${LIBS_save}"
345 fi
346
347 AC_MSG_CHECKING([whether to use gnutls_pubkey_verify_hash])
348 AC_MSG_RESULT([${use_gnutls_pubkey_verify_hash}])
349
350 # Openssl library
351 have_openssl="no"
352 if test "x${want_openssl}" = "xyes" || test "x${want_openssl}" = "xauto" ; then
353    PKG_CHECK_EXISTS([openssl],
354       [
355        have_openssl="yes"
356        AC_DEFINE([HAVE_OPENSSL], [1], [Have Openssl support])
357        requirements_pc_eet="openssl ${requirements_pc_eet}"
358       ],
359       [have_openssl="no"])
360 fi
361
362 if test "x${have_gnutls}" = "xyes" ; then
363    secure_layer="GnuTLS"
364 elif test "x${have_openssl}" = "xyes" ; then
365    secure_layer="OpenSSL"
366 else
367    secure_layer="no"
368 fi
369
370 have_cipher="no"
371 if test "x${have_gnutls}" = "xyes" && test "x${want_cipher}" = "xyes" ; then
372    have_cipher="yes"
373    AC_DEFINE([HAVE_CIPHER], [1], [Have cipher support built in eet])
374 elif test "x${have_openssl}" = "xyes" && test "x${want_cipher}" = "xyes" ; then
375    have_cipher="yes"
376    AC_DEFINE([HAVE_CIPHER], [1], [Have cipher support built in eet])
377 fi
378
379 AC_MSG_CHECKING([whether to activate cipher support in eet])
380 AC_MSG_RESULT([${have_cipher}])
381
382 have_signature="no"
383 if test "x${have_gnutls}" = "xyes" && test "x${want_signature}" = "xyes" ; then
384    have_signature="yes"
385    AC_DEFINE([HAVE_SIGNATURE], [1], [Have signature support for eet file])
386 elif test "x${have_openssl}" = "xyes" && test "x${want_signature}" = "xyes" ; then
387    have_signature="yes"
388    AC_DEFINE([HAVE_SIGNATURE], [1], [Have signature support for eet file])
389 fi
390
391 AC_MSG_CHECKING([whether to activate signature support in eet])
392 AC_MSG_RESULT([${have_signature}])
393
394 # libjpeg and zlib
395 EFL_CHECK_LIBS([eet], [libjpeg zlib])
396
397 # Eina library
398
399 requirements_pc_eet="eina >= 1.2.0 ${requirements_pc_eet}"
400 PKG_CHECK_MODULES([EET], [${requirements_pc_eet}])
401
402 case "$host_os" in
403    mingw32ce*)
404       requirements_libs_eet="${requirements_libs_eet} -lws2"
405       ;;
406    mingw*)
407       requirements_libs_eet="${requirements_libs_eet} -lws2_32"
408       ;;
409 esac
410
411 EET_LIBS="${EET_LIBS} ${requirements_libs_eet}"
412
413 ### Checks for header files
414
415 AC_CHECK_HEADERS(netinet/in.h unistd.h)
416 EFL_CHECK_PATH_MAX
417
418 ### Checks for types
419
420
421 ### Checks for structures
422
423
424 ### Checks for compiler characteristics
425 AM_PROG_CC_C_O
426 AC_C_INLINE
427 AC_PROG_CC_STDC
428 AC_C___ATTRIBUTE__
429
430 # Check whether the null pointer is zero on this arch
431 AC_TRY_RUN(
432    [
433 #include <stdlib.h>
434 #include <inttypes.h>
435 int main (int argc, char **argv) {
436   void *foo = NULL;
437   uintptr_t bar = (uintptr_t)foo;
438   return (uintptr_t)foo;
439 }
440    ],
441    [have_null="yes"],
442    [have_null="no"],
443    [
444     AC_MSG_WARN([Cannot check when cross-compiling -- assuming null is okay])
445     have_null="yes"
446    ])
447 AC_MSG_CHECKING([value of the null pointer])
448 AC_MSG_RESULT([${have_null}])
449
450 if test ! "x${have_null}" = "xyes" ; then
451    AC_MSG_WARN([Your system is a bit too funny, eet might not work properly])
452 fi
453
454
455 ### Checks for linker characteristics
456
457 # use --enable-auto-import on Windows
458
459 lt_enable_auto_import=""
460 case "$host_os" in
461    mingw*)
462       lt_enable_auto_import="-Wl,--enable-auto-import"
463       ;;
464 esac
465 AC_SUBST([lt_enable_auto_import])
466
467 case "${host_os}" in
468    openbsd*)
469       ;;
470    *)
471       EFL_LINKER_FLAG([-Wl,--as-needed])
472       ;;
473 esac
474
475
476 ### Checks for library functions
477 AC_ISC_POSIX
478 AC_FUNC_ALLOCA
479
480 AC_CHECK_FUNCS(fmemopen open_memstream realpath)
481
482 EFL_CHECK_FUNCS([eet], [fnmatch])
483
484
485 ### Unit tests, coverage and benchmarking
486
487 EFL_CHECK_TESTS([eet], [enable_tests="yes"], [enable_tests="no"])
488
489
490 AC_SUBST([requirements_pc_eet])
491 AC_SUBST([requirements_libs_eet])
492
493 AC_OUTPUT([
494 Makefile
495 eet.pc
496 doc/Makefile
497 doc/Doxyfile
498 doc/eet.dox
499 src/Makefile
500 src/lib/Makefile
501 src/bin/Makefile
502 src/tests/Makefile
503 src/examples/Makefile
504 eet.spec
505 ])
506
507
508 #####################################################################
509 ## Info
510
511 echo
512 echo
513 echo
514 echo "------------------------------------------------------------------------"
515 echo "$PACKAGE_NAME $PACKAGE_VERSION"
516 echo "------------------------------------------------------------------------"
517 echo
518 echo "Configuration Options Summary:"
519 echo
520 echo "  Secure layer.........: ${secure_layer}"
521 if test "x${have_gnutls}" = "xyes" || test "x${have_openssl}" = "xyes" ; then
522    echo "    Cipher support.....: ${have_cipher}"
523    echo "    Signature..........: ${have_signature}"
524 fi
525 echo
526 echo "  Old eet file format..: ${old_eet_file_format}"
527 echo
528 echo "  Tests................: ${enable_tests} (Coverage: ${efl_enable_coverage})"
529 echo
530 echo "  Build eet............: $have_eet"
531 echo
532 echo "  Documentation........: ${build_doc}"
533 if test "x${build_doc}" = "xyes" ; then
534    echo "    Building...........: make doc"
535 fi
536 echo "  Examples.............: ${build_examples}"
537 echo "  Examples installed...: ${install_examples}"
538 echo
539 echo "Compilation............: make (or gmake)"
540 echo "  CPPFLAGS.............: $CPPFLAGS"
541 echo "  CFLAGS...............: $CFLAGS"
542 echo "  LDFLAGS..............: $LDFLAGS"
543 echo
544 echo "Installation...........: make install (as root if needed, with 'su' or 'sudo')"
545 echo "  prefix...............: $prefix"
546 echo