diff options
author | Bruno Haible <bruno@clisp.org> | 2005-07-27 11:23:13 +0000 |
---|---|---|
committer | Bruno Haible <bruno@clisp.org> | 2009-06-23 12:12:42 +0200 |
commit | 3236af7163ddf0dda162f0d99f120a9eb9382540 (patch) | |
tree | 8e2e1cc5d9f04f535b215fcc44cab4f8b5a52af5 /gettext-runtime | |
parent | f4cf6ba852adb186af0abf4d07158d17135def44 (diff) | |
download | external_gettext-3236af7163ddf0dda162f0d99f120a9eb9382540.zip external_gettext-3236af7163ddf0dda162f0d99f120a9eb9382540.tar.gz external_gettext-3236af7163ddf0dda162f0d99f120a9eb9382540.tar.bz2 |
Control exported symbols.
Diffstat (limited to 'gettext-runtime')
-rw-r--r-- | gettext-runtime/intl/export.h | 6 | ||||
-rw-r--r-- | gettext-runtime/m4/visibility.m4 | 52 |
2 files changed, 58 insertions, 0 deletions
diff --git a/gettext-runtime/intl/export.h b/gettext-runtime/intl/export.h new file mode 100644 index 0000000..b5c47ad --- /dev/null +++ b/gettext-runtime/intl/export.h @@ -0,0 +1,6 @@ + +#if @HAVE_VISIBILITY@ && BUILDING_LIBINTL +#define LIBINTL_DLL_EXPORTED __attribute__((__visibility__("default"))) +#else +#define LIBINTL_DLL_EXPORTED +#endif diff --git a/gettext-runtime/m4/visibility.m4 b/gettext-runtime/m4/visibility.m4 new file mode 100644 index 0000000..2ff6330 --- /dev/null +++ b/gettext-runtime/m4/visibility.m4 @@ -0,0 +1,52 @@ +# visibility.m4 serial 1 (gettext-0.15) +dnl Copyright (C) 2005 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Bruno Haible. + +dnl Tests whether the compiler supports the command-line option +dnl -fvisibility=hidden and the function and variable attributes +dnl __attribute__((__visibility__("hidden"))) and +dnl __attribute__((__visibility__("default"))). +dnl Does *not* test for __visibility__("protected") - which has tricky +dnl semantics (see the 'vismain' test in glibc) and does not exist e.g. on +dnl MacOS X. +dnl Does *not* test for __visibility__("internal") - which has processor +dnl dependent semantics. +dnl Does *not* test for #pragma GCC visibility push(hidden) - which is +dnl "really only recommended for legacy code". +dnl Set the variable CFLAG_VISIBILITY. +dnl Defines and sets the variable HAVE_VISIBILITY. + +AC_DEFUN([gl_VISIBILITY], +[ + AC_REQUIRE([AC_PROG_CC]) + CFLAG_VISIBILITY= + HAVE_VISIBILITY=0 + if test -n "$GCC"; then + AC_MSG_CHECKING([for simple visibility declarations]) + AC_CACHE_VAL(gl_cv_cc_visibility, [ + gl_save_CFLAGS="$CFLAGS" + CFLAGS="$CFLAGS -fvisibility=hidden" + AC_TRY_COMPILE( + [extern __attribute__((__visibility__("hidden"))) int hiddenvar; + extern __attribute__((__visibility__("default"))) int exportedvar; + extern __attribute__((__visibility__("hidden"))) int hiddenfunc (void); + extern __attribute__((__visibility__("default"))) int exportedfunc (void);], + [], + gl_cv_cc_visibility=yes, + gl_cv_cc_visibility=no) + CFLAGS="$gl_save_CFLAGS"]) + AC_MSG_RESULT([$gl_cv_cc_visibility]) + if test $gl_cv_cc_visibility = yes; then + CFLAG_VISIBILITY="-fvisibility=hidden" + HAVE_VISIBILITY=1 + fi + fi + AC_SUBST([CFLAG_VISIBILITY]) + AC_SUBST([HAVE_VISIBILITY]) + AC_DEFINE_UNQUOTED([HAVE_VISIBILITY], [$HAVE_VISIBILITY], + [Define to 1 or 0, depending whether the compiler supports simple visibility declarations.]) +]) |