]> git.sur5r.net Git - kconfig-frontends/blobdiff - configure.ac
configure: pretty-print configuration
[kconfig-frontends] / configure.ac
index 7a747b70d61e18e237f173c8533f4a00cf9dd140..e565d117cbcd3dfe1e2543df1366b47263c225c5 100644 (file)
@@ -2,7 +2,10 @@
 # Process this file with autoconf to produce a configure script.
 
 AC_PREREQ([2.67])
-AC_INIT([kconfig-frontends], [m4_esyscmd_s([cat .version])], [nobody@nowhere.org])
+AC_INIT(
+    [kconfig-frontends],
+    [m4_esyscmd_s([./scripts/version.sh])],
+    [nobody@nowhere.org])
 AC_CONFIG_SRCDIR([frontends/conf/conf.c])
 # Use a config.h to avoid brazilions -DHAVE_FOO on compile lines
 AC_CONFIG_HEADERS([config.h])
@@ -46,36 +49,35 @@ AC_ARG_ENABLE(
     [conf],
     [AS_HELP_STRING(
         [--disable-conf],
-        [conf, the stdin-based frontend (default=yes)])])
-AC_SUBST([enable_conf], [${enable_conf:-yes}])
+        [conf, the stdin-based frontend (default=enabled)])])
+AC_SUBST([enable_conf], [${enable_conf:-auto}])
 AC_ARG_ENABLE(
     [mconf],
     [AS_HELP_STRING(
         [--disable-mconf],
-        [mconf, the traditional ncurses-based frontend (default=yes)])])
-AC_SUBST([enable_mconf], [${enable_mconf:-yes}])
+        [mconf, the traditional ncurses-based frontend (default=enabled)])])
+AC_SUBST([enable_mconf], [${enable_mconf:-auto}])
 AC_ARG_ENABLE(
     [nconf],
     [AS_HELP_STRING(
         [--disable-nconf],
-        [nconf, the modern ncurses-based frontend (default=yes)])])
-AC_SUBST([enable_nconf], [${enable_nconf:-yes}])
+        [nconf, the modern ncurses-based frontend (default=enabled)])])
+AC_SUBST([enable_nconf], [${enable_nconf:-auto}])
 AC_ARG_ENABLE(
     [gconf],
     [AS_HELP_STRING(
         [--disable-gconf],
-        [gconf, the GTK-based frontend (default=yes)])])
-AC_SUBST([enable_gconf], [${enable_gconf:-yes}])
+        [gconf, the GTK-based frontend (default=enabled)])])
+AC_SUBST([enable_gconf], [${enable_gconf:-auto}])
 AC_ARG_ENABLE(
     [qconf],
     [AS_HELP_STRING(
         [--disable-qconf],
-        [qconf, the QT-based frontend (default=yes)])])
-AC_SUBST([enable_qconf], [${enable_qconf:-yes}])
+        [qconf, the QT-based frontend (default=enabled)])])
+AC_SUBST([enable_qconf], [${enable_qconf:-auto}])
 
 #----------------------------------------
 # Some program checks
