summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGregory P. Smith <greg@mad-scientist.com>2008-09-07 05:15:18 (GMT)
committerGregory P. Smith <greg@mad-scientist.com>2008-09-07 05:15:18 (GMT)
commit980b99b5299fb2361932da60a95ae7c54ddc68e7 (patch)
treed8501221c81eb5ea9aab732b07768b26e41edc75
parentb7a841ca40609dfc935555716de0471cff7ec03f (diff)
downloadcpython-980b99b5299fb2361932da60a95ae7c54ddc68e7.zip
cpython-980b99b5299fb2361932da60a95ae7c54ddc68e7.tar.gz
cpython-980b99b5299fb2361932da60a95ae7c54ddc68e7.tar.bz2
- Issue #1204: The configure script now tests for additional libraries
that may be required when linking against readline. This fixes issues with x86_64 builds on some platforms (at least a few Linux flavors as well as OpenBSD/amd64).
-rw-r--r--Misc/NEWS4
-rw-r--r--configure.in36
-rw-r--r--pyconfig.h.in3
3 files changed, 33 insertions, 10 deletions
diff --git a/Misc/NEWS b/Misc/NEWS
index 83bbd49..6c22cd8 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -48,6 +48,10 @@ Core and Builtins
- Issue #3678: Correctly pass LDFLAGS and LDLAST to the linker on shared
library targets in the Makefile.
+- Issue #1204: The configure script now tests for additional libraries
+ that may be required when linking against readline. This fixes issues
+ with x86_64 builds on some platforms (a few Linux flavors and OpenBSD).
+
C-API
-----
diff --git a/configure.in b/configure.in
index ee99597..8fa9ad7 100644
--- a/configure.in
+++ b/configure.in
@@ -251,14 +251,12 @@ case $ac_sys_system/$ac_sys_release in
# On OpenBSD, select(2) is not available if _XOPEN_SOURCE is defined,
# even though select is a POSIX function. Reported by J. Ribbens.
# Reconfirmed for OpenBSD 3.3 by Zachary Hamm, for 3.4 by Jason Ish.
- OpenBSD*)
+ OpenBSD/2.* | OpenBSD/3.@<:@0123456789@:>@ | OpenBSD/4.@<:@0123@:>@)
define_xopen_source=no
# OpenBSD undoes our definition of __BSD_VISIBLE if _XOPEN_SOURCE is
# also defined. This can be overridden by defining _BSD_SOURCE
# As this has a different meaning on Linux, only define it on OpenBSD
AC_DEFINE(_BSD_SOURCE, 1, [Define on OpenBSD to activate all library features])
- # OpenBSD's readline library needs the libcurses
- READLINE_LIBS="-lcurses"
;;
# Defining _XOPEN_SOURCE on NetBSD version prior to the introduction of
# _NETBSD_SOURCE disables certain features (eg. setgroups). Reported by
@@ -3326,10 +3324,34 @@ fi
# check where readline lives
# save the value of LIBS so we don't actually link Python with readline
LIBS_no_readline=$LIBS
-AC_CHECK_LIB(readline, readline, , ,$READLINE_LIBS)
-if test "$ac_cv_have_readline_readline" = no
-then
- AC_CHECK_LIB(termcap, readline)
+
+# On some systems we need to link readline to a termcap compatible
+# library. NOTE: Keep the precedence of listed libraries synchronised
+# with setup.py.
+py_cv_lib_readline=no
+AC_MSG_CHECKING([how to link readline libs])
+for py_libtermcap in "" ncursesw ncurses curses termcap; do
+ if test -z "$py_libtermcap"; then
+ READLINE_LIBS="-lreadline"
+ else
+ READLINE_LIBS="-lreadline -l$py_libtermcap"
+ fi
+ LIBS="$READLINE_LIBS $LIBS_no_readline"
+ AC_LINK_IFELSE(
+ [AC_LANG_CALL([],[readline])],
+ [py_cv_lib_readline=yes])
+ if test $py_cv_lib_readline = yes; then
+ break
+ fi
+done
+# Uncomment this line if you want to use READINE_LIBS in Makefile or scripts
+#AC_SUBST([READLINE_LIBS])
+if test $py_cv_lib_readline = !yes; then
+ AC_MSG_RESULT([none])
+else
+ AC_MSG_RESULT([$READLINE_LIBS])
+ AC_DEFINE(HAVE_LIBREADLINE, 1,
+ [Define if you have the readline library (-lreadline).])
fi
# check for readline 2.1
diff --git a/pyconfig.h.in b/pyconfig.h.in
index 1c2d377..852e671 100644
--- a/pyconfig.h.in
+++ b/pyconfig.h.in
@@ -366,9 +366,6 @@
/* Define to 1 if you have the `resolv' library (-lresolv). */
#undef HAVE_LIBRESOLV
-/* Define to 1 if you have the `termcap' library (-ltermcap). */
-#undef HAVE_LIBTERMCAP
-
/* Define to 1 if you have the <libutil.h> header file. */
#undef HAVE_LIBUTIL_H