mirror of
				https://gitlab.gnome.org/GNOME/glib.git
				synced 2025-10-25 14:32:16 +02:00 
			
		
		
		
	Sat Sep 30 2006 Matthias Clasen <mclasen@redhat.com>
* pltcheck.sh: Script to check PLT entries.
        * Makefile.am (TESTS): Run pltcheck.sh
        * gtype.c:
        * gsignal.c:
        * gobject.c:
        * gvaluetypes.c: Move all includes before gobjectalias.h.
        (#3545422, Behdad Esfahbod)
			
			
This commit is contained in:
		| @@ -1,3 +1,15 @@ | |||||||
|  | Sat Sep 30 2006  Matthias Clasen  <mclasen@redhat.com> | ||||||
|  |  | ||||||
|  | 	* pltcheck.sh: Script to check PLT entries. | ||||||
|  |  | ||||||
|  | 	* Makefile.am (TESTS): Run pltcheck.sh | ||||||
|  |  | ||||||
|  | 	* gtype.c: | ||||||
|  | 	* gsignal.c: | ||||||
|  | 	* gobject.c: | ||||||
|  | 	* gvaluetypes.c: Move all includes before gobjectalias.h. | ||||||
|  | 	(#3545422, Behdad Esfahbod) | ||||||
|  |  | ||||||
| 2006-08-30  Matthias Clasen  <mclasen@redhat.com> | 2006-08-30  Matthias Clasen  <mclasen@redhat.com> | ||||||
|  |  | ||||||
| 	* === Released 2.12.3 === | 	* === Released 2.12.3 === | ||||||
|   | |||||||
| @@ -154,6 +154,12 @@ EXTRA_DIST = \ | |||||||
| gen_sources = xgen-gmh xgen-gmc xgen-gms | gen_sources = xgen-gmh xgen-gmc xgen-gms | ||||||
| CLEANFILES = $(gen_sources) | CLEANFILES = $(gen_sources) | ||||||
|  |  | ||||||
|  | if OS_LINUX | ||||||
|  | if HAVE_GNUC_VISIBILITY | ||||||
|  | TESTS = pltcheck.sh | ||||||
|  | endif | ||||||
|  | endif | ||||||
|  |  | ||||||
| # normal autogeneration rules | # normal autogeneration rules | ||||||
| # all autogenerated files need to be generated in the srcdir, | # all autogenerated files need to be generated in the srcdir, | ||||||
| # so old versions get remade and are not confused with newer | # so old versions get remade and are not confused with newer | ||||||
|   | |||||||
| @@ -17,7 +17,6 @@ | |||||||
|  * Boston, MA 02111-1307, USA. |  * Boston, MA 02111-1307, USA. | ||||||
|  */ |  */ | ||||||
| #include	"gobject.h" | #include	"gobject.h" | ||||||
| #include	"gobjectalias.h" |  | ||||||
| #include        <glib/gdatasetprivate.h> | #include        <glib/gdatasetprivate.h> | ||||||
|  |  | ||||||
| /* | /* | ||||||
| @@ -28,10 +27,14 @@ | |||||||
| #include	"gsignal.h" | #include	"gsignal.h" | ||||||
| #include	"gparamspecs.h" | #include	"gparamspecs.h" | ||||||
| #include	"gvaluetypes.h" | #include	"gvaluetypes.h" | ||||||
| #include	"gobjectnotifyqueue.c" |  | ||||||
| #include	<string.h> | #include	<string.h> | ||||||
| #include	<signal.h> | #include	<signal.h> | ||||||
|  |  | ||||||
|  | #include	"gobjectalias.h" | ||||||
|  |  | ||||||
|  | /* This should be included after gobjectalias.h (or pltcheck.sh will fail) */ | ||||||
|  | #include	"gobjectnotifyqueue.c" | ||||||
|  |  | ||||||
|  |  | ||||||
| #define	PREALLOC_CPARAMS	(8) | #define	PREALLOC_CPARAMS	(8) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -32,6 +32,8 @@ | |||||||
| #include        "gvaluecollector.h" | #include        "gvaluecollector.h" | ||||||
| #include	"gvaluetypes.h" | #include	"gvaluetypes.h" | ||||||
| #include	"gboxed.h" | #include	"gboxed.h" | ||||||
|  | #include	"gobject.h" | ||||||
|  | #include	"genums.h" | ||||||
|  |  | ||||||
| #include	"gobjectalias.h" | #include	"gobjectalias.h" | ||||||
|  |  | ||||||
| @@ -2605,8 +2607,6 @@ g_signal_accumulator_true_handled (GSignalInvocationHint *ihint, | |||||||
| } | } | ||||||
|  |  | ||||||
| /* --- compile standard marshallers --- */ | /* --- compile standard marshallers --- */ | ||||||
| #include	"gobject.h" |  | ||||||
| #include	"genums.h" |  | ||||||
| #include        "gmarshal.c" | #include        "gmarshal.c" | ||||||
|  |  | ||||||
| #define __G_SIGNAL_C__ | #define __G_SIGNAL_C__ | ||||||
|   | |||||||
| @@ -18,7 +18,6 @@ | |||||||
|  */ |  */ | ||||||
| #include        <config.h> | #include        <config.h> | ||||||
| #include	"gtype.h" | #include	"gtype.h" | ||||||
| #include	"gobjectalias.h" |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * MT safe |  * MT safe | ||||||
| @@ -29,6 +28,7 @@ | |||||||
| #include	"gbsearcharray.h" | #include	"gbsearcharray.h" | ||||||
| #include	<string.h> | #include	<string.h> | ||||||
|  |  | ||||||
|  | #include	"gobjectalias.h" | ||||||
|  |  | ||||||
| /* NOTE: some functions (some internal variants and exported ones) | /* NOTE: some functions (some internal variants and exported ones) | ||||||
|  * invalidate data portions of the TypeNodes. if external functions/callbacks |  * invalidate data portions of the TypeNodes. if external functions/callbacks | ||||||
|   | |||||||
| @@ -348,7 +348,7 @@ gpointer g_type_instance_get_private    (GTypeInstance              *instance, | |||||||
|  *                                                 gtk_tree_store_tree_model_init)); |  *                                                 gtk_tree_store_tree_model_init)); | ||||||
|  */ |  */ | ||||||
| #define G_IMPLEMENT_INTERFACE(TYPE_IFACE, iface_init)       { \ | #define G_IMPLEMENT_INTERFACE(TYPE_IFACE, iface_init)       { \ | ||||||
|   static const GInterfaceInfo g_implement_interface_info = { \ |   const GInterfaceInfo g_implement_interface_info = { \ | ||||||
|     (GInterfaceInitFunc) iface_init, NULL, NULL \ |     (GInterfaceInitFunc) iface_init, NULL, NULL \ | ||||||
|   }; \ |   }; \ | ||||||
|   g_type_add_interface_static (g_define_type_id, TYPE_IFACE, &g_implement_interface_info); \ |   g_type_add_interface_static (g_define_type_id, TYPE_IFACE, &g_implement_interface_info); \ | ||||||
|   | |||||||
| @@ -24,6 +24,12 @@ | |||||||
| #include	"gvaluetypes.h" | #include	"gvaluetypes.h" | ||||||
|  |  | ||||||
| #include	"gvaluecollector.h" | #include	"gvaluecollector.h" | ||||||
|  |  | ||||||
|  | #include "gobject.h" | ||||||
|  | #include "gparam.h" | ||||||
|  | #include "gboxed.h" | ||||||
|  | #include "genums.h" | ||||||
|  |  | ||||||
| #include	"gobjectalias.h" | #include	"gobjectalias.h" | ||||||
| #include	<string.h> | #include	<string.h> | ||||||
| #include	<stdlib.h>	/* qsort() */ | #include	<stdlib.h>	/* qsort() */ | ||||||
| @@ -847,12 +853,6 @@ g_value_get_gtype (const GValue *value) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| /* need extra includes for g_strdup_value_contents() ;( */ |  | ||||||
| #include "gobject.h" |  | ||||||
| #include "gparam.h" |  | ||||||
| #include "gboxed.h" |  | ||||||
| #include "genums.h" |  | ||||||
|  |  | ||||||
| gchar* | gchar* | ||||||
| g_strdup_value_contents (const GValue *value) | g_strdup_value_contents (const GValue *value) | ||||||
| { | { | ||||||
|   | |||||||
							
								
								
									
										17
									
								
								gobject/pltcheck.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										17
									
								
								gobject/pltcheck.sh
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | #!/bin/sh | ||||||
|  |  | ||||||
|  | LANG=C | ||||||
|  |  | ||||||
|  | status=0 | ||||||
|  |  | ||||||
|  | if ! which readelf 2>/dev/null >/dev/null; then | ||||||
|  | 	echo "'readelf' not found; skipping test" | ||||||
|  | 	exit 0 | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | for so in .libs/lib*.so; do | ||||||
|  | 	echo Checking $so for local PLT entries | ||||||
|  | 	readelf -r $so | grep 'JU\?MP_SLOT' | grep '\<g_type_\|\<g_boxed_\|\<g_value_\|\<g_cclosure_\|\<g_closure_\|\<g_signal\|\<g_enum_\|\<g_flags_\|\<g_io_\|\<g_object_\|\<g_param_' && status=1 | ||||||
|  | done | ||||||
|  |  | ||||||
|  | exit $status | ||||||
		Reference in New Issue
	
	Block a user