-AC_PROG_RANLIB
 AC_PROG_LEX
 AC_PROG_YACC
 AC_CHECK_PROGS(
@@ -103,44 +105,139 @@ AS_IF(
         [#include <$ac_ct_gettext_hdr>])])
 
 #----------------------------------------
-# Check for ncurses, for the kconfig frontends
-AC_SUBST([CURSES_LOC])
-AC_CHECK_HEADERS(
-    [ncurses/ncurses.h ncurses/curses.h ncursesw/curses.h ncurses.h curses.h],
-    [CURSES_LOC=$ac_header; break])
+# Check for ncurses, for the mconf & nconf frontends
+AS_CASE(
+    ["$enable_mconf":"$enable_nconf"],
+    [yes:*],  [need_curses=yes],
+    [*:yes],  [need_curses=yes],
+    [auto:*], [need_curses=auto],
+    [*:auto], [need_curses=auto],
+              [need_curses=no])
+
+AS_IF(
+    [test "$need_curses" = "yes" -o "$need_curses" = "auto"],
+    [AC_SUBST([CURSES_LOC])
+     AC_CHECK_HEADERS(
+        [ncurses/ncurses.h ncurses/curses.h ncursesw/curses.h ncurses.h curses.h],
+        [CURSES_LOC=$ac_header; break])
+     AS_IF(
+        [test -z "$CURSES_LOC"],
+        [AS_IF(
+            [test "$need_curses" = "yes"],
+            [AC_MSG_ERROR([could not find curses headers (frontends: mconf/nconf)])],
+            [has_curses=no])])
+     AC_SEARCH_LIBS(
+        [initscr],
+        [ncursesw ncurses curses],
+        [ac_ct_curses_lib_found=yes; break])
+     AS_IF(
+        [test -z "$ac_ct_curses_lib_found"],
+        [AS_IF(
+            [test "$need_curses" = "yes"],
+            [AC_MSG_ERROR([could not find curses library (frontends: mconf/nconf)])],
+            [has_curses=no])])])
+
+AS_IF(
+    [test "$has_curses" = "no" ],
+    [enable_mconf=no; enable_nconf=no])
+
+#----------------------------------------
+# Check for libpanel and libmenu, for the nconf frontend
+[need_panel_menu="$enable_nconf"]
+
 AS_IF(
-    [test -z "$CURSES_LOC"],
-    [AC_MSG_ERROR([could not find curses headers])])
-AC_SEARCH_LIBS(
-    [initscr],
-    [ncursesw ncurses curses],
-    [ac_ct_curses_lib_found=yes; break])
+    [test "$need_panel_menu" = "yes" -o "$need_panel_menu" = "auto"],
+    [AC_SEARCH_LIBS(
+        [new_panel],
+        [panel],
+        [ac_ct_panel_lib_found=yes; break])
+     AS_IF(
+        [test -z "$ac_ct_panel_lib_found"],
+        [AS_IF(
+            [test "$need_panel_menu" = "yes"],
+            [AC_MSG_ERROR([could not find libpanel library (frontend: nconf)])],
+            [has_panel_menu=no])])
+     AC_SEARCH_LIBS(
+        [menu_init],
+        [menu],
+        [ac_ct_menu_lib_found=yes; break])
+     AS_IF(
+        [test -z "$ac_ct_panel_lib_found"],
+        [AS_IF(
+            [test "$need_panel_menu" = "yes"],
+            [AC_MSG_ERROR([could not find libmenu library (frontend: nconf)])],
+            [has_panel_menu=no])])])
+
 AS_IF(
-    [test -z "$ac_ct_curses_lib_found"],
-    [AC_MSG_ERROR([could not find curses library])])
+    [test "$has_panel_menu" = "no" ],
+    [enable_nconf=no])
+
+#----------------------------------------
+# Check if the lxdialog library should be built
+AS_IF(
+    [test "$enable_mconf" = "yes" -o "$enable_mconf" = "auto"],
+    [need_lxdialog=yes],
+    [need_lxdialog=no])
 
 #----------------------------------------
 # Check pkg-config if needed
+AS_CASE(
+    ["$enable_gconf":"$enable_qconf"],
+    [yes:*],  [need_pkgconfig=yes],
+    [*:yes],  [need_pkgconfig=yes],
+    [auto:*], [need_pkgconfig=yes],
+    [*:auto], [need_pkgconfig=yes],
+              [need_pkgconfig=no ])
+
 AS_IF(
-    [test    "$enable_gconf" = "yes"    \
-          -o "$enable_qconf" = "yes"],
+    [test "$need_pkgconfig" = "yes"],
     [PKG_PROG_PKG_CONFIG()])
 
 #----------------------------------------
 # Check headers and libs for gconf
+[need_gtk="$enable_gconf"]
+
 AS_IF(
-    [test "$enable_gconf" = yes ],
+    [test "$need_gtk" = "yes" -o "$need_gtk" = "auto"],
     [PKG_CHECK_MODULES(
         [gtk],
-        [gtk+-2.0 gmodule-2.0 libglade-2.0])])
+        [gtk+-2.0 gmodule-2.0 libglade-2.0],
+        [has_gtk=yes],
+        [AS_IF(
+            [test "$need_gtk" = "yes"],
+            [AC_MSG_ERROR([could not find GTK+ headers and/or libraries (frontend: gconf)])],
+            [has_gtk=no])])])
+
+AS_IF(
+    [test "$has_gtk" = "no" ],
+    [enable_gconf=no])
 
 #----------------------------------------
 # Check headers and libs for gconf
