This is the mail archive of the
gdb-patches@sourceware.org
mailing list for the GDB project.
Re: [PATCH v2 01/36] Guile extension language: configure changes
- From: Doug Evans <xdje42 at gmail dot com>
- To: Joel Brobecker <brobecker at adacore dot com>
- Cc: ludo at gnu dot org, gdb-patches at sourceware dot org
- Date: Mon, 10 Feb 2014 23:16:02 -0800
- Subject: Re: [PATCH v2 01/36] Guile extension language: configure changes
- Authentication-results: sourceware.org; auth=none
- References: <52dd9a9a dot 488b440a dot 4678 dot 03e6 at mx dot google dot com> <m3y51j8r62 dot fsf at sspiff dot org> <20140210102342 dot GA7151 at adacore dot com> <m3zjly7uaa dot fsf at sspiff dot org>
Doug Evans <xdje42@gmail.com> writes:
> Joel Brobecker <brobecker@adacore.com> writes:
>
>> Hi Doug,
>>
>>> +AC_PATH_PROG(pkg_config_prog_path, pkg-config, missing)
>> [...]
>>> +AC_DEFUN([AC_TRY_LIBGUILE],
>>> +[
>>> + pkg_config=$1
>>> + guile_version_list=$2
>>> + flag_errors=$3
>>> + define([have_libguile_var],$4)
>>> + if test "${pkg_config}" = "missing"; then
>>> + AC_ERROR(pkg-config program not found)
>>> + fi
>>> + if test ! -f "${pkg_config}"; then
>>> + AC_ERROR(pkg-config program ${pkg_config} not found)
>>> + fi
>>
>> I don't think we should error if pkg-config was not found and --with-guile
>> was left to "auto". This is going to break the build of many of us
>> who work on systems that don't have that tool installed (I've just
>> noticed that on Windows). Intead, let's disable guile support
>> when that happens.
>>
>> For the second error, I think we should apply the same principle.
>
> Indeed!
> The only combination I didn't test (removing pkg-config)...
>
>> Can you adjust that part, please?
>>
>> Thank you,
Here's what I committed.
I'll look into redoing this with pkg-config autoconf support.
2014-02-11 Doug Evans <xdje42@gmail.com>
* configure.ac: Don't crash if pkg-config is not found and guile
wasn't explicitly requested. Use AC_MSG_ERROR instead of AC_ERROR
in guile checks.
* configure: Regenerate.
diff --git a/gdb/configure.ac b/gdb/configure.ac
index 73decd0..494d711 100644
--- a/gdb/configure.ac
+++ b/gdb/configure.ac
@@ -1058,10 +1058,6 @@ AC_SUBST(PYTHON_LIBS)
# Check for libguile. #
# -------------------- #
-dnl We check guile with pkg-config.
-
-AC_PATH_PROG(pkg_config_prog_path, pkg-config, missing)
-
dnl Utility to simplify finding libguile.
dnl $1 = pkg-config-program
dnl $2 = space-separate list of guile versions to try
@@ -1075,12 +1071,6 @@ AC_DEFUN([AC_TRY_LIBGUILE],
guile_version_list=$2
flag_errors=$3
define([have_libguile_var],$4)
- if test "${pkg_config}" = "missing"; then
- AC_ERROR(pkg-config program not found)
- fi
- if test ! -f "${pkg_config}"; then
- AC_ERROR(pkg-config program ${pkg_config} not found)
- fi
found_usable_guile=checking
AC_MSG_CHECKING([for usable guile from ${pkg_config}])
for guile_version in ${guile_version_list}; do
@@ -1092,11 +1082,11 @@ AC_DEFUN([AC_TRY_LIBGUILE],
dnl that's bad.
new_CPPFLAGS=`${pkg_config} --cflags ${guile_version}`
if test $? != 0; then
- AC_ERROR(failure running pkg-config --cflags ${guile_version})
+ AC_MSG_ERROR([failure running pkg-config --cflags ${guile_version}])
fi
new_LIBS=`${pkg_config} --libs ${guile_version}`
if test $? != 0; then
- AC_ERROR(failure running pkg-config --libs ${guile_version})
+ AC_MSG_ERROR([failure running pkg-config --libs ${guile_version}])
fi
dnl If we get this far, great.
found_usable_guile=${guile_version}
@@ -1104,7 +1094,7 @@ AC_DEFUN([AC_TRY_LIBGUILE],
done
if test "${found_usable_guile}" = "checking"; then
if test "${flag_errors}" = "yes"; then
- AC_ERROR(unable to find usable guile version from "${guile_version_list}")
+ AC_MSG_ERROR([unable to find usable guile version from "${guile_version_list}"])
else
found_usable_guile=no
fi
@@ -1126,7 +1116,7 @@ AC_DEFUN([AC_TRY_LIBGUILE],
LIBS=$save_LIBS
if test "${found_usable_guile}" = no; then
if test "${flag_errors}" = yes; then
- AC_MSG_FAILURE(linking guile version ${guile_version} test program failed)
+ AC_MSG_FAILURE([linking guile version ${guile_version} test program failed])
fi
fi
fi
@@ -1161,6 +1151,9 @@ AC_ARG_WITH(guile,
AC_MSG_CHECKING([whether to use guile])
AC_MSG_RESULT([$with_guile])
+dnl We check guile with pkg-config.
+AC_PATH_PROG(pkg_config_prog_path, pkg-config, missing)
+
try_guile_versions="guile-2.0"
have_libguile=no
case "${with_guile}" in
@@ -1168,20 +1161,34 @@ no)
AC_MSG_WARN([guile support disabled; some features will be unavailable.])
;;
auto)
- AC_TRY_LIBGUILE(${pkg_config_prog_path}, ${try_guile_versions}, no, have_libguile)
+ if test "${pkg_config_prog_path}" = "missing"; then
+ AC_MSG_WARN([pkg-config not found, guile support disabled])
+ else
+ AC_TRY_LIBGUILE(${pkg_config_prog_path}, ${try_guile_versions}, no, have_libguile)
+ fi
;;
yes)
+ if test "${pkg_config_prog_path}" = "missing"; then
+ AC_MSG_ERROR([pkg-config not found])
+ fi
AC_TRY_LIBGUILE(${pkg_config_prog_path}, ${try_guile_versions}, yes, have_libguile)
;;
[[\\/]]* | ?:[[\\/]]*)
- AC_TRY_LIBGUILE(${with_guile}, ${try_guile_versions}, yes, have_libguile)
+ if test -x "${with_guile}"; then
+ AC_TRY_LIBGUILE(${with_guile}, ${try_guile_versions}, yes, have_libguile)
+ else
+ AC_MSG_ERROR([Guile config program not executable: ${with_guile}])
+ fi
;;
"" | */*)
# Disallow --with=guile="" and --with-guile=foo/bar.
- AC_ERROR(invalid value for --with-guile)
+ AC_MSG_ERROR([invalid value for --with-guile])
;;
*)
# A space separate list of guile versions to try, in order.
+ if test "${pkg_config_prog_path}" = "missing"; then
+ AC_MSG_ERROR([pkg-config not found])
+ fi
AC_TRY_LIBGUILE(${pkg_config_prog_path}, ${with_guile}, yes, have_libguile)
;;
esac