? libxklavier/stamp-xkl-enum-types.h ? libxklavier/xkl-enum-types.c ? libxklavier/xkl-enum-types.h Index: ChangeLog =================================================================== RCS file: /cvs/xklavier/libxklavier/ChangeLog,v retrieving revision 1.110 diff -u -r1.110 ChangeLog --- ChangeLog 24 Apr 2009 22:10:19 -0000 1.110 +++ ChangeLog 5 May 2009 21:24:32 -0000 @@ -1,3 +1,11 @@ +2009-05-06 Sayamindu Dasgupta + https://bugs.freedesktop.org/show_bug.cgi?id=21578 - Make use + of glib-mkenums + * libxklavier/Makefile.am: Use glib-mkenums + * libxklavier/xklavier.c (xkl_engine_class_init): Do not use + g_flags_register_static for XklEngineFeatures here. + * libxklavier/xklavier.h: Include xkl-enum-types.h + 2009-04-23 Federico Mena Quintero https://bugs.freedesktop.org/show_bug.cgi?id=21365 - Make sure Index: libxklavier/Makefile.am =================================================================== RCS file: /cvs/xklavier/libxklavier/libxklavier/Makefile.am,v retrieving revision 1.23 diff -u -r1.23 Makefile.am --- libxklavier/Makefile.am 6 Apr 2009 22:54:45 -0000 1.23 +++ libxklavier/Makefile.am 5 May 2009 21:24:32 -0000 @@ -15,17 +15,6 @@ ENABLE_XMODMAP_SUPPORT_CFLAG = -DDISABLE_XMODMAP_SUPPORT=1 endif -EXTRA_DIST=marshal.list - -# GLIB_GENMARSHAL = $(shell $PKG_CONFIG --variable=glib_genmarshal glib-2.0) -GLIB_GENMARSHAL = `$PKG_CONFIG --variable=glib_genmarshal glib-2.0` - -xkl_engine_marshal.h: marshal.list - $(GLIB_GENMARSHAL) --prefix=xkl_engine marshal.list --header > xkl_engine_marshal.h - -xkl_engine_marshal.c: xkl_engine_marshal.h - $(GLIB_GENMARSHAL) --prefix=xkl_engine marshal.list --body > xkl_engine_marshal.c - AM_CFLAGS=-Wall -DDATA_DIR=\"$(datadir)/$(PACKAGE)\" \ -I. -I$(top_srcdir) $(X_CFLAGS) \ $(XML_CFLAGS) $(GLIB_CFLAGS) $(XINPUT_CFLAGS) \ @@ -35,20 +24,64 @@ lib_LTLIBRARIES = libxklavier.la noinst_HEADERS = xklavier_private.h xklavier_private_xkb.h xklavier_private_xmm.h +xklavier_headers = xklavier.h xkl_config_registry.h xkl_engine.h \ + xkl_config_rec.h xkl_config_item.h xkl_engine_marshal.h +xklavier_built_headers = xkl-enum-types.h +xklavier_built_cfiles = xkl-enum-types.c xklavierincdir = $(includedir)/libxklavier -xklavierinc_HEADERS = xklavier.h xkl_config_registry.h xkl_engine.h \ - xkl_config_rec.h xkl_config_item.h xkl_engine_marshal.h +xklavierinc_HEADERS = $(xklavier_headers) $(xklavier_built_headers) + libxklavier_la_SOURCES = xklavier.c xklavier_evt.c xklavier_config.c xklavier_config_iso.c \ xklavier_xkb.c xklavier_evt_xkb.c xklavier_config_xkb.c xklavier_toplevel.c \ xklavier_xmm.c xklavier_xmm_opts.c xklavier_evt_xmm.c xklavier_config_xmm.c \ xklavier_util.c xklavier_props.c xklavier_dump.c xkl_engine_marshal.c \ - $(noinst_HEADERS) $(xklavierinc_HEADERS) + $(noinst_HEADERS) $(xklavierinc_HEADERS) $(xklavier_built_cfiles) libxklavier_la_LDFLAGS = -version-info @VERSION_INFO@ -no-undefined libxklavier_la_LIBADD = \ $(XML_LIBS) $(GLIB_LIBS) $(XINPUT_LIBS) \ $(LIBXKBFILE_PRESENT_LDFLAGS) \ $(X_LIBS) -lX11 $(LIBICONV) +EXTRA_DIST=marshal.list \ + $(xklavier_built_headers) \ + $(xklavier_built_cfiles) + + +# GLIB_GENMARSHAL = $(shell $PKG_CONFIG --variable=glib_genmarshal glib-2.0) +GLIB_GENMARSHAL = `$PKG_CONFIG --variable=glib_genmarshal glib-2.0` + +xkl_engine_marshal.h: marshal.list + $(GLIB_GENMARSHAL) --prefix=xkl_engine marshal.list --header > xkl_engine_marshal.h + +xkl_engine_marshal.c: xkl_engine_marshal.h + $(GLIB_GENMARSHAL) --prefix=xkl_engine marshal.list --body > xkl_engine_marshal.c + +xkl-enum-types.h: stamp-xkl-enum-types.h + @true +stamp-xkl-enum-types.h: $(xklavier_headers) + (cd $(srcdir) \ + && glib-mkenums \ + --fhead "#ifndef __XKL_ENUM_TYPES_H__\n#define __XKL_ENUM_TYPES_H__\n" \ + --fprod "/* enumerations from \"@filename@\" */\n" \ + --vhead "GType @enum_name@_get_type (void);\n#define XKL_TYPE_@ENUMSHORT@ (@enum_name@_get_type())\n" \ + --ftail "#endif /* __XKL_ENUM_TYPES_H__ */" \ + $(xklavier_headers)) > new-xkl-enum-types.h \ + && (cmp -s new-xkl-enum-types.h xkl-enum-types.h || cp new-xkl-enum-types.h xkl-enum-types.h) \ + && rm -f new-xkl-enum-types.h \ + && echo timestamp > $(@F) + +xkl-enum-types.c: $(xklavier_headers) xkl-enum-types.h + (cd $(srcdir) \ + && glib-mkenums \ + --fhead "#include " \ + --fprod "\n/* enumerations from \"@filename@\" */" \ + --vhead "GType\n@enum_name@_get_type (void)\n{\n static GType etype = 0;\n if (etype == 0) {\n static const G@Type@Value values[] = {" \ + --vprod " { @VALUENAME@, \"@VALUENAME@\", \"@valuenick@\" }," \ + --vtail " { 0, NULL, NULL }\n };\n etype = g_@type@_register_static (\"@EnumName@\", values);\n }\n return etype;\n}\n" \ + $(xklavier_headers)) > new-xkl-enum-types.c \ + && cp new-xkl-enum-types.c $(@F) \ + && rm -f new-xkl-enum-types.c + Index: libxklavier/xklavier.c =================================================================== RCS file: /cvs/xklavier/libxklavier/libxklavier/xklavier.c,v retrieving revision 1.32 diff -u -r1.32 xklavier.c --- libxklavier/xklavier.c 24 Apr 2009 22:10:19 -0000 1.32 +++ libxklavier/xklavier.c 5 May 2009 21:24:33 -0000 @@ -799,7 +799,6 @@ GParamSpec *default_group_param_spec; GParamSpec *secondary_groups_mask_param_spec; GParamSpec *indicators_handling_param_spec; - GType features_type; GType state_change_type; const gchar *sdl; @@ -824,9 +823,6 @@ NULL, G_PARAM_READABLE); - features_type = g_flags_register_static("XklEngineFeatures", - feature_flags); - state_change_type = g_enum_register_static("XklEngineStateChangeType", state_change_values); @@ -834,7 +830,7 @@ features_param_spec = g_param_spec_flags("features", "Features", "Backend features", - features_type, + XKL_TYPE_ENGINE_FEATURES, 0, G_PARAM_READABLE); max_num_groups_param_spec = g_param_spec_uint("max-num-groups", "maxNumGroups", Index: libxklavier/xklavier.h =================================================================== RCS file: /cvs/xklavier/libxklavier/libxklavier/xklavier.h,v retrieving revision 1.9 diff -u -r1.9 xklavier.h --- libxklavier/xklavier.h 7 Oct 2006 16:56:51 -0000 1.9 +++ libxklavier/xklavier.h 5 May 2009 21:24:33 -0000 @@ -30,6 +30,7 @@ #include #include #include +#include #ifdef __cplusplus extern "C" {