From 2b0bad889a3fc473295dd4548942bb5f42752f84 Mon Sep 17 00:00:00 2001 From: David Adam Date: Sat, 26 Nov 2016 22:51:44 +0800 Subject: [PATCH] configure: force use of `-pthread` on Solaris This fixes a problem with non-threadsafe errno. Ideally, this would be the use of the AX_PTHREAD macro, but it is GPL 3+ only, which is incompatible with the GPL 2 license of fish. It also would need extending to cover C++. For now, fish doesn't build on anything except GCC under Solaris anyway, so `-pthread` is the right thing to use. Work on #3340. --- configure.ac | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/configure.ac b/configure.ac index 0489da9c5..a8bf7b29c 100644 --- a/configure.ac +++ b/configure.ac @@ -110,7 +110,7 @@ AX_CXX_COMPILE_STDCXX_11(noext,mandatory) # Tell autoconf to create config.h header # AC_CONFIG_HEADERS(config.h) -AC_CANONICAL_TARGET +AC_CANONICAL_HOST # @@ -250,6 +250,18 @@ AC_CHECK_FILES([/proc/self/stat]) AC_DEFINE([NCURSES_NOMACROS], [1], [Define to 1 to disable ncurses macros that conflict with the STL]) AC_DEFINE([NOMACROS], [1], [Define to 1 to disable curses macros that conflict with the STL]) +# Threading is excitingly broken on Solaris without adding -pthread to CXXFLAGS +# Only support GCC for now +dnl Ideally we would use the AX_PTHREAD macro here, but it's GPL3-licensed +dnl ACX_PTHREAD is way too old and seems to break the OS X build +dnl Both only check with AC_LANG(C) in any case +case $host_os in + solaris*) + CXXFLAGS="$CXXFLAGS -pthread" + CFLAGS="$CFLAGS -pthread" + ;; +esac + # # Check presense of various libraries. This is done on a per-binary # level, since including various extra libraries in all binaries only