mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-26 22:16:16 +01:00
Merge branch 'fix-gdbus-codegen--interface-info' into 'master'
fix gdbus-codegen --interface-info-{header,body} See merge request GNOME/glib!514
This commit is contained in:
commit
af39a37312
@ -619,17 +619,19 @@ class HeaderCodeGenerator:
|
||||
# ----------------------------------------------------------------------------------------------------
|
||||
|
||||
class InterfaceInfoHeaderCodeGenerator:
|
||||
def __init__(self, ifaces, namespace, header_name, use_pragma, outfile):
|
||||
def __init__(self, ifaces, namespace, header_name, input_files_basenames, use_pragma, outfile):
|
||||
self.ifaces = ifaces
|
||||
self.namespace, self.ns_upper, self.ns_lower = generate_namespace(namespace)
|
||||
self.header_guard = header_name.upper().replace('.', '_').replace('-', '_').replace('/', '_').replace(':', '_')
|
||||
self.input_files_basenames = input_files_basenames
|
||||
self.use_pragma = use_pragma
|
||||
self.outfile = outfile
|
||||
|
||||
# ----------------------------------------------------------------------------------------------------
|
||||
|
||||
def generate_header_preamble(self):
|
||||
self.outfile.write(LICENSE_STR.format(config.VERSION))
|
||||
basenames = ', '.join(self.input_files_basenames)
|
||||
self.outfile.write(LICENSE_STR.format(config.VERSION, basenames))
|
||||
self.outfile.write('\n')
|
||||
|
||||
if self.use_pragma:
|
||||
@ -670,16 +672,18 @@ class InterfaceInfoHeaderCodeGenerator:
|
||||
# ----------------------------------------------------------------------------------------------------
|
||||
|
||||
class InterfaceInfoBodyCodeGenerator:
|
||||
def __init__(self, ifaces, namespace, header_name, outfile):
|
||||
def __init__(self, ifaces, namespace, header_name, input_files_basenames, outfile):
|
||||
self.ifaces = ifaces
|
||||
self.namespace, self.ns_upper, self.ns_lower = generate_namespace(namespace)
|
||||
self.header_name = header_name
|
||||
self.input_files_basenames = input_files_basenames
|
||||
self.outfile = outfile
|
||||
|
||||
# ----------------------------------------------------------------------------------------------------
|
||||
|
||||
def generate_body_preamble(self):
|
||||
self.outfile.write(LICENSE_STR.format(config.VERSION))
|
||||
basenames = ', '.join(self.input_files_basenames)
|
||||
self.outfile.write(LICENSE_STR.format(config.VERSION, basenames))
|
||||
self.outfile.write('\n')
|
||||
self.outfile.write('#ifdef HAVE_CONFIG_H\n'
|
||||
'# include "config.h"\n'
|
||||
@ -696,7 +700,7 @@ class InterfaceInfoBodyCodeGenerator:
|
||||
def generate_array(self, array_name_lower, element_type, elements):
|
||||
self.outfile.write('const %s * const %s[] =\n' % (element_type, array_name_lower))
|
||||
self.outfile.write('{\n')
|
||||
for (_, name) in sorted(elements, key=utils.version_cmp_key):
|
||||
for (_, name) in elements:
|
||||
self.outfile.write(' &%s,\n' % name)
|
||||
self.outfile.write(' NULL,\n')
|
||||
self.outfile.write('};\n')
|
||||
|
@ -235,7 +235,7 @@ def codegen_main():
|
||||
|
||||
all_ifaces = []
|
||||
input_files_basenames = []
|
||||
for fname in args.files + args.xml_files:
|
||||
for fname in sorted(args.files + args.xml_files):
|
||||
with open(fname, 'rb') as f:
|
||||
xml_data = f.read()
|
||||
parsed_ifaces = parser.parse_dbus_xml(xml_data)
|
||||
@ -281,6 +281,7 @@ def codegen_main():
|
||||
gen = codegen.InterfaceInfoHeaderCodeGenerator(all_ifaces,
|
||||
args.c_namespace,
|
||||
header_name,
|
||||
input_files_basenames,
|
||||
args.pragma_once,
|
||||
outfile)
|
||||
gen.generate()
|
||||
@ -290,6 +291,7 @@ def codegen_main():
|
||||
gen = codegen.InterfaceInfoBodyCodeGenerator(all_ifaces,
|
||||
args.c_namespace,
|
||||
header_name,
|
||||
input_files_basenames,
|
||||
outfile)
|
||||
gen.generate()
|
||||
|
||||
|
@ -487,16 +487,16 @@ gdbus_proxy_threads_SOURCES = $(gdbus_sessionbus_sources) gdbus-pro
|
||||
gdbus_proxy_unique_name_SOURCES = $(gdbus_sessionbus_sources) gdbus-proxy-unique-name.c
|
||||
gdbus_proxy_well_known_name_SOURCES = $(gdbus_sessionbus_sources) gdbus-proxy-well-known-name.c
|
||||
gdbus_test_codegen_SOURCES = $(gdbus_sessionbus_sources) gdbus-test-codegen.c
|
||||
nodist_gdbus_test_codegen_SOURCES = gdbus-test-codegen-generated.c gdbus-test-codegen-generated.h
|
||||
nodist_gdbus_test_codegen_SOURCES = gdbus-test-codegen-generated.c gdbus-test-codegen-generated.h gdbus-test-codegen-generated-interface-info.c gdbus-test-codegen-generated-interface-info.h
|
||||
gdbus_test_codegen_old_SOURCES = $(gdbus_sessionbus_sources) gdbus-test-codegen.c
|
||||
nodist_gdbus_test_codegen_old_SOURCES = gdbus-test-codegen-generated.c gdbus-test-codegen-generated.h
|
||||
nodist_gdbus_test_codegen_old_SOURCES = gdbus-test-codegen-generated.c gdbus-test-codegen-generated.h gdbus-test-codegen-generated-interface-info.c gdbus-test-codegen-generated-interface-info.h
|
||||
gdbus_test_codegen_old_CPPFLAGS = $(AM_CPPFLAGS) -DGLIB_VERSION_MIN_REQUIRED=GLIB_VERSION_2_36 -DGLIB_VERSION_MAX_ALLOWED=GLIB_VERSION_2_36
|
||||
gdbus_threading_SOURCES = $(gdbus_sessionbus_sources) gdbus-threading.c
|
||||
gmenumodel_SOURCES = $(gdbus_sessionbus_sources) gmenumodel.c
|
||||
gnotification_SOURCES = $(gdbus_sessionbus_sources) gnotification.c gnotification-server.h gnotification-server.c
|
||||
|
||||
BUILT_SOURCES += gdbus-test-codegen-generated.c gdbus-test-codegen-generated.h
|
||||
gdbus-test-codegen.o: gdbus-test-codegen-generated.h
|
||||
BUILT_SOURCES += gdbus-test-codegen-generated.c gdbus-test-codegen-generated.h gdbus-test-codegen-generated-interface-info.c gdbus-test-codegen-generated-interface-info.h
|
||||
gdbus-test-codegen.o: gdbus-test-codegen-generated.h gdbus-test-codegen-generated-interface-info.h
|
||||
gdbus-test-codegen-generated.h: test-codegen.xml Makefile $(top_builddir)/gio/gdbus-2.0/codegen/gdbus-codegen
|
||||
$(AM_V_GEN) UNINSTALLED_GLIB_SRCDIR=$(top_srcdir) \
|
||||
UNINSTALLED_GLIB_BUILDDIR=$(top_builddir) \
|
||||
@ -519,9 +519,41 @@ gdbus-test-codegen-generated.h: test-codegen.xml Makefile $(top_builddir)/gio/gd
|
||||
$(NULL)
|
||||
gdbus-test-codegen-generated.c: gdbus-test-codegen-generated.h
|
||||
@: # Generated as side-effect of .h
|
||||
gdbus-test-codegen-generated-interface-info.h: test-codegen.xml Makefile $(top_builddir)/gio/gdbus-2.0/codegen/gdbus-codegen
|
||||
$(AM_V_GEN) UNINSTALLED_GLIB_SRCDIR=$(top_srcdir) \
|
||||
UNINSTALLED_GLIB_BUILDDIR=$(top_builddir) \
|
||||
$(PYTHON) $(top_builddir)/gio/gdbus-2.0/codegen/gdbus-codegen \
|
||||
--interface-info-header \
|
||||
--annotate "org.project.Bar" Key1 Value1 \
|
||||
--annotate "org.project.Bar" org.gtk.GDBus.Internal Value2 \
|
||||
--annotate "org.project.Bar.HelloWorld()" Key3 Value3 \
|
||||
--annotate "org.project.Bar::TestSignal" Key4 Value4 \
|
||||
--annotate "org.project.Bar:ay" Key5 Value5 \
|
||||
--annotate "org.project.Bar.TestPrimitiveTypes()[val_int32]" Key6 Value6 \
|
||||
--annotate "org.project.Bar.TestPrimitiveTypes()[ret_uint32]" Key7 Value7 \
|
||||
--annotate "org.project.Bar::TestSignal[array_of_strings]" Key8 Value8 \
|
||||
--output $@ \
|
||||
$(srcdir)/test-codegen.xml \
|
||||
$(NULL)
|
||||
gdbus-test-codegen-generated-interface-info.c: test-codegen.xml Makefile $(top_builddir)/gio/gdbus-2.0/codegen/gdbus-codegen
|
||||
$(AM_V_GEN) UNINSTALLED_GLIB_SRCDIR=$(top_srcdir) \
|
||||
UNINSTALLED_GLIB_BUILDDIR=$(top_builddir) \
|
||||
$(PYTHON) $(top_builddir)/gio/gdbus-2.0/codegen/gdbus-codegen \
|
||||
--interface-info-body \
|
||||
--annotate "org.project.Bar" Key1 Value1 \
|
||||
--annotate "org.project.Bar" org.gtk.GDBus.Internal Value2 \
|
||||
--annotate "org.project.Bar.HelloWorld()" Key3 Value3 \
|
||||
--annotate "org.project.Bar::TestSignal" Key4 Value4 \
|
||||
--annotate "org.project.Bar:ay" Key5 Value5 \
|
||||
--annotate "org.project.Bar.TestPrimitiveTypes()[val_int32]" Key6 Value6 \
|
||||
--annotate "org.project.Bar.TestPrimitiveTypes()[ret_uint32]" Key7 Value7 \
|
||||
--annotate "org.project.Bar::TestSignal[array_of_strings]" Key8 Value8 \
|
||||
--output $@ \
|
||||
$(srcdir)/test-codegen.xml \
|
||||
$(NULL)
|
||||
|
||||
EXTRA_DIST += test-codegen.xml
|
||||
CLEANFILES += gdbus-test-codegen-generated.[ch] gdbus-test-codegen-generated-doc-*.xml
|
||||
CLEANFILES += gdbus-test-codegen-generated.[ch] gdbus-test-codegen-generated-doc-*.xml gdbus-test-codegen-generated-interface-info.[ch]
|
||||
endif # OS_UNIX
|
||||
endif # HAVE_DBUS_DAEMON
|
||||
|
||||
|
@ -26,6 +26,7 @@
|
||||
#include "gdbus-tests.h"
|
||||
|
||||
#include "gdbus-test-codegen-generated.h"
|
||||
#include "gdbus-test-codegen-generated-interface-info.h"
|
||||
|
||||
/* ---------------------------------------------------------------------------------------------------- */
|
||||
|
||||
@ -2463,6 +2464,110 @@ test_deprecations (void)
|
||||
|
||||
/* ---------------------------------------------------------------------------------------------------- */
|
||||
|
||||
static void
|
||||
assert_arg_infos_equal (GDBusArgInfo **a,
|
||||
GDBusArgInfo **b)
|
||||
{
|
||||
if (a == NULL)
|
||||
{
|
||||
g_assert_null (b);
|
||||
return;
|
||||
}
|
||||
|
||||
g_assert_nonnull (b);
|
||||
|
||||
for (; *a != NULL && *b != NULL; a++, b++)
|
||||
{
|
||||
g_assert_cmpstr ((*a)->name, ==, (*b)->name);
|
||||
g_assert_cmpstr ((*a)->signature, ==, (*b)->signature);
|
||||
}
|
||||
|
||||
g_assert_null (*a);
|
||||
g_assert_null (*b);
|
||||
}
|
||||
|
||||
static void
|
||||
assert_annotations_equal (GDBusAnnotationInfo **a,
|
||||
GDBusAnnotationInfo **b)
|
||||
{
|
||||
guint a_len = count_annotations (a);
|
||||
guint b_len = count_annotations (b);
|
||||
|
||||
g_assert_cmpuint (a_len, ==, b_len);
|
||||
|
||||
if (a == NULL || b == NULL)
|
||||
return;
|
||||
|
||||
for (; *a != NULL && *b != NULL; a++, b++)
|
||||
{
|
||||
g_assert_cmpstr ((*a)->key, ==, (*b)->key);
|
||||
g_assert_cmpstr ((*a)->value, ==, (*b)->value);
|
||||
assert_annotations_equal ((*a)->annotations, (*b)->annotations);
|
||||
}
|
||||
|
||||
g_assert_null (*a);
|
||||
g_assert_null (*b);
|
||||
}
|
||||
|
||||
/* Test that the GDBusInterfaceInfo structure generated by gdbus-codegen
|
||||
* --interface-info-body matches that generated by the other mode.
|
||||
*/
|
||||
static void
|
||||
test_standalone_interface_info (void)
|
||||
{
|
||||
GDBusInterfaceSkeleton *skel = G_DBUS_INTERFACE_SKELETON (foo_igen_bar_skeleton_new ());
|
||||
GDBusInterfaceInfo *skel_info = g_dbus_interface_skeleton_get_info (skel);
|
||||
const GDBusInterfaceInfo *slim_info = &org_project_bar_interface;
|
||||
gsize i;
|
||||
|
||||
g_assert_cmpstr (skel_info->name, ==, slim_info->name);
|
||||
|
||||
for (i = 0; skel_info->methods[i] != NULL; i++)
|
||||
{
|
||||
GDBusMethodInfo *skel_method = skel_info->methods[i];
|
||||
GDBusMethodInfo *slim_method = slim_info->methods[i];
|
||||
|
||||
g_assert_nonnull (slim_method);
|
||||
g_assert_cmpstr (skel_method->name, ==, slim_method->name);
|
||||
assert_arg_infos_equal (skel_method->in_args, slim_method->in_args);
|
||||
assert_arg_infos_equal (skel_method->out_args, slim_method->out_args);
|
||||
assert_annotations_equal (skel_method->annotations, slim_method->annotations);
|
||||
}
|
||||
g_assert_null (slim_info->methods[i]);
|
||||
|
||||
for (i = 0; skel_info->signals[i] != NULL; i++)
|
||||
{
|
||||
GDBusSignalInfo *skel_signal = skel_info->signals[i];
|
||||
GDBusSignalInfo *slim_signal = slim_info->signals[i];
|
||||
|
||||
g_assert_nonnull (slim_signal);
|
||||
g_assert_cmpstr (skel_signal->name, ==, slim_signal->name);
|
||||
assert_arg_infos_equal (skel_signal->args, slim_signal->args);
|
||||
assert_annotations_equal (skel_signal->annotations, slim_signal->annotations);
|
||||
}
|
||||
g_assert_null (slim_info->signals[i]);
|
||||
|
||||
for (i = 0; skel_info->properties[i] != NULL; i++)
|
||||
{
|
||||
GDBusPropertyInfo *skel_prop = skel_info->properties[i];
|
||||
GDBusPropertyInfo *slim_prop = slim_info->properties[i];
|
||||
|
||||
g_assert_nonnull (slim_prop);
|
||||
|
||||
g_assert_cmpstr (skel_prop->name, ==, slim_prop->name);
|
||||
g_assert_cmpstr (skel_prop->signature, ==, slim_prop->signature);
|
||||
g_assert_cmpuint (skel_prop->flags, ==, slim_prop->flags);
|
||||
assert_annotations_equal (skel_prop->annotations, slim_prop->annotations);
|
||||
}
|
||||
g_assert_null (slim_info->properties[i]);
|
||||
|
||||
assert_annotations_equal (skel_info->annotations, slim_info->annotations);
|
||||
|
||||
g_clear_object (&skel);
|
||||
}
|
||||
|
||||
/* ---------------------------------------------------------------------------------------------------- */
|
||||
|
||||
int
|
||||
main (int argc,
|
||||
char *argv[])
|
||||
@ -2475,6 +2580,7 @@ main (int argc,
|
||||
g_test_add_func ("/gdbus/codegen/property-naming", test_property_naming);
|
||||
g_test_add_func ("/gdbus/codegen/autocleanups", test_autocleanups);
|
||||
g_test_add_func ("/gdbus/codegen/deprecations", test_deprecations);
|
||||
g_test_add_func ("/gdbus/codegen/standalone-interface-info", test_standalone_interface_info);
|
||||
|
||||
return session_bus_run ();
|
||||
}
|
||||
|
@ -171,6 +171,16 @@ if host_machine.system() != 'windows'
|
||||
# Test programs that need to bring up a session bus (requires dbus-daemon)
|
||||
have_dbus_daemon = find_program('dbus-daemon', required : false).found()
|
||||
if have_dbus_daemon
|
||||
annotate_args = [
|
||||
'--annotate', 'org.project.Bar', 'Key1', 'Value1',
|
||||
'--annotate', 'org.project.Bar', 'org.gtk.GDBus.Internal', 'Value2',
|
||||
'--annotate', 'org.project.Bar.HelloWorld()', 'Key3', 'Value3',
|
||||
'--annotate', 'org.project.Bar::TestSignal', 'Key4', 'Value4',
|
||||
'--annotate', 'org.project.Bar:ay', 'Key5', 'Value5',
|
||||
'--annotate', 'org.project.Bar.TestPrimitiveTypes()[val_int32]', 'Key6', 'Value6',
|
||||
'--annotate', 'org.project.Bar.TestPrimitiveTypes()[ret_uint32]', 'Key7', 'Value7',
|
||||
'--annotate', 'org.project.Bar::TestSignal[array_of_strings]', 'Key8', 'Value8',
|
||||
]
|
||||
# Generate gdbus-test-codegen-generated.{c,h}
|
||||
gdbus_test_codegen_generated = custom_target('gdbus-test-codegen-generated',
|
||||
input : ['test-codegen.xml'],
|
||||
@ -185,16 +195,30 @@ if host_machine.system() != 'windows'
|
||||
'--c-generate-autocleanup', 'all',
|
||||
'--c-namespace', 'Foo_iGen',
|
||||
'--generate-docbook', 'gdbus-test-codegen-generated-doc',
|
||||
'--annotate', 'org.project.Bar', 'Key1', 'Value1',
|
||||
'--annotate', 'org.project.Bar', 'org.gtk.GDBus.Internal', 'Value2',
|
||||
'--annotate', 'org.project.Bar.HelloWorld()', 'Key3', 'Value3',
|
||||
'--annotate', 'org.project.Bar::TestSignal', 'Key4', 'Value4',
|
||||
'--annotate', 'org.project.Bar:ay', 'Key5', 'Value5',
|
||||
'--annotate', 'org.project.Bar.TestPrimitiveTypes()[val_int32]', 'Key6', 'Value6',
|
||||
'--annotate', 'org.project.Bar.TestPrimitiveTypes()[ret_uint32]', 'Key7', 'Value7',
|
||||
'--annotate', 'org.project.Bar::TestSignal[array_of_strings]', 'Key8', 'Value8',
|
||||
annotate_args,
|
||||
'@INPUT@'])
|
||||
|
||||
gdbus_test_codegen_generated_interface_info = [
|
||||
custom_target('gdbus-test-codegen-generated-interface-info-h',
|
||||
input : ['test-codegen.xml'],
|
||||
output : ['gdbus-test-codegen-generated-interface-info.h'],
|
||||
depend_files : gdbus_codegen_built_files,
|
||||
command : [python, gdbus_codegen,
|
||||
'--interface-info-header',
|
||||
annotate_args,
|
||||
'--output', '@OUTPUT@',
|
||||
'@INPUT@']),
|
||||
custom_target('gdbus-test-codegen-generated-interface-info-c',
|
||||
input : ['test-codegen.xml'],
|
||||
output : ['gdbus-test-codegen-generated-interface-info.c'],
|
||||
depend_files : gdbus_codegen_built_files,
|
||||
command : [python, gdbus_codegen,
|
||||
'--interface-info-body',
|
||||
annotate_args,
|
||||
'--output', '@OUTPUT@',
|
||||
'@INPUT@']),
|
||||
]
|
||||
|
||||
extra_sources = ['gdbus-sessionbus.c', 'gdbus-tests.c']
|
||||
|
||||
gio_tests += {
|
||||
@ -224,7 +248,7 @@ if host_machine.system() != 'windows'
|
||||
'gdbus-proxy-unique-name' : {'extra_sources' : extra_sources},
|
||||
'gdbus-proxy-well-known-name' : {'extra_sources' : extra_sources},
|
||||
'gdbus-test-codegen' : {
|
||||
'extra_sources' : [extra_sources, gdbus_test_codegen_generated],
|
||||
'extra_sources' : [extra_sources, gdbus_test_codegen_generated, gdbus_test_codegen_generated_interface_info],
|
||||
},
|
||||
'gdbus-threading' : {
|
||||
'extra_sources' : extra_sources,
|
||||
@ -239,7 +263,7 @@ if host_machine.system() != 'windows'
|
||||
},
|
||||
'gdbus-test-codegen-old' : {
|
||||
'source' : 'gdbus-test-codegen.c',
|
||||
'extra_sources' : [extra_sources, gdbus_test_codegen_generated],
|
||||
'extra_sources' : [extra_sources, gdbus_test_codegen_generated, gdbus_test_codegen_generated_interface_info],
|
||||
'c_args' : ['-DGLIB_VERSION_MIN_REQUIRED=GLIB_VERSION_2_36',
|
||||
'-DGLIB_VERSION_MAX_ALLOWED=GLIB_VERSION_2_36'],
|
||||
},
|
||||
|
Loading…
Reference in New Issue
Block a user