Skip to content

Commit

Permalink
visibility: Use a separate CFLAGS variable
Browse files Browse the repository at this point in the history
We only want to control the default visibility for our five main
installable libraries: libglib, libgthread, libgmodule, libgobject,
libgio.  We should therefore only set -fvisibility=hidden when building
those.

Use a separate substitution variable for this purpose.

Using CFLAGS directly leads to some modules built in testcases not
exporting their symbols (and then the tests fail).  It also affects the
fam file monitoring module.

Colin had originally done it this way in his visibility patch series but
I failed to understand why so I didn't copy it.  Now I do.

Also: revert changes made to two testcases in an attempt to work around
this issue.

https://bugzilla.gnome.org/show_bug.cgi?id=691756
  • Loading branch information
allisonkarlitskaya committed Jan 15, 2013
1 parent 7e00f38 commit 5d42fdd
Show file tree
Hide file tree
Showing 10 changed files with 30 additions and 35 deletions.
4 changes: 3 additions & 1 deletion configure.ac
Original file line number Diff line number Diff line change
Expand Up @@ -3570,6 +3570,7 @@ dnl
dnl Check for -fvisibility=hidden to determine if we can do GNU-style
dnl visibility attributes for symbol export control
dnl
GLIB_HIDDEN_VISIBILITY_CFLAGS=""
case "$host" in
*-*-mingw*)
dnl on mingw32 we do -fvisibility=hidden and __declspec(dllexport)
Expand All @@ -3592,10 +3593,11 @@ case "$host" in
AS_IF([test "${enable_fvisibility_hidden}" = "yes"], [
AC_DEFINE([_GLIB_EXTERN], [__attribute__((visibility("default"))) extern],
[defines how to decorate public symbols while building])
CFLAGS="${CFLAGS} -fvisibility=hidden"
GLIB_HIDDEN_VISIBILITY_CFLAGS="-fvisibility=hidden"
])
;;
esac
AC_SUBST(GLIB_HIDDEN_VISIBILITY_CFLAGS)

dnl Compiler flags; macro originates from systemd
dnl See https://bugzilla.gnome.org/show_bug.cgi?id=608953
Expand Down
3 changes: 2 additions & 1 deletion gio/Makefile.am
Original file line number Diff line number Diff line change
Expand Up @@ -501,14 +501,15 @@ install-data-local: install-ms-lib

uninstall-local: uninstall-ms-lib

libgio_2_0_la_CFLAGS = $(AM_CFLAGS) $(GLIB_HIDDEN_VISIBILITY_CFLAGS)
libgio_2_0_la_LDFLAGS = $(GLIB_LINK_FLAGS) \
$(gio_win32_res_ldflag) \
-version-info $(LT_CURRENT):$(LT_REVISION):$(LT_AGE) \
-export-dynamic $(no_undefined) $(export_symbols)

if OS_COCOA
# This is dumb. The ObjC source file should be properly named .m
libgio_2_0_la_CFLAGS = -xobjective-c
libgio_2_0_la_CFLAGS += -xobjective-c
libgio_2_0_la_LDFLAGS += -Wl,-framework,Foundation
endif

Expand Down
8 changes: 3 additions & 5 deletions gio/tests/resourceplugin.c
Original file line number Diff line number Diff line change
@@ -1,18 +1,16 @@
#include "config.h"

#include <gio/gio.h>

_GLIB_EXTERN void
void
g_io_module_load (GIOModule *module)
{
}

_GLIB_EXTERN void
void
g_io_module_unload (GIOModule *module)
{
}

