mirror of
https://github.com/sudo-project/sudo.git
synced 2025-08-22 01:49:11 +00:00
Move gettext checks to m4/gettext.m4
This commit is contained in:
parent
12da6bd0ce
commit
38ffd03cd6
1
MANIFEST
1
MANIFEST
@ -425,6 +425,7 @@ m4/ax_check_link_flag.m4
|
||||
m4/ax_func_getaddrinfo.m4
|
||||
m4/ax_func_snprintf.m4
|
||||
m4/ax_prog_cc_for_build.m4
|
||||
m4/gettext.m4
|
||||
m4/hardening.m4
|
||||
m4/ldap.m4
|
||||
m4/libtool.m4
|
||||
|
1
aclocal.m4
vendored
1
aclocal.m4
vendored
@ -18,6 +18,7 @@ m4_include([m4/ax_check_link_flag.m4])
|
||||
m4_include([m4/ax_func_getaddrinfo.m4])
|
||||
m4_include([m4/ax_func_snprintf.m4])
|
||||
m4_include([m4/ax_prog_cc_for_build.m4])
|
||||
m4_include([m4/gettext.m4])
|
||||
m4_include([m4/hardening.m4])
|
||||
m4_include([m4/ldap.m4])
|
||||
m4_include([m4/libtool.m4])
|
||||
|
2
configure
vendored
2
configure
vendored
@ -27286,6 +27286,7 @@ printf "%s\n" "#define __func__ __FUNCTION__" >>confdefs.h
|
||||
fi
|
||||
fi
|
||||
|
||||
|
||||
# gettext() and friends may be located in libc (Linux and Solaris)
|
||||
# or in libintl. However, it is possible to have libintl installed
|
||||
# even when gettext() is present in libc. In the case of GNU libintl,
|
||||
@ -27490,6 +27491,7 @@ fi
|
||||
fi
|
||||
fi
|
||||
|
||||
|
||||
case "$enable_zlib" in
|
||||
yes)
|
||||
{ printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for gzclearerr in -lz" >&5
|
||||
|
60
configure.ac
60
configure.ac
@ -3253,65 +3253,7 @@ elif test -n "$GCC"; then
|
||||
fi
|
||||
fi
|
||||
|
||||
# gettext() and friends may be located in libc (Linux and Solaris)
|
||||
# or in libintl. However, it is possible to have libintl installed
|
||||
# even when gettext() is present in libc. In the case of GNU libintl,
|
||||
# gettext() will be defined to gettext_libintl in libintl.h.
|
||||
# Since gcc prefers /usr/local/include to /usr/include, we need to
|
||||
# make sure we use the gettext() that matches the include file.
|
||||
if test "$enable_nls" != "no"; then
|
||||
if test "$enable_nls" != "yes"; then
|
||||
AX_APPEND_FLAG([-I${enable_nls}/include], [CPPFLAGS])
|
||||
SUDO_APPEND_LIBPATH(LDFLAGS, [$enable_nls/lib])
|
||||
fi
|
||||
OLIBS="$LIBS"
|
||||
for l in "libc" "-lintl" "-lintl -liconv"; do
|
||||
if test "$l" = "libc"; then
|
||||
# If user specified a dir for libintl ignore libc
|
||||
if test "$enable_nls" != "yes"; then
|
||||
continue
|
||||
fi
|
||||
gettext_name=sudo_cv_gettext
|
||||
AC_MSG_CHECKING([for gettext])
|
||||
else
|
||||
LIBS="$OLIBS $l"
|
||||
gettext_name=sudo_cv_gettext"`echo $l|sed -e 's/ //g' -e 's/-/_/g'`"
|
||||
AC_MSG_CHECKING([for gettext in $l])
|
||||
fi
|
||||
AC_CACHE_VAL($gettext_name, [
|
||||
AC_LINK_IFELSE(
|
||||
[
|
||||
AC_LANG_PROGRAM([[#include <libintl.h>]], [(void)gettext((char *)0);])
|
||||
], [eval $gettext_name=yes], [eval $gettext_name=no]
|
||||
)
|
||||
])
|
||||
eval gettext_result="\$$gettext_name"
|
||||
AC_MSG_RESULT($gettext_result)
|
||||
if test "$gettext_result" = "yes"; then
|
||||
AC_CHECK_FUNCS([ngettext])
|
||||
break
|
||||
fi
|
||||
done
|
||||
LIBS="$OLIBS"
|
||||
|
||||
if test "$sudo_cv_gettext" = "yes"; then
|
||||
SUDO_NLS=enabled
|
||||
# For Solaris we need links from lang to lang.UTF-8 in localedir
|
||||
case "$host_os" in
|
||||
solaris2*) LOCALEDIR_SUFFIX=".UTF-8";;
|
||||
esac
|
||||
elif test "$sudo_cv_gettext_lintl" = "yes"; then
|
||||
SUDO_NLS=enabled
|
||||
LIBINTL="-lintl"
|
||||
elif test "$sudo_cv_gettext_lintl_liconv" = "yes"; then
|
||||
SUDO_NLS=enabled
|
||||
LIBINTL="-lintl -liconv"
|
||||
fi
|
||||
if test X"$SUDO_NLS" = X"enabled"; then
|
||||
AC_DEFINE(HAVE_LIBINTL_H)
|
||||
SUDO_APPEND_COMPAT_EXP(sudo_warn_gettext_v1)
|
||||
fi
|
||||
fi
|
||||
SUDO_CHECK_GETTEXT
|
||||
|
||||
dnl
|
||||
dnl Deferred zlib option processing.
|
||||
|
61
m4/gettext.m4
Normal file
61
m4/gettext.m4
Normal file
@ -0,0 +1,61 @@
|
||||
AC_DEFUN([SUDO_CHECK_GETTEXT], [
|
||||
# gettext() and friends may be located in libc (Linux and Solaris)
|
||||
# or in libintl. However, it is possible to have libintl installed
|
||||
# even when gettext() is present in libc. In the case of GNU libintl,
|
||||
# gettext() will be defined to gettext_libintl in libintl.h.
|
||||
# Since gcc prefers /usr/local/include to /usr/include, we need to
|
||||
# make sure we use the gettext() that matches the include file.
|
||||
if test "$enable_nls" != "no"; then
|
||||
if test "$enable_nls" != "yes"; then
|
||||
AX_APPEND_FLAG([-I${enable_nls}/include], [CPPFLAGS])
|
||||
SUDO_APPEND_LIBPATH(LDFLAGS, [$enable_nls/lib])
|
||||
fi
|
||||
OLIBS="$LIBS"
|
||||
for l in "libc" "-lintl" "-lintl -liconv"; do
|
||||
if test "$l" = "libc"; then
|
||||
# If user specified a dir for libintl ignore libc
|
||||
if test "$enable_nls" != "yes"; then
|
||||
continue
|
||||
fi
|
||||
gettext_name=sudo_cv_gettext
|
||||
AC_MSG_CHECKING([for gettext])
|
||||
else
|
||||
LIBS="$OLIBS $l"
|
||||
gettext_name=sudo_cv_gettext"`echo $l|sed -e 's/ //g' -e 's/-/_/g'`"
|
||||
AC_MSG_CHECKING([for gettext in $l])
|
||||
fi
|
||||
AC_CACHE_VAL($gettext_name, [
|
||||
AC_LINK_IFELSE(
|
||||
[
|
||||
AC_LANG_PROGRAM([[#include <libintl.h>]], [(void)gettext((char *)0);])
|
||||
], [eval $gettext_name=yes], [eval $gettext_name=no]
|
||||
)
|
||||
])
|
||||
eval gettext_result="\$$gettext_name"
|
||||
AC_MSG_RESULT($gettext_result)
|
||||
if test "$gettext_result" = "yes"; then
|
||||
AC_CHECK_FUNCS([ngettext])
|
||||
break
|
||||
fi
|
||||
done
|
||||
LIBS="$OLIBS"
|
||||
|
||||
if test "$sudo_cv_gettext" = "yes"; then
|
||||
SUDO_NLS=enabled
|
||||
# For Solaris we need links from lang to lang.UTF-8 in localedir
|
||||
case "$host_os" in
|
||||
solaris2*) LOCALEDIR_SUFFIX=".UTF-8";;
|
||||
esac
|
||||
elif test "$sudo_cv_gettext_lintl" = "yes"; then
|
||||
SUDO_NLS=enabled
|
||||
LIBINTL="-lintl"
|
||||
elif test "$sudo_cv_gettext_lintl_liconv" = "yes"; then
|
||||
SUDO_NLS=enabled
|
||||
LIBINTL="-lintl -liconv"
|
||||
fi
|
||||
if test X"$SUDO_NLS" = X"enabled"; then
|
||||
AC_DEFINE(HAVE_LIBINTL_H)
|
||||
SUDO_APPEND_COMPAT_EXP(sudo_warn_gettext_v1)
|
||||
fi
|
||||
fi
|
||||
])
|
Loading…
x
Reference in New Issue
Block a user