+[need_qt="$enable_qconf"]
+
 AS_IF(
-    [test "$enable_qconf" = "yes"],
+    [test "$need_qt" = "yes" -o "$need_qt" = "auto"],
     [PKG_CHECK_MODULES(
         [qt4],
-        [QtCore QtGui Qt3Support])])
+        [QtCore QtGui Qt3Support],
+        [has_qt=yes],
+        [AS_IF(
+            [test "$need_qt" = "yes"],
+            [AC_MSG_ERROR([could not find QT4 headers and/or libraries (frontend: qconf)])],
+            [has_qt=no])])])
+
+AS_IF(
+    [test "$has_qt" = "no" ],
+    [enable_qconf=no])
+
+#---------------------------------------------------------------------------
+# Now, we know what frontends to enable
+AS_IF([test "$enable_conf"  = "auto"], [enable_conf=yes ])
+AS_IF([test "$enable_gconf" = "auto"], [enable_gconf=yes])
+AS_IF([test "$enable_mconf" = "auto"], [enable_mconf=yes])
+AS_IF([test "$enable_nconf" = "auto"], [enable_nconf=yes])
+AS_IF([test "$enable_qconf" = "auto"], [enable_qconf=yes])
 
 #---------------------------------------------------------------------------
 # Prepare automake
@@ -161,6 +258,19 @@ AM_CONDITIONAL(
 AM_CONDITIONAL(
     [COND_qconf],
     [test "$enable_qconf" = "yes"])
+AM_CONDITIONAL(
+    [COND_lxdialog],
+    [test "$need_lxdialog" = "yes"])
+
+#---------------------------------------------------------------------------
+# Prepare libtool
+LT_INIT([disable-static])
+
+#----------------------------------------
+# Get the version to apply to the parser shared library
+AC_SUBST(
+    [KCONFIGPARSER_LIB_VERSION],
+    [m4_esyscmd_s([./scripts/version.sh --plain])])
 
 #----------------------------------------
 # Finalise
@@ -177,3 +287,26 @@ AC_CONFIG_FILES([
     frontends/qconf/Makefile
 ])
 AC_OUTPUT
+
+AC_MSG_NOTICE([Configured with:])
+AC_MSG_NOTICE([- frontends:])
+AS_IF([test "$enable_conf" = "yes"],
+      [AC_MSG_NOTICE([  - conf:  yes])],
+      [AC_MSG_NOTICE([  - conf:  no])])
+AS_IF([test "$enable_gconf" = "yes"],
+      [AC_MSG_NOTICE([  - gconf: yes])],
+      [AC_MSG_NOTICE([  - gconf: no])])
+AS_IF([test "$enable_mconf" = "yes"],
+      [AC_MSG_NOTICE([  - mconf: yes])],
+      [AC_MSG_NOTICE([  - mconf: no])])
+AS_IF([test "$enable_nconf" = "yes"],
+      [AC_MSG_NOTICE([  - nconf: yes])],
+      [AC_MSG_NOTICE([  - nconf: no])])
+AS_IF([test "$enable_qconf" = "yes"],
+      [AC_MSG_NOTICE([  - qconf: yes])],
+      [AC_MSG_NOTICE([  - qconf: no])])
+AC_MSG_NOTICE([- parser library:])
+AS_IF([test "$enable_shared" = "yes"],
+      [AC_MSG_NOTICE([  - shared: yes, versioned $KCONFIGPARSER_LIB_VERSION])],
+      [AC_MSG_NOTICE([  - shared: no])])
+AC_MSG_NOTICE([  - static: $enable_static])