_GLIB_EXTERN char **
char **
g_io_module_query (void)
{
return NULL;
Expand Down
1 change: 1 addition & 0 deletions glib/Makefile.am
Original file line number Diff line number Diff line change
Expand Up @@ -360,6 +360,7 @@ pcre_lib = pcre/libpcre.la
pcre_inc =
endif

libglib_2_0_la_CFLAGS = $(AM_CFLAGS) $(GLIB_HIDDEN_VISIBILITY_CFLAGS)
libglib_2_0_la_LIBADD = libcharset/libcharset.la $(printf_la) @GIO@ @GSPAWN@ @PLATFORMDEP@ @ICONV_LIBS@ @G_LIBS_EXTRA@ $(pcre_lib) $(G_THREAD_LIBS_EXTRA) $(G_THREAD_LIBS_FOR_GTHREAD)
libglib_2_0_la_DEPENDENCIES = libcharset/libcharset.la $(printf_la) @GIO@ @GSPAWN@ @PLATFORMDEP@ $(glib_win32_res) $(glib_def)

Expand Down
1 change: 1 addition & 0 deletions gmodule/Makefile.am
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,7 @@ gmodule_win32_res = gmodule-win32-res.o
gmodule_win32_res_ldflag = -Wl,$(gmodule_win32_res)
endif

libgmodule_2_0_la_CFLAGS = $(AM_CFLAGS) $(GLIB_HIDDEN_VISIBILITY_CFLAGS)
libgmodule_2_0_la_SOURCES = gmodule.c
libgmodule_2_0_la_LDFLAGS = $(GLIB_LINK_FLAGS) \
$(gmodule_win32_res_ldflag) \
Expand Down
2 changes: 1 addition & 1 deletion gobject/Makefile.am
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ libgobject_2_0_la_LDFLAGS = $(GLIB_LINK_FLAGS) \
-version-info $(LT_CURRENT):$(LT_REVISION):$(LT_AGE) \
-export-dynamic $(no_undefined) $(export_symbols)

libgobject_2_0_la_CFLAGS = $(LIBFFI_CFLAGS)
libgobject_2_0_la_CFLAGS = $(AM_CFLAGS) $(LIBFFI_CFLAGS) $(GLIB_HIDDEN_VISIBILITY_CFLAGS)

libgobject_2_0_la_LIBADD = $(libglib) $(LIBFFI_LIBS)

Expand Down
1 change: 1 addition & 0 deletions gthread/Makefile.am
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,7 @@ gthread_win32_res = gthread-win32-res.o
gthread_win32_res_ldflag = -Wl,$(gthread_win32_res)
endif

libgthread_2_0_la_CFLAGS = $(AM_CFLAGS) $(GLIB_HIDDEN_VISIBILITY_CFLAGS)
libgthread_2_0_la_SOURCES = gthread-impl.c
libgthread_2_0_la_LDFLAGS = $(GLIB_LINK_FLAGS) \
$(gthread_win32_res_ldflag) \
Expand Down
20 changes: 8 additions & 12 deletions tests/libmoduletestplugin_a.c
Original file line number Diff line number Diff line change
Expand Up @@ -27,46 +27,42 @@
#undef G_DISABLE_ASSERT
#undef G_LOG_DOMAIN

#include "config.h"

#include <glib.h>
#include <gmodule.h>
#include <stdlib.h>
#include <gmodule.h>
#include <stdlib.h>

void gplugin_a_func (void);
void gplugin_clash_func (void);
void g_clash_func (void);
void gplugin_say_boo_func (void);
void gplugin_a_module_func (GModule *module);

_GLIB_EXTERN gchar* gplugin_a_state;
gchar* gplugin_a_state;
G_MODULE_EXPORT gchar* gplugin_a_state;

_GLIB_EXTERN void
G_MODULE_EXPORT void
gplugin_a_func (void)
{
gplugin_a_state = "Hello world";
}

_GLIB_EXTERN void
G_MODULE_EXPORT void
gplugin_clash_func (void)
{
gplugin_a_state = "plugin clash";
}

_GLIB_EXTERN void
G_MODULE_EXPORT void
g_clash_func (void)
{
gplugin_a_state = "global clash";
}

_GLIB_EXTERN void
G_MODULE_EXPORT void
gplugin_say_boo_func (void)
{
gplugin_a_state = "BOOH";
}

_GLIB_EXTERN void
G_MODULE_EXPORT void
gplugin_a_module_func (GModule *module)
{
void *f = NULL;
Expand Down
19 changes: 8 additions & 11 deletions tests/libmoduletestplugin_b.c
Original file line number Diff line number Diff line change
Expand Up @@ -27,12 +27,9 @@
#undef G_DISABLE_ASSERT
#undef G_LOG_DOMAIN

#include "config.h"
#include <gmodule.h>

#include <gmodule.h>

_GLIB_EXTERN gchar* gplugin_b_state;
gchar* gplugin_b_state;
G_MODULE_EXPORT gchar* gplugin_b_state;

const gchar* g_module_check_init (GModule *module);
void g_module_unload (GModule *module);
Expand All @@ -42,39 +39,39 @@ void gplugin_clash_func (void);
void g_clash_func (void);
void gplugin_say_boo_func (void);

_GLIB_EXTERN const gchar*
G_MODULE_EXPORT const gchar*
g_module_check_init (GModule *module)
{
gplugin_b_state = "check-init";

return NULL;
}

_GLIB_EXTERN void
G_MODULE_EXPORT void
g_module_unload (GModule *module)
{
gplugin_b_state = "unloaded";
}

_GLIB_EXTERN void
G_MODULE_EXPORT void
gplugin_b_func (void)
{
gplugin_b_state = "Hello world";
}

_GLIB_EXTERN void
G_MODULE_EXPORT void
gplugin_clash_func (void)
{
gplugin_b_state = "plugin clash";
}

_GLIB_EXTERN void
G_MODULE_EXPORT void
g_clash_func (void)
{
gplugin_b_state = "global clash";
}

_GLIB_EXTERN void
G_MODULE_EXPORT void
gplugin_say_boo_func (void)
{
gplugin_b_state = "BOOH";
Expand Down
6 changes: 2 additions & 4 deletions tests/module-test.c
Original file line number Diff line number Diff line change
Expand Up @@ -27,16 +27,14 @@
#undef G_DISABLE_ASSERT
#undef G_LOG_DOMAIN

#include "config.h"

#include <gmodule.h>
#include <string.h>

gchar* global_state;

_GLIB_EXTERN void g_clash_func (void);
G_MODULE_EXPORT void g_clash_func (void);

_GLIB_EXTERN void
G_MODULE_EXPORT void
g_clash_func (void)
{
global_state = "global clash";
Expand Down

0 comments on commit 5d42fdd

Please sign in to comment.