diff options
author | Philip Withnall <pwithnall@endlessos.org> | 2020-11-17 15:07:09 +0000 |
---|---|---|
committer | Philip Withnall <pwithnall@endlessos.org> | 2020-11-17 15:50:07 +0000 |
commit | 905b22a17eee2b0b4648f59e615360ca52d3b603 (patch) | |
tree | 7f1bdd4645fb15632ea4707d6b90449f1ad0877c /gio | |
parent | 053d2ae2b4cd31c98f1523f0bc7748296e633b6d (diff) | |
download | glib-905b22a17eee2b0b4648f59e615360ca52d3b603.tar.gz |
py: Reformat all Python files consistently
This commit is the unmodified results of running
```
black $(git ls-files '*.py')
```
with black version 19.10b0. See #2046.
Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
Diffstat (limited to 'gio')
-rwxr-xr-x | gio/data-to-c.py | 14 | ||||
-rw-r--r-- | gio/gdbus-2.0/codegen/__init__.py | 6 | ||||
-rw-r--r-- | gio/gdbus-2.0/codegen/codegen.py | 7527 | ||||
-rw-r--r-- | gio/gdbus-2.0/codegen/codegen_docbook.py | 412 | ||||
-rw-r--r-- | gio/gdbus-2.0/codegen/codegen_main.py | 407 | ||||
-rw-r--r-- | gio/gdbus-2.0/codegen/dbustypes.py | 501 | ||||
-rw-r--r-- | gio/gdbus-2.0/codegen/parser.py | 164 | ||||
-rw-r--r-- | gio/gdbus-2.0/codegen/utils.py | 90 | ||||
-rw-r--r-- | gio/gio-querymodules-wrapper.py | 6 | ||||
-rw-r--r-- | gio/tests/codegen.py | 655 | ||||
-rw-r--r-- | gio/tests/gen-big-test-resource.py | 4 | ||||
-rw-r--r-- | gio/tests/gengiotypefuncs.py | 43 | ||||
-rwxr-xr-x | gio/tests/static-link.py | 38 | ||||
-rw-r--r-- | gio/tests/taptestrunner.py | 283 |
14 files changed, 5925 insertions, 4225 deletions
diff --git a/gio/data-to-c.py b/gio/data-to-c.py index f226220ed..d8854b417 100755 --- a/gio/data-to-c.py +++ b/gio/data-to-c.py @@ -3,14 +3,14 @@ import sys if len(sys.argv) < 4: - print('Usage: {0} <filename> <variable> <output>') + print("Usage: {0} <filename> <variable> <output>") -with open(sys.argv[1], 'rb') as f: - in_data = f.read().decode('utf-8', 'backslashreplace') -b = [r'\x{:02x}'.format(ord(c)) for c in in_data] +with open(sys.argv[1], "rb") as f: + in_data = f.read().decode("utf-8", "backslashreplace") +b = [r"\x{:02x}".format(ord(c)) for c in in_data] -out_data = "const char {0}[] = \"".format(sys.argv[2]) -out_data += "".join(b) + "\";" +out_data = 'const char {0}[] = "'.format(sys.argv[2]) +out_data += "".join(b) + '";' -with open(sys.argv[3], 'w') as f: +with open(sys.argv[3], "w") as f: f.write(out_data) diff --git a/gio/gdbus-2.0/codegen/__init__.py b/gio/gdbus-2.0/codegen/__init__.py index f876f04af..ed324d7cf 100644 --- a/gio/gdbus-2.0/codegen/__init__.py +++ b/gio/gdbus-2.0/codegen/__init__.py @@ -21,7 +21,9 @@ import os -builddir = os.environ.get('UNINSTALLED_GLIB_BUILDDIR') +builddir = os.environ.get("UNINSTALLED_GLIB_BUILDDIR") if builddir is not None: - __path__.append(os.path.abspath(os.path.join(builddir, 'gio', 'gdbus-2.0', 'codegen'))) + __path__.append( + os.path.abspath(os.path.join(builddir, "gio", "gdbus-2.0", "codegen")) + ) diff --git a/gio/gdbus-2.0/codegen/codegen.py b/gio/gdbus-2.0/codegen/codegen.py index cda047173..621af665a 100644 --- a/gio/gdbus-2.0/codegen/codegen.py +++ b/gio/gdbus-2.0/codegen/codegen.py @@ -28,42 +28,56 @@ from . import utils from . import dbustypes from .utils import print_error -LICENSE_STR = '''/* +LICENSE_STR = """/* * This file is generated by gdbus-codegen, do not modify it. * * The license of this code is the same as for the D-Bus interface description * it was derived from. Note that it links to GLib, so must comply with the * LGPL linking clauses. - */\n''' + */\n""" + def generate_namespace(namespace): ns = namespace if len(namespace) > 0: if utils.is_ugly_case(namespace): - ns = namespace.replace('_', '') - ns_upper = namespace.upper() + '_' - ns_lower = namespace.lower() + '_' + ns = namespace.replace("_", "") + ns_upper = namespace.upper() + "_" + ns_lower = namespace.lower() + "_" else: - ns_upper = utils.camel_case_to_uscore(namespace).upper() + '_' - ns_lower = utils.camel_case_to_uscore(namespace).lower() + '_' + ns_upper = utils.camel_case_to_uscore(namespace).upper() + "_" + ns_lower = utils.camel_case_to_uscore(namespace).lower() + "_" else: - ns_upper = '' - ns_lower = '' + ns_upper = "" + ns_lower = "" return (ns, ns_upper, ns_lower) + def generate_header_guard(header_name): # There might be more characters that are safe to use than these, but lets # stay conservative. safe_valid_chars = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ" - return ''.join(map(lambda c: c if c in safe_valid_chars else '_', - header_name.upper())) + return "".join( + map(lambda c: c if c in safe_valid_chars else "_", header_name.upper()) + ) + class HeaderCodeGenerator: - def __init__(self, ifaces, namespace, generate_objmanager, - generate_autocleanup, header_name, input_files_basenames, - use_pragma, glib_min_required, - symbol_decorator, symbol_decorator_header, outfile): + def __init__( + self, + ifaces, + namespace, + generate_objmanager, + generate_autocleanup, + header_name, + input_files_basenames, + use_pragma, + glib_min_required, + symbol_decorator, + symbol_decorator_header, + outfile, + ): self.ifaces = ifaces self.namespace, self.ns_upper, self.ns_lower = generate_namespace(namespace) self.generate_objmanager = generate_objmanager @@ -79,84 +93,106 @@ class HeaderCodeGenerator: # ---------------------------------------------------------------------------------------------------- def generate_header_preamble(self): - basenames = ', '.join(self.input_files_basenames) + basenames = ", ".join(self.input_files_basenames) self.outfile.write(LICENSE_STR.format(config.VERSION, basenames)) - self.outfile.write('\n') + self.outfile.write("\n") if self.use_pragma: - self.outfile.write('#pragma once\n') + self.outfile.write("#pragma once\n") else: - self.outfile.write('#ifndef __{!s}__\n'.format(self.header_guard)) - self.outfile.write('#define __{!s}__\n'.format(self.header_guard)) + self.outfile.write("#ifndef __{!s}__\n".format(self.header_guard)) + self.outfile.write("#define __{!s}__\n".format(self.header_guard)) if self.symbol_decorator_header is not None: - self.outfile.write('\n') + self.outfile.write("\n") self.outfile.write('#include "%s"\n' % self.symbol_decorator_header) - self.outfile.write('\n') - self.outfile.write('#include <gio/gio.h>\n') - self.outfile.write('\n') - self.outfile.write('G_BEGIN_DECLS\n') - self.outfile.write('\n') + self.outfile.write("\n") + self.outfile.write("#include <gio/gio.h>\n") + self.outfile.write("\n") + self.outfile.write("G_BEGIN_DECLS\n") + self.outfile.write("\n") # ---------------------------------------------------------------------------------------------------- def declare_types(self): for i in self.ifaces: - self.outfile.write('\n') - self.outfile.write('/* ------------------------------------------------------------------------ */\n') - self.outfile.write('/* Declarations for %s */\n'%i.name) - self.outfile.write('\n') + self.outfile.write("\n") + self.outfile.write( + "/* ------------------------------------------------------------------------ */\n" + ) + self.outfile.write("/* Declarations for %s */\n" % i.name) + self.outfile.write("\n") # First the GInterface - self.outfile.write('#define %sTYPE_%s (%s_get_type ())\n'%(i.ns_upper, i.name_upper, i.name_lower)) - self.outfile.write('#define %s%s(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), %sTYPE_%s, %s))\n'%(i.ns_upper, i.name_upper, i.ns_upper, i.name_upper, i.camel_name)) - self.outfile.write('#define %sIS_%s(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), %sTYPE_%s))\n'%(i.ns_upper, i.name_upper, i.ns_upper, i.name_upper)) - self.outfile.write('#define %s%s_GET_IFACE(o) (G_TYPE_INSTANCE_GET_INTERFACE ((o), %sTYPE_%s, %sIface))\n'%(i.ns_upper, i.name_upper, i.ns_upper, i.name_upper, i.camel_name)) - self.outfile.write('\n') - self.outfile.write('struct _%s;\n'%(i.camel_name)) - self.outfile.write('typedef struct _%s %s;\n'%(i.camel_name, i.camel_name)) - self.outfile.write('typedef struct _%sIface %sIface;\n'%(i.camel_name, i.camel_name)) - self.outfile.write('\n') - self.outfile.write('struct _%sIface\n'%(i.camel_name)) - self.outfile.write('{\n') - self.outfile.write(' GTypeInterface parent_iface;\n') + self.outfile.write( + "#define %sTYPE_%s (%s_get_type ())\n" + % (i.ns_upper, i.name_upper, i.name_lower) + ) + self.outfile.write( + "#define %s%s(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), %sTYPE_%s, %s))\n" + % (i.ns_upper, i.name_upper, i.ns_upper, i.name_upper, i.camel_name) + ) + self.outfile.write( + "#define %sIS_%s(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), %sTYPE_%s))\n" + % (i.ns_upper, i.name_upper, i.ns_upper, i.name_upper) + ) + self.outfile.write( + "#define %s%s_GET_IFACE(o) (G_TYPE_INSTANCE_GET_INTERFACE ((o), %sTYPE_%s, %sIface))\n" + % (i.ns_upper, i.name_upper, i.ns_upper, i.name_upper, i.camel_name) + ) + self.outfile.write("\n") + self.outfile.write("struct _%s;\n" % (i.camel_name)) + self.outfile.write( + "typedef struct _%s %s;\n" % (i.camel_name, i.camel_name) + ) + self.outfile.write( + "typedef struct _%sIface %sIface;\n" % (i.camel_name, i.camel_name) + ) + self.outfile.write("\n") + self.outfile.write("struct _%sIface\n" % (i.camel_name)) + self.outfile.write("{\n") + self.outfile.write(" GTypeInterface parent_iface;\n") function_pointers = {} # vfuncs for methods if len(i.methods) > 0: - self.outfile.write('\n') + self.outfile.write("\n") for m in i.methods: - key = (m.since, '_method_%s'%m.name_lower) - value = ' gboolean (*handle_%s) (\n'%(m.name_lower) - value += ' %s *object,\n'%(i.camel_name) - value += ' GDBusMethodInvocation *invocation'%() + key = (m.since, "_method_%s" % m.name_lower) + value = " gboolean (*handle_%s) (\n" % (m.name_lower) + value += " %s *object,\n" % (i.camel_name) + value += " GDBusMethodInvocation *invocation" % () if m.unix_fd: - value += ',\n GUnixFDList *fd_list' + value += ",\n GUnixFDList *fd_list" for a in m.in_args: - value += ',\n %sarg_%s'%(a.ctype_in, a.name) - value += ');\n\n' + value += ",\n %sarg_%s" % (a.ctype_in, a.name) + value += ");\n\n" function_pointers[key] = value # vfuncs for signals if len(i.signals) > 0: - self.outfile.write('\n') + self.outfile.write("\n") for s in i.signals: - key = (s.since, '_signal_%s'%s.name_lower) - value = ' void (*%s) (\n'%(s.name_lower) - value += ' %s *object'%(i.camel_name) + key = (s.since, "_signal_%s" % s.name_lower) + value = " void (*%s) (\n" % (s.name_lower) + value += " %s *object" % (i.camel_name) for a in s.args: - value += ',\n %sarg_%s'%(a.ctype_in, a.name) - value += ');\n\n' + value += ",\n %sarg_%s" % (a.ctype_in, a.name) + value += ");\n\n" function_pointers[key] = value # vfuncs for properties if len(i.properties) > 0: - self.outfile.write('\n') + self.outfile.write("\n") for p in i.properties: - key = (p.since, '_prop_get_%s'%p.name_lower) - value = ' %s (*get_%s) (%s *object);\n\n'%(p.arg.ctype_in, p.name_lower, i.camel_name) + key = (p.since, "_prop_get_%s" % p.name_lower) + value = " %s (*get_%s) (%s *object);\n\n" % ( + p.arg.ctype_in, + p.name_lower, + i.camel_name, + ) function_pointers[key] = value # Sort according to @since tag, then name.. this ensures @@ -169,530 +205,799 @@ class HeaderCodeGenerator: # See https://bugzilla.gnome.org/show_bug.cgi?id=647577#c5 # for discussion for key in sorted(function_pointers.keys(), key=utils.version_cmp_key): - self.outfile.write('%s'%function_pointers[key]) - - self.outfile.write('};\n') - self.outfile.write('\n') - if self.generate_autocleanup == 'all': - self.outfile.write('#if GLIB_CHECK_VERSION(2, 44, 0)\n') - self.outfile.write('G_DEFINE_AUTOPTR_CLEANUP_FUNC (%s, g_object_unref)\n' % (i.camel_name)) - self.outfile.write('#endif\n') - self.outfile.write('\n') + self.outfile.write("%s" % function_pointers[key]) + + self.outfile.write("};\n") + self.outfile.write("\n") + if self.generate_autocleanup == "all": + self.outfile.write("#if GLIB_CHECK_VERSION(2, 44, 0)\n") + self.outfile.write( + "G_DEFINE_AUTOPTR_CLEANUP_FUNC (%s, g_object_unref)\n" + % (i.camel_name) + ) + self.outfile.write("#endif\n") + self.outfile.write("\n") if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('GType %s_get_type (void) G_GNUC_CONST;\n'%(i.name_lower)) - self.outfile.write('\n') + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "GType %s_get_type (void) G_GNUC_CONST;\n" % (i.name_lower) + ) + self.outfile.write("\n") if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('GDBusInterfaceInfo *%s_interface_info (void);\n'%(i.name_lower)) + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "GDBusInterfaceInfo *%s_interface_info (void);\n" % (i.name_lower) + ) if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('guint %s_override_properties (GObjectClass *klass, guint property_id_begin);\n'%(i.name_lower)) - self.outfile.write('\n') + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "guint %s_override_properties (GObjectClass *klass, guint property_id_begin);\n" + % (i.name_lower) + ) + self.outfile.write("\n") # Then method call completion functions if len(i.methods) > 0: - self.outfile.write('\n') - self.outfile.write('/* D-Bus method call completion functions: */\n') + self.outfile.write("\n") + self.outfile.write("/* D-Bus method call completion functions: */\n") for m in i.methods: if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if m.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('void %s_complete_%s (\n' - ' %s *object,\n' - ' GDBusMethodInvocation *invocation'%(i.name_lower, m.name_lower, i.camel_name)) + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "void %s_complete_%s (\n" + " %s *object,\n" + " GDBusMethodInvocation *invocation" + % (i.name_lower, m.name_lower, i.camel_name) + ) if m.unix_fd: - self.outfile.write(',\n GUnixFDList *fd_list') + self.outfile.write(",\n GUnixFDList *fd_list") for a in m.out_args: - self.outfile.write(',\n %s%s'%(a.ctype_in, a.name)) - self.outfile.write(');\n') - self.outfile.write('\n') - self.outfile.write('\n') + self.outfile.write(",\n %s%s" % (a.ctype_in, a.name)) + self.outfile.write(");\n") + self.outfile.write("\n") + self.outfile.write("\n") # Then signal emission functions if len(i.signals) > 0: - self.outfile.write('\n') - self.outfile.write('/* D-Bus signal emissions functions: */\n') + self.outfile.write("\n") + self.outfile.write("/* D-Bus signal emissions functions: */\n") for s in i.signals: if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if s.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('void %s_emit_%s (\n' - ' %s *object'%(i.name_lower, s.name_lower, i.camel_name)) + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "void %s_emit_%s (\n" + " %s *object" % (i.name_lower, s.name_lower, i.camel_name) + ) for a in s.args: - self.outfile.write(',\n %sarg_%s'%(a.ctype_in, a.name)) - self.outfile.write(');\n') - self.outfile.write('\n') - self.outfile.write('\n') + self.outfile.write(",\n %sarg_%s" % (a.ctype_in, a.name)) + self.outfile.write(");\n") + self.outfile.write("\n") + self.outfile.write("\n") # Then method call declarations if len(i.methods) > 0: - self.outfile.write('\n') - self.outfile.write('/* D-Bus method calls: */\n') + self.outfile.write("\n") + self.outfile.write("/* D-Bus method calls: */\n") for m in i.methods: # async begin if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if m.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('void %s_call_%s (\n' - ' %s *proxy'%(i.name_lower, m.name_lower, i.camel_name)) + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "void %s_call_%s (\n" + " %s *proxy" % (i.name_lower, m.name_lower, i.camel_name) + ) for a in m.in_args: - self.outfile.write(',\n %sarg_%s'%(a.ctype_in, a.name)) + self.outfile.write(",\n %sarg_%s" % (a.ctype_in, a.name)) if self.glib_min_required >= (2, 64): - self.outfile.write(',\n GDBusCallFlags call_flags' - ',\n gint timeout_msec') + self.outfile.write( + ",\n GDBusCallFlags call_flags" + ",\n gint timeout_msec" + ) if m.unix_fd: - self.outfile.write(',\n GUnixFDList *fd_list') - self.outfile.write(',\n' - ' GCancellable *cancellable,\n' - ' GAsyncReadyCallback callback,\n' - ' gpointer user_data);\n') - self.outfile.write('\n') + self.outfile.write(",\n GUnixFDList *fd_list") + self.outfile.write( + ",\n" + " GCancellable *cancellable,\n" + " GAsyncReadyCallback callback,\n" + " gpointer user_data);\n" + ) + self.outfile.write("\n") # async finish if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if m.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('gboolean %s_call_%s_finish (\n' - ' %s *proxy'%(i.name_lower, m.name_lower, i.camel_name)) + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "gboolean %s_call_%s_finish (\n" + " %s *proxy" % (i.name_lower, m.name_lower, i.camel_name) + ) for a in m.out_args: - self.outfile.write(',\n %sout_%s'%(a.ctype_out, a.name)) + self.outfile.write(",\n %sout_%s" % (a.ctype_out, a.name)) if m.unix_fd: - self.outfile.write(',\n GUnixFDList **out_fd_list') - self.outfile.write(',\n' - ' GAsyncResult *res,\n' - ' GError **error);\n') - self.outfile.write('\n') + self.outfile.write(",\n GUnixFDList **out_fd_list") + self.outfile.write( + ",\n" " GAsyncResult *res,\n" " GError **error);\n" + ) + self.outfile.write("\n") # sync if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if m.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('gboolean %s_call_%s_sync (\n' - ' %s *proxy'%(i.name_lower, m.name_lower, i.camel_name)) + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "gboolean %s_call_%s_sync (\n" + " %s *proxy" % (i.name_lower, m.name_lower, i.camel_name) + ) for a in m.in_args: - self.outfile.write(',\n %sarg_%s'%(a.ctype_in, a.name)) + self.outfile.write(",\n %sarg_%s" % (a.ctype_in, a.name)) if self.glib_min_required >= (2, 64): - self.outfile.write(',\n GDBusCallFlags call_flags' - ',\n gint timeout_msec') + self.outfile.write( + ",\n GDBusCallFlags call_flags" + ",\n gint timeout_msec" + ) if m.unix_fd: - self.outfile.write(',\n GUnixFDList *fd_list') + self.outfile.write(",\n GUnixFDList *fd_list") for a in m.out_args: - self.outfile.write(',\n %sout_%s'%(a.ctype_out, a.name)) + self.outfile.write(",\n %sout_%s" % (a.ctype_out, a.name)) if m.unix_fd: - self.outfile.write(',\n GUnixFDList **out_fd_list') - self.outfile.write(',\n' - ' GCancellable *cancellable,\n' - ' GError **error);\n') - self.outfile.write('\n') - self.outfile.write('\n') + self.outfile.write(",\n GUnixFDList **out_fd_list") + self.outfile.write( + ",\n" + " GCancellable *cancellable,\n" + " GError **error);\n" + ) + self.outfile.write("\n") + self.outfile.write("\n") # Then the property accessor declarations if len(i.properties) > 0: - self.outfile.write('\n') - self.outfile.write('/* D-Bus property accessors: */\n') + self.outfile.write("\n") + self.outfile.write("/* D-Bus property accessors: */\n") for p in i.properties: # getter if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if p.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('%s%s_get_%s (%s *object);\n'%(p.arg.ctype_in, i.name_lower, p.name_lower, i.camel_name)) + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "%s%s_get_%s (%s *object);\n" + % (p.arg.ctype_in, i.name_lower, p.name_lower, i.camel_name) + ) if p.arg.free_func != None: if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if p.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('%s%s_dup_%s (%s *object);\n'%(p.arg.ctype_in_dup, i.name_lower, p.name_lower, i.camel_name)) + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "%s%s_dup_%s (%s *object);\n" + % ( + p.arg.ctype_in_dup, + i.name_lower, + p.name_lower, + i.camel_name, + ) + ) # setter if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if p.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('void %s_set_%s (%s *object, %svalue);\n'%(i.name_lower, p.name_lower, i.camel_name, p.arg.ctype_in, )) - self.outfile.write('\n') + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "void %s_set_%s (%s *object, %svalue);\n" + % (i.name_lower, p.name_lower, i.camel_name, p.arg.ctype_in,) + ) + self.outfile.write("\n") # Then the proxy - self.outfile.write('\n') - self.outfile.write('/* ---- */\n') - self.outfile.write('\n') - self.outfile.write('#define %sTYPE_%s_PROXY (%s_proxy_get_type ())\n'%(i.ns_upper, i.name_upper, i.name_lower)) - self.outfile.write('#define %s%s_PROXY(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), %sTYPE_%s_PROXY, %sProxy))\n'%(i.ns_upper, i.name_upper, i.ns_upper, i.name_upper, i.camel_name)) - self.outfile.write('#define %s%s_PROXY_CLASS(k) (G_TYPE_CHECK_CLASS_CAST ((k), %sTYPE_%s_PROXY, %sProxyClass))\n'%(i.ns_upper, i.name_upper, i.ns_upper, i.name_upper, i.camel_name)) - self.outfile.write('#define %s%s_PROXY_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), %sTYPE_%s_PROXY, %sProxyClass))\n'%(i.ns_upper, i.name_upper, i.ns_upper, i.name_upper, i.camel_name)) - self.outfile.write('#define %sIS_%s_PROXY(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), %sTYPE_%s_PROXY))\n'%(i.ns_upper, i.name_upper, i.ns_upper, i.name_upper)) - self.outfile.write('#define %sIS_%s_PROXY_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), %sTYPE_%s_PROXY))\n'%(i.ns_upper, i.name_upper, i.ns_upper, i.name_upper)) - self.outfile.write('\n') - self.outfile.write('typedef struct _%sProxy %sProxy;\n'%(i.camel_name, i.camel_name)) - self.outfile.write('typedef struct _%sProxyClass %sProxyClass;\n'%(i.camel_name, i.camel_name)) - self.outfile.write('typedef struct _%sProxyPrivate %sProxyPrivate;\n'%(i.camel_name, i.camel_name)) - self.outfile.write('\n') - self.outfile.write('struct _%sProxy\n'%(i.camel_name)) - self.outfile.write('{\n') - self.outfile.write(' /*< private >*/\n') - self.outfile.write(' GDBusProxy parent_instance;\n') - self.outfile.write(' %sProxyPrivate *priv;\n'%(i.camel_name)) - self.outfile.write('};\n') - self.outfile.write('\n') - self.outfile.write('struct _%sProxyClass\n'%(i.camel_name)) - self.outfile.write('{\n') - self.outfile.write(' GDBusProxyClass parent_class;\n') - self.outfile.write('};\n') - self.outfile.write('\n') + self.outfile.write("\n") + self.outfile.write("/* ---- */\n") + self.outfile.write("\n") + self.outfile.write( + "#define %sTYPE_%s_PROXY (%s_proxy_get_type ())\n" + % (i.ns_upper, i.name_upper, i.name_lower) + ) + self.outfile.write( + "#define %s%s_PROXY(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), %sTYPE_%s_PROXY, %sProxy))\n" + % (i.ns_upper, i.name_upper, i.ns_upper, i.name_upper, i.camel_name) + ) + self.outfile.write( + "#define %s%s_PROXY_CLASS(k) (G_TYPE_CHECK_CLASS_CAST ((k), %sTYPE_%s_PROXY, %sProxyClass))\n" + % (i.ns_upper, i.name_upper, i.ns_upper, i.name_upper, i.camel_name) + ) + self.outfile.write( + "#define %s%s_PROXY_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), %sTYPE_%s_PROXY, %sProxyClass))\n" + % (i.ns_upper, i.name_upper, i.ns_upper, i.name_upper, i.camel_name) + ) + self.outfile.write( + "#define %sIS_%s_PROXY(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), %sTYPE_%s_PROXY))\n" + % (i.ns_upper, i.name_upper, i.ns_upper, i.name_upper) + ) + self.outfile.write( + "#define %sIS_%s_PROXY_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), %sTYPE_%s_PROXY))\n" + % (i.ns_upper, i.name_upper, i.ns_upper, i.name_upper) + ) + self.outfile.write("\n") + self.outfile.write( + "typedef struct _%sProxy %sProxy;\n" % (i.camel_name, i.camel_name) + ) + self.outfile.write( + "typedef struct _%sProxyClass %sProxyClass;\n" + % (i.camel_name, i.camel_name) + ) + self.outfile.write( + "typedef struct _%sProxyPrivate %sProxyPrivate;\n" + % (i.camel_name, i.camel_name) + ) + self.outfile.write("\n") + self.outfile.write("struct _%sProxy\n" % (i.camel_name)) + self.outfile.write("{\n") + self.outfile.write(" /*< private >*/\n") + self.outfile.write(" GDBusProxy parent_instance;\n") + self.outfile.write(" %sProxyPrivate *priv;\n" % (i.camel_name)) + self.outfile.write("};\n") + self.outfile.write("\n") + self.outfile.write("struct _%sProxyClass\n" % (i.camel_name)) + self.outfile.write("{\n") + self.outfile.write(" GDBusProxyClass parent_class;\n") + self.outfile.write("};\n") + self.outfile.write("\n") if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('GType %s_proxy_get_type (void) G_GNUC_CONST;\n'%(i.name_lower)) - self.outfile.write('\n') - if self.generate_autocleanup in ('objects', 'all'): - self.outfile.write('#if GLIB_CHECK_VERSION(2, 44, 0)\n') - self.outfile.write('G_DEFINE_AUTOPTR_CLEANUP_FUNC (%sProxy, g_object_unref)\n' % (i.camel_name)) - self.outfile.write('#endif\n') - self.outfile.write('\n') + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "GType %s_proxy_get_type (void) G_GNUC_CONST;\n" % (i.name_lower) + ) + self.outfile.write("\n") + if self.generate_autocleanup in ("objects", "all"): + self.outfile.write("#if GLIB_CHECK_VERSION(2, 44, 0)\n") + self.outfile.write( + "G_DEFINE_AUTOPTR_CLEANUP_FUNC (%sProxy, g_object_unref)\n" + % (i.camel_name) + ) + self.outfile.write("#endif\n") + self.outfile.write("\n") if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if i.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('void %s_proxy_new (\n' - ' GDBusConnection *connection,\n' - ' GDBusProxyFlags flags,\n' - ' const gchar *name,\n' - ' const gchar *object_path,\n' - ' GCancellable *cancellable,\n' - ' GAsyncReadyCallback callback,\n' - ' gpointer user_data);\n' - %(i.name_lower)) + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "void %s_proxy_new (\n" + " GDBusConnection *connection,\n" + " GDBusProxyFlags flags,\n" + " const gchar *name,\n" + " const gchar *object_path,\n" + " GCancellable *cancellable,\n" + " GAsyncReadyCallback callback,\n" + " gpointer user_data);\n" % (i.name_lower) + ) if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if i.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('%s *%s_proxy_new_finish (\n' - ' GAsyncResult *res,\n' - ' GError **error);\n' - %(i.camel_name, i.name_lower)) + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "%s *%s_proxy_new_finish (\n" + " GAsyncResult *res,\n" + " GError **error);\n" % (i.camel_name, i.name_lower) + ) if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if i.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('%s *%s_proxy_new_sync (\n' - ' GDBusConnection *connection,\n' - ' GDBusProxyFlags flags,\n' - ' const gchar *name,\n' - ' const gchar *object_path,\n' - ' GCancellable *cancellable,\n' - ' GError **error);\n' - %(i.camel_name, i.name_lower)) - self.outfile.write('\n') + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "%s *%s_proxy_new_sync (\n" + " GDBusConnection *connection,\n" + " GDBusProxyFlags flags,\n" + " const gchar *name,\n" + " const gchar *object_path,\n" + " GCancellable *cancellable,\n" + " GError **error);\n" % (i.camel_name, i.name_lower) + ) + self.outfile.write("\n") if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if i.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('void %s_proxy_new_for_bus (\n' - ' GBusType bus_type,\n' - ' GDBusProxyFlags flags,\n' - ' const gchar *name,\n' - ' const gchar *object_path,\n' - ' GCancellable *cancellable,\n' - ' GAsyncReadyCallback callback,\n' - ' gpointer user_data);\n' - %(i.name_lower)) + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "void %s_proxy_new_for_bus (\n" + " GBusType bus_type,\n" + " GDBusProxyFlags flags,\n" + " const gchar *name,\n" + " const gchar *object_path,\n" + " GCancellable *cancellable,\n" + " GAsyncReadyCallback callback,\n" + " gpointer user_data);\n" % (i.name_lower) + ) if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if i.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('%s *%s_proxy_new_for_bus_finish (\n' - ' GAsyncResult *res,\n' - ' GError **error);\n' - %(i.camel_name, i.name_lower)) + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "%s *%s_proxy_new_for_bus_finish (\n" + " GAsyncResult *res,\n" + " GError **error);\n" % (i.camel_name, i.name_lower) + ) if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if i.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('%s *%s_proxy_new_for_bus_sync (\n' - ' GBusType bus_type,\n' - ' GDBusProxyFlags flags,\n' - ' const gchar *name,\n' - ' const gchar *object_path,\n' - ' GCancellable *cancellable,\n' - ' GError **error);\n' - %(i.camel_name, i.name_lower)) - self.outfile.write('\n') + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "%s *%s_proxy_new_for_bus_sync (\n" + " GBusType bus_type,\n" + " GDBusProxyFlags flags,\n" + " const gchar *name,\n" + " const gchar *object_path,\n" + " GCancellable *cancellable,\n" + " GError **error);\n" % (i.camel_name, i.name_lower) + ) + self.outfile.write("\n") # Then the skeleton - self.outfile.write('\n') - self.outfile.write('/* ---- */\n') - self.outfile.write('\n') - self.outfile.write('#define %sTYPE_%s_SKELETON (%s_skeleton_get_type ())\n'%(i.ns_upper, i.name_upper, i.name_lower)) - self.outfile.write('#define %s%s_SKELETON(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), %sTYPE_%s_SKELETON, %sSkeleton))\n'%(i.ns_upper, i.name_upper, i.ns_upper, i.name_upper, i.camel_name)) - self.outfile.write('#define %s%s_SKELETON_CLASS(k) (G_TYPE_CHECK_CLASS_CAST ((k), %sTYPE_%s_SKELETON, %sSkeletonClass))\n'%(i.ns_upper, i.name_upper, i.ns_upper, i.name_upper, i.camel_name)) - self.outfile.write('#define %s%s_SKELETON_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), %sTYPE_%s_SKELETON, %sSkeletonClass))\n'%(i.ns_upper, i.name_upper, i.ns_upper, i.name_upper, i.camel_name)) - self.outfile.write('#define %sIS_%s_SKELETON(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), %sTYPE_%s_SKELETON))\n'%(i.ns_upper, i.name_upper, i.ns_upper, i.name_upper)) - self.outfile.write('#define %sIS_%s_SKELETON_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), %sTYPE_%s_SKELETON))\n'%(i.ns_upper, i.name_upper, i.ns_upper, i.name_upper)) - self.outfile.write('\n') - self.outfile.write('typedef struct _%sSkeleton %sSkeleton;\n'%(i.camel_name, i.camel_name)) - self.outfile.write('typedef struct _%sSkeletonClass %sSkeletonClass;\n'%(i.camel_name, i.camel_name)) - self.outfile.write('typedef struct _%sSkeletonPrivate %sSkeletonPrivate;\n'%(i.camel_name, i.camel_name)) - self.outfile.write('\n') - self.outfile.write('struct _%sSkeleton\n'%(i.camel_name)) - self.outfile.write('{\n') - self.outfile.write(' /*< private >*/\n') - self.outfile.write(' GDBusInterfaceSkeleton parent_instance;\n') - self.outfile.write(' %sSkeletonPrivate *priv;\n'%(i.camel_name)) - self.outfile.write('};\n') - self.outfile.write('\n') - self.outfile.write('struct _%sSkeletonClass\n'%(i.camel_name)) - self.outfile.write('{\n') - self.outfile.write(' GDBusInterfaceSkeletonClass parent_class;\n') - self.outfile.write('};\n') - self.outfile.write('\n') + self.outfile.write("\n") + self.outfile.write("/* ---- */\n") + self.outfile.write("\n") + self.outfile.write( + "#define %sTYPE_%s_SKELETON (%s_skeleton_get_type ())\n" + % (i.ns_upper, i.name_upper, i.name_lower) + ) + self.outfile.write( + "#define %s%s_SKELETON(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), %sTYPE_%s_SKELETON, %sSkeleton))\n" + % (i.ns_upper, i.name_upper, i.ns_upper, i.name_upper, i.camel_name) + ) + self.outfile.write( + "#define %s%s_SKELETON_CLASS(k) (G_TYPE_CHECK_CLASS_CAST ((k), %sTYPE_%s_SKELETON, %sSkeletonClass))\n" + % (i.ns_upper, i.name_upper, i.ns_upper, i.name_upper, i.camel_name) + ) + self.outfile.write( + "#define %s%s_SKELETON_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), %sTYPE_%s_SKELETON, %sSkeletonClass))\n" + % (i.ns_upper, i.name_upper, i.ns_upper, i.name_upper, i.camel_name) + ) + self.outfile.write( + "#define %sIS_%s_SKELETON(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), %sTYPE_%s_SKELETON))\n" + % (i.ns_upper, i.name_upper, i.ns_upper, i.name_upper) + ) + self.outfile.write( + "#define %sIS_%s_SKELETON_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), %sTYPE_%s_SKELETON))\n" + % (i.ns_upper, i.name_upper, i.ns_upper, i.name_upper) + ) + self.outfile.write("\n") + self.outfile.write( + "typedef struct _%sSkeleton %sSkeleton;\n" + % (i.camel_name, i.camel_name) + ) + self.outfile.write( + "typedef struct _%sSkeletonClass %sSkeletonClass;\n" + % (i.camel_name, i.camel_name) + ) + self.outfile.write( + "typedef struct _%sSkeletonPrivate %sSkeletonPrivate;\n" + % (i.camel_name, i.camel_name) + ) + self.outfile.write("\n") + self.outfile.write("struct _%sSkeleton\n" % (i.camel_name)) + self.outfile.write("{\n") + self.outfile.write(" /*< private >*/\n") + self.outfile.write(" GDBusInterfaceSkeleton parent_instance;\n") + self.outfile.write(" %sSkeletonPrivate *priv;\n" % (i.camel_name)) + self.outfile.write("};\n") + self.outfile.write("\n") + self.outfile.write("struct _%sSkeletonClass\n" % (i.camel_name)) + self.outfile.write("{\n") + self.outfile.write(" GDBusInterfaceSkeletonClass parent_class;\n") + self.outfile.write("};\n") + self.outfile.write("\n") if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('GType %s_skeleton_get_type (void) G_GNUC_CONST;\n'%(i.name_lower)) - self.outfile.write('\n') - if self.generate_autocleanup in ('objects', 'all'): - self.outfile.write('#if GLIB_CHECK_VERSION(2, 44, 0)\n') - self.outfile.write('G_DEFINE_AUTOPTR_CLEANUP_FUNC (%sSkeleton, g_object_unref)\n' % (i.camel_name)) - self.outfile.write('#endif\n') - self.outfile.write('\n') + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "GType %s_skeleton_get_type (void) G_GNUC_CONST;\n" % (i.name_lower) + ) + self.outfile.write("\n") + if self.generate_autocleanup in ("objects", "all"): + self.outfile.write("#if GLIB_CHECK_VERSION(2, 44, 0)\n") + self.outfile.write( + "G_DEFINE_AUTOPTR_CLEANUP_FUNC (%sSkeleton, g_object_unref)\n" + % (i.camel_name) + ) + self.outfile.write("#endif\n") + self.outfile.write("\n") if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if i.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('%s *%s_skeleton_new (void);\n'%(i.camel_name, i.name_lower)) + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "%s *%s_skeleton_new (void);\n" % (i.camel_name, i.name_lower) + ) - self.outfile.write('\n') + self.outfile.write("\n") # Finally, the Object, ObjectProxy, ObjectSkeleton and ObjectManagerClient if self.generate_objmanager: - self.outfile.write('\n') - self.outfile.write('/* ---- */\n') - self.outfile.write('\n') - self.outfile.write('#define %sTYPE_OBJECT (%sobject_get_type ())\n'%(self.ns_upper, self.ns_lower)) - self.outfile.write('#define %sOBJECT(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), %sTYPE_OBJECT, %sObject))\n'%(self.ns_upper, self.ns_upper, self.namespace)) - self.outfile.write('#define %sIS_OBJECT(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), %sTYPE_OBJECT))\n'%(self.ns_upper, self.ns_upper)) - self.outfile.write('#define %sOBJECT_GET_IFACE(o) (G_TYPE_INSTANCE_GET_INTERFACE ((o), %sTYPE_OBJECT, %sObject))\n'%(self.ns_upper, self.ns_upper, self.namespace)) - self.outfile.write('\n') - self.outfile.write('struct _%sObject;\n'%(self.namespace)) - self.outfile.write('typedef struct _%sObject %sObject;\n'%(self.namespace, self.namespace)) - self.outfile.write('typedef struct _%sObjectIface %sObjectIface;\n'%(self.namespace, self.namespace)) - self.outfile.write('\n') - self.outfile.write('struct _%sObjectIface\n'%(self.namespace)) - self.outfile.write('{\n' - ' GTypeInterface parent_iface;\n' - '};\n' - '\n') + self.outfile.write("\n") + self.outfile.write("/* ---- */\n") + self.outfile.write("\n") + self.outfile.write( + "#define %sTYPE_OBJECT (%sobject_get_type ())\n" + % (self.ns_upper, self.ns_lower) + ) + self.outfile.write( + "#define %sOBJECT(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), %sTYPE_OBJECT, %sObject))\n" + % (self.ns_upper, self.ns_upper, self.namespace) + ) + self.outfile.write( + "#define %sIS_OBJECT(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), %sTYPE_OBJECT))\n" + % (self.ns_upper, self.ns_upper) + ) + self.outfile.write( + "#define %sOBJECT_GET_IFACE(o) (G_TYPE_INSTANCE_GET_INTERFACE ((o), %sTYPE_OBJECT, %sObject))\n" + % (self.ns_upper, self.ns_upper, self.namespace) + ) + self.outfile.write("\n") + self.outfile.write("struct _%sObject;\n" % (self.namespace)) + self.outfile.write( + "typedef struct _%sObject %sObject;\n" + % (self.namespace, self.namespace) + ) + self.outfile.write( + "typedef struct _%sObjectIface %sObjectIface;\n" + % (self.namespace, self.namespace) + ) + self.outfile.write("\n") + self.outfile.write("struct _%sObjectIface\n" % (self.namespace)) + self.outfile.write("{\n" " GTypeInterface parent_iface;\n" "};\n" "\n") if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('GType %sobject_get_type (void) G_GNUC_CONST;\n' - '\n' - %(self.ns_lower)) - if self.generate_autocleanup == 'all': - self.outfile.write('#if GLIB_CHECK_VERSION(2, 44, 0)\n') - self.outfile.write('G_DEFINE_AUTOPTR_CLEANUP_FUNC (%sObject, g_object_unref)\n' % (self.namespace)) - self.outfile.write('#endif\n') - self.outfile.write('\n') + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "GType %sobject_get_type (void) G_GNUC_CONST;\n" "\n" % (self.ns_lower) + ) + if self.generate_autocleanup == "all": + self.outfile.write("#if GLIB_CHECK_VERSION(2, 44, 0)\n") + self.outfile.write( + "G_DEFINE_AUTOPTR_CLEANUP_FUNC (%sObject, g_object_unref)\n" + % (self.namespace) + ) + self.outfile.write("#endif\n") + self.outfile.write("\n") for i in self.ifaces: if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if i.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('%s *%sobject_get_%s (%sObject *object);\n' - %(i.camel_name, self.ns_lower, i.name_upper.lower(), self.namespace)) + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "%s *%sobject_get_%s (%sObject *object);\n" + % ( + i.camel_name, + self.ns_lower, + i.name_upper.lower(), + self.namespace, + ) + ) for i in self.ifaces: if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if i.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('%s *%sobject_peek_%s (%sObject *object);\n' - %(i.camel_name, self.ns_lower, i.name_upper.lower(), self.namespace)) - self.outfile.write('\n') - self.outfile.write('#define %sTYPE_OBJECT_PROXY (%sobject_proxy_get_type ())\n'%(self.ns_upper, self.ns_lower)) - self.outfile.write('#define %sOBJECT_PROXY(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), %sTYPE_OBJECT_PROXY, %sObjectProxy))\n'%(self.ns_upper, self.ns_upper, self.namespace)) - self.outfile.write('#define %sOBJECT_PROXY_CLASS(k) (G_TYPE_CHECK_CLASS_CAST ((k), %sTYPE_OBJECT_PROXY, %sObjectProxyClass))\n'%(self.ns_upper, self.ns_upper, self.namespace)) - self.outfile.write('#define %sOBJECT_PROXY_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), %sTYPE_OBJECT_PROXY, %sObjectProxyClass))\n'%(self.ns_upper, self.ns_upper, self.namespace)) - self.outfile.write('#define %sIS_OBJECT_PROXY(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), %sTYPE_OBJECT_PROXY))\n'%(self.ns_upper, self.ns_upper)) - self.outfile.write('#define %sIS_OBJECT_PROXY_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), %sTYPE_OBJECT_PROXY))\n'%(self.ns_upper, self.ns_upper)) - self.outfile.write('\n') - self.outfile.write('typedef struct _%sObjectProxy %sObjectProxy;\n'%(self.namespace, self.namespace)) - self.outfile.write('typedef struct _%sObjectProxyClass %sObjectProxyClass;\n'%(self.namespace, self.namespace)) - self.outfile.write('typedef struct _%sObjectProxyPrivate %sObjectProxyPrivate;\n'%(self.namespace, self.namespace)) - self.outfile.write('\n') - self.outfile.write('struct _%sObjectProxy\n'%(self.namespace)) - self.outfile.write('{\n') - self.outfile.write(' /*< private >*/\n') - self.outfile.write(' GDBusObjectProxy parent_instance;\n') - self.outfile.write(' %sObjectProxyPrivate *priv;\n'%(self.namespace)) - self.outfile.write('};\n') - self.outfile.write('\n') - self.outfile.write('struct _%sObjectProxyClass\n'%(self.namespace)) - self.outfile.write('{\n') - self.outfile.write(' GDBusObjectProxyClass parent_class;\n') - self.outfile.write('};\n') - self.outfile.write('\n') + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "%s *%sobject_peek_%s (%sObject *object);\n" + % ( + i.camel_name, + self.ns_lower, + i.name_upper.lower(), + self.namespace, + ) + ) + self.outfile.write("\n") + self.outfile.write( + "#define %sTYPE_OBJECT_PROXY (%sobject_proxy_get_type ())\n" + % (self.ns_upper, self.ns_lower) + ) + self.outfile.write( + "#define %sOBJECT_PROXY(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), %sTYPE_OBJECT_PROXY, %sObjectProxy))\n" + % (self.ns_upper, self.ns_upper, self.namespace) + ) + self.outfile.write( + "#define %sOBJECT_PROXY_CLASS(k) (G_TYPE_CHECK_CLASS_CAST ((k), %sTYPE_OBJECT_PROXY, %sObjectProxyClass))\n" + % (self.ns_upper, self.ns_upper, self.namespace) + ) + self.outfile.write( + "#define %sOBJECT_PROXY_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), %sTYPE_OBJECT_PROXY, %sObjectProxyClass))\n" + % (self.ns_upper, self.ns_upper, self.namespace) + ) + self.outfile.write( + "#define %sIS_OBJECT_PROXY(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), %sTYPE_OBJECT_PROXY))\n" + % (self.ns_upper, self.ns_upper) + ) + self.outfile.write( + "#define %sIS_OBJECT_PROXY_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), %sTYPE_OBJECT_PROXY))\n" + % (self.ns_upper, self.ns_upper) + ) + self.outfile.write("\n") + self.outfile.write( + "typedef struct _%sObjectProxy %sObjectProxy;\n" + % (self.namespace, self.namespace) + ) + self.outfile.write( + "typedef struct _%sObjectProxyClass %sObjectProxyClass;\n" + % (self.namespace, self.namespace) + ) + self.outfile.write( + "typedef struct _%sObjectProxyPrivate %sObjectProxyPrivate;\n" + % (self.namespace, self.namespace) + ) + self.outfile.write("\n") + self.outfile.write("struct _%sObjectProxy\n" % (self.namespace)) + self.outfile.write("{\n") + self.outfile.write(" /*< private >*/\n") + self.outfile.write(" GDBusObjectProxy parent_instance;\n") + self.outfile.write(" %sObjectProxyPrivate *priv;\n" % (self.namespace)) + self.outfile.write("};\n") + self.outfile.write("\n") + self.outfile.write("struct _%sObjectProxyClass\n" % (self.namespace)) + self.outfile.write("{\n") + self.outfile.write(" GDBusObjectProxyClass parent_class;\n") + self.outfile.write("};\n") + self.outfile.write("\n") if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('GType %sobject_proxy_get_type (void) G_GNUC_CONST;\n'%(self.ns_lower)) - self.outfile.write('\n') - if self.generate_autocleanup in ('objects', 'all'): - self.outfile.write('#if GLIB_CHECK_VERSION(2, 44, 0)\n') - self.outfile.write('G_DEFINE_AUTOPTR_CLEANUP_FUNC (%sObjectProxy, g_object_unref)\n' % (self.namespace)) - self.outfile.write('#endif\n') - self.outfile.write('\n') + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "GType %sobject_proxy_get_type (void) G_GNUC_CONST;\n" % (self.ns_lower) + ) + self.outfile.write("\n") + if self.generate_autocleanup in ("objects", "all"): + self.outfile.write("#if GLIB_CHECK_VERSION(2, 44, 0)\n") + self.outfile.write( + "G_DEFINE_AUTOPTR_CLEANUP_FUNC (%sObjectProxy, g_object_unref)\n" + % (self.namespace) + ) + self.outfile.write("#endif\n") + self.outfile.write("\n") if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('%sObjectProxy *%sobject_proxy_new (GDBusConnection *connection, const gchar *object_path);\n'%(self.namespace, self.ns_lower)) - self.outfile.write('\n') - self.outfile.write('#define %sTYPE_OBJECT_SKELETON (%sobject_skeleton_get_type ())\n'%(self.ns_upper, self.ns_lower)) - self.outfile.write('#define %sOBJECT_SKELETON(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), %sTYPE_OBJECT_SKELETON, %sObjectSkeleton))\n'%(self.ns_upper, self.ns_upper, self.namespace)) - self.outfile.write('#define %sOBJECT_SKELETON_CLASS(k) (G_TYPE_CHECK_CLASS_CAST ((k), %sTYPE_OBJECT_SKELETON, %sObjectSkeletonClass))\n'%(self.ns_upper, self.ns_upper, self.namespace)) - self.outfile.write('#define %sOBJECT_SKELETON_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), %sTYPE_OBJECT_SKELETON, %sObjectSkeletonClass))\n'%(self.ns_upper, self.ns_upper, self.namespace)) - self.outfile.write('#define %sIS_OBJECT_SKELETON(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), %sTYPE_OBJECT_SKELETON))\n'%(self.ns_upper, self.ns_upper)) - self.outfile.write('#define %sIS_OBJECT_SKELETON_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), %sTYPE_OBJECT_SKELETON))\n'%(self.ns_upper, self.ns_upper)) - self.outfile.write('\n') - self.outfile.write('typedef struct _%sObjectSkeleton %sObjectSkeleton;\n'%(self.namespace, self.namespace)) - self.outfile.write('typedef struct _%sObjectSkeletonClass %sObjectSkeletonClass;\n'%(self.namespace, self.namespace)) - self.outfile.write('typedef struct _%sObjectSkeletonPrivate %sObjectSkeletonPrivate;\n'%(self.namespace, self.namespace)) - self.outfile.write('\n') - self.outfile.write('struct _%sObjectSkeleton\n'%(self.namespace)) - self.outfile.write('{\n') - self.outfile.write(' /*< private >*/\n') - self.outfile.write(' GDBusObjectSkeleton parent_instance;\n') - self.outfile.write(' %sObjectSkeletonPrivate *priv;\n'%(self.namespace)) - self.outfile.write('};\n') - self.outfile.write('\n') - self.outfile.write('struct _%sObjectSkeletonClass\n'%(self.namespace)) - self.outfile.write('{\n') - self.outfile.write(' GDBusObjectSkeletonClass parent_class;\n') - self.outfile.write('};\n') - self.outfile.write('\n') + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "%sObjectProxy *%sobject_proxy_new (GDBusConnection *connection, const gchar *object_path);\n" + % (self.namespace, self.ns_lower) + ) + self.outfile.write("\n") + self.outfile.write( + "#define %sTYPE_OBJECT_SKELETON (%sobject_skeleton_get_type ())\n" + % (self.ns_upper, self.ns_lower) + ) + self.outfile.write( + "#define %sOBJECT_SKELETON(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), %sTYPE_OBJECT_SKELETON, %sObjectSkeleton))\n" + % (self.ns_upper, self.ns_upper, self.namespace) + ) + self.outfile.write( + "#define %sOBJECT_SKELETON_CLASS(k) (G_TYPE_CHECK_CLASS_CAST ((k), %sTYPE_OBJECT_SKELETON, %sObjectSkeletonClass))\n" + % (self.ns_upper, self.ns_upper, self.namespace) + ) + self.outfile.write( + "#define %sOBJECT_SKELETON_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), %sTYPE_OBJECT_SKELETON, %sObjectSkeletonClass))\n" + % (self.ns_upper, self.ns_upper, self.namespace) + ) + self.outfile.write( + "#define %sIS_OBJECT_SKELETON(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), %sTYPE_OBJECT_SKELETON))\n" + % (self.ns_upper, self.ns_upper) + ) + self.outfile.write( + "#define %sIS_OBJECT_SKELETON_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), %sTYPE_OBJECT_SKELETON))\n" + % (self.ns_upper, self.ns_upper) + ) + self.outfile.write("\n") + self.outfile.write( + "typedef struct _%sObjectSkeleton %sObjectSkeleton;\n" + % (self.namespace, self.namespace) + ) + self.outfile.write( + "typedef struct _%sObjectSkeletonClass %sObjectSkeletonClass;\n" + % (self.namespace, self.namespace) + ) + self.outfile.write( + "typedef struct _%sObjectSkeletonPrivate %sObjectSkeletonPrivate;\n" + % (self.namespace, self.namespace) + ) + self.outfile.write("\n") + self.outfile.write("struct _%sObjectSkeleton\n" % (self.namespace)) + self.outfile.write("{\n") + self.outfile.write(" /*< private >*/\n") + self.outfile.write(" GDBusObjectSkeleton parent_instance;\n") + self.outfile.write(" %sObjectSkeletonPrivate *priv;\n" % (self.namespace)) + self.outfile.write("};\n") + self.outfile.write("\n") + self.outfile.write("struct _%sObjectSkeletonClass\n" % (self.namespace)) + self.outfile.write("{\n") + self.outfile.write(" GDBusObjectSkeletonClass parent_class;\n") + self.outfile.write("};\n") + self.outfile.write("\n") if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('GType %sobject_skeleton_get_type (void) G_GNUC_CONST;\n'%(self.ns_lower)) - self.outfile.write('\n') - if self.generate_autocleanup in ('objects', 'all'): - self.outfile.write('#if GLIB_CHECK_VERSION(2, 44, 0)\n') - self.outfile.write('G_DEFINE_AUTOPTR_CLEANUP_FUNC (%sObjectSkeleton, g_object_unref)\n' % (self.namespace)) - self.outfile.write('#endif\n') - self.outfile.write('\n') + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "GType %sobject_skeleton_get_type (void) G_GNUC_CONST;\n" + % (self.ns_lower) + ) + self.outfile.write("\n") + if self.generate_autocleanup in ("objects", "all"): + self.outfile.write("#if GLIB_CHECK_VERSION(2, 44, 0)\n") + self.outfile.write( + "G_DEFINE_AUTOPTR_CLEANUP_FUNC (%sObjectSkeleton, g_object_unref)\n" + % (self.namespace) + ) + self.outfile.write("#endif\n") + self.outfile.write("\n") if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('%sObjectSkeleton *%sobject_skeleton_new (const gchar *object_path);\n' - %(self.namespace, self.ns_lower)) + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "%sObjectSkeleton *%sobject_skeleton_new (const gchar *object_path);\n" + % (self.namespace, self.ns_lower) + ) for i in self.ifaces: if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) + self.outfile.write("%s\n" % self.symbol_decorator) if i.deprecated: - self.outfile.write('G_GNUC_DEPRECATED ') - self.outfile.write('void %sobject_skeleton_set_%s (%sObjectSkeleton *object, %s *interface_);\n' - %(self.ns_lower, i.name_upper.lower(), self.namespace, i.camel_name)) - self.outfile.write('\n') - - self.outfile.write('/* ---- */\n') - self.outfile.write('\n') - self.outfile.write('#define %sTYPE_OBJECT_MANAGER_CLIENT (%sobject_manager_client_get_type ())\n'%(self.ns_upper, self.ns_lower)) - self.outfile.write('#define %sOBJECT_MANAGER_CLIENT(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), %sTYPE_OBJECT_MANAGER_CLIENT, %sObjectManagerClient))\n'%(self.ns_upper, self.ns_upper, self.namespace)) - self.outfile.write('#define %sOBJECT_MANAGER_CLIENT_CLASS(k) (G_TYPE_CHECK_CLASS_CAST ((k), %sTYPE_OBJECT_MANAGER_CLIENT, %sObjectManagerClientClass))\n'%(self.ns_upper, self.ns_upper, self.namespace)) - self.outfile.write('#define %sOBJECT_MANAGER_CLIENT_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), %sTYPE_OBJECT_MANAGER_CLIENT, %sObjectManagerClientClass))\n'%(self.ns_upper, self.ns_upper, self.namespace)) - self.outfile.write('#define %sIS_OBJECT_MANAGER_CLIENT(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), %sTYPE_OBJECT_MANAGER_CLIENT))\n'%(self.ns_upper, self.ns_upper)) - self.outfile.write('#define %sIS_OBJECT_MANAGER_CLIENT_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), %sTYPE_OBJECT_MANAGER_CLIENT))\n'%(self.ns_upper, self.ns_upper)) - self.outfile.write('\n') - self.outfile.write('typedef struct _%sObjectManagerClient %sObjectManagerClient;\n'%(self.namespace, self.namespace)) - self.outfile.write('typedef struct _%sObjectManagerClientClass %sObjectManagerClientClass;\n'%(self.namespace, self.namespace)) - self.outfile.write('typedef struct _%sObjectManagerClientPrivate %sObjectManagerClientPrivate;\n'%(self.namespace, self.namespace)) - self.outfile.write('\n') - self.outfile.write('struct _%sObjectManagerClient\n'%(self.namespace)) - self.outfile.write('{\n') - self.outfile.write(' /*< private >*/\n') - self.outfile.write(' GDBusObjectManagerClient parent_instance;\n') - self.outfile.write(' %sObjectManagerClientPrivate *priv;\n'%(self.namespace)) - self.outfile.write('};\n') - self.outfile.write('\n') - self.outfile.write('struct _%sObjectManagerClientClass\n'%(self.namespace)) - self.outfile.write('{\n') - self.outfile.write(' GDBusObjectManagerClientClass parent_class;\n') - self.outfile.write('};\n') - self.outfile.write('\n') - if self.generate_autocleanup in ('objects', 'all'): - self.outfile.write('#if GLIB_CHECK_VERSION(2, 44, 0)\n') - self.outfile.write('G_DEFINE_AUTOPTR_CLEANUP_FUNC (%sObjectManagerClient, g_object_unref)\n' % (self.namespace)) - self.outfile.write('#endif\n') - self.outfile.write('\n') + self.outfile.write("G_GNUC_DEPRECATED ") + self.outfile.write( + "void %sobject_skeleton_set_%s (%sObjectSkeleton *object, %s *interface_);\n" + % ( + self.ns_lower, + i.name_upper.lower(), + self.namespace, + i.camel_name, + ) + ) + self.outfile.write("\n") + + self.outfile.write("/* ---- */\n") + self.outfile.write("\n") + self.outfile.write( + "#define %sTYPE_OBJECT_MANAGER_CLIENT (%sobject_manager_client_get_type ())\n" + % (self.ns_upper, self.ns_lower) + ) + self.outfile.write( + "#define %sOBJECT_MANAGER_CLIENT(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), %sTYPE_OBJECT_MANAGER_CLIENT, %sObjectManagerClient))\n" + % (self.ns_upper, self.ns_upper, self.namespace) + ) + self.outfile.write( + "#define %sOBJECT_MANAGER_CLIENT_CLASS(k) (G_TYPE_CHECK_CLASS_CAST ((k), %sTYPE_OBJECT_MANAGER_CLIENT, %sObjectManagerClientClass))\n" + % (self.ns_upper, self.ns_upper, self.namespace) + ) + self.outfile.write( + "#define %sOBJECT_MANAGER_CLIENT_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), %sTYPE_OBJECT_MANAGER_CLIENT, %sObjectManagerClientClass))\n" + % (self.ns_upper, self.ns_upper, self.namespace) + ) + self.outfile.write( + "#define %sIS_OBJECT_MANAGER_CLIENT(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), %sTYPE_OBJECT_MANAGER_CLIENT))\n" + % (self.ns_upper, self.ns_upper) + ) + self.outfile.write( + "#define %sIS_OBJECT_MANAGER_CLIENT_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), %sTYPE_OBJECT_MANAGER_CLIENT))\n" + % (self.ns_upper, self.ns_upper) + ) + self.outfile.write("\n") + self.outfile.write( + "typedef struct _%sObjectManagerClient %sObjectManagerClient;\n" + % (self.namespace, self.namespace) + ) + self.outfile.write( + "typedef struct _%sObjectManagerClientClass %sObjectManagerClientClass;\n" + % (self.namespace, self.namespace) + ) + self.outfile.write( + "typedef struct _%sObjectManagerClientPrivate %sObjectManagerClientPrivate;\n" + % (self.namespace, self.namespace) + ) + self.outfile.write("\n") + self.outfile.write("struct _%sObjectManagerClient\n" % (self.namespace)) + self.outfile.write("{\n") + self.outfile.write(" /*< private >*/\n") + self.outfile.write(" GDBusObjectManagerClient parent_instance;\n") + self.outfile.write( + " %sObjectManagerClientPrivate *priv;\n" % (self.namespace) + ) + self.outfile.write("};\n") + self.outfile.write("\n") + self.outfile.write( + "struct _%sObjectManagerClientClass\n" % (self.namespace) + ) + self.outfile.write("{\n") + self.outfile.write(" GDBusObjectManagerClientClass parent_class;\n") + self.outfile.write("};\n") + self.outfile.write("\n") + if self.generate_autocleanup in ("objects", "all"): + self.outfile.write("#if GLIB_CHECK_VERSION(2, 44, 0)\n") + self.outfile.write( + "G_DEFINE_AUTOPTR_CLEANUP_FUNC (%sObjectManagerClient, g_object_unref)\n" + % (self.namespace) + ) + self.outfile.write("#endif\n") + self.outfile.write("\n") if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('GType %sobject_manager_client_get_type (void) G_GNUC_CONST;\n'%(self.ns_lower)) - self.outfile.write('\n') + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "GType %sobject_manager_client_get_type (void) G_GNUC_CONST;\n" + % (self.ns_lower) + ) + self.outfile.write("\n") if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('GType %sobject_manager_client_get_proxy_type (GDBusObjectManagerClient *manager, const gchar *object_path, const gchar *interface_name, gpointer user_data);\n'%(self.ns_lower)) - self.outfile.write('\n') + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "GType %sobject_manager_client_get_proxy_type (GDBusObjectManagerClient *manager, const gchar *object_path, const gchar *interface_name, gpointer user_data);\n" + % (self.ns_lower) + ) + self.outfile.write("\n") if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('void %sobject_manager_client_new (\n' - ' GDBusConnection *connection,\n' - ' GDBusObjectManagerClientFlags flags,\n' - ' const gchar *name,\n' - ' const gchar *object_path,\n' - ' GCancellable *cancellable,\n' - ' GAsyncReadyCallback callback,\n' - ' gpointer user_data);\n' - %(self.ns_lower)) + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "void %sobject_manager_client_new (\n" + " GDBusConnection *connection,\n" + " GDBusObjectManagerClientFlags flags,\n" + " const gchar *name,\n" + " const gchar *object_path,\n" + " GCancellable *cancellable,\n" + " GAsyncReadyCallback callback,\n" + " gpointer user_data);\n" % (self.ns_lower) + ) if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('GDBusObjectManager *%sobject_manager_client_new_finish (\n' - ' GAsyncResult *res,\n' - ' GError **error);\n' - %(self.ns_lower)) + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "GDBusObjectManager *%sobject_manager_client_new_finish (\n" + " GAsyncResult *res,\n" + " GError **error);\n" % (self.ns_lower) + ) if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('GDBusObjectManager *%sobject_manager_client_new_sync (\n' - ' GDBusConnection *connection,\n' - ' GDBusObjectManagerClientFlags flags,\n' - ' const gchar *name,\n' - ' const gchar *object_path,\n' - ' GCancellable *cancellable,\n' - ' GError **error);\n' - %(self.ns_lower)) - self.outfile.write('\n') + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "GDBusObjectManager *%sobject_manager_client_new_sync (\n" + " GDBusConnection *connection,\n" + " GDBusObjectManagerClientFlags flags,\n" + " const gchar *name,\n" + " const gchar *object_path,\n" + " GCancellable *cancellable,\n" + " GError **error);\n" % (self.ns_lower) + ) + self.outfile.write("\n") if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('void %sobject_manager_client_new_for_bus (\n' - ' GBusType bus_type,\n' - ' GDBusObjectManagerClientFlags flags,\n' - ' const gchar *name,\n' - ' const gchar *object_path,\n' - ' GCancellable *cancellable,\n' - ' GAsyncReadyCallback callback,\n' - ' gpointer user_data);\n' - %(self.ns_lower)) + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "void %sobject_manager_client_new_for_bus (\n" + " GBusType bus_type,\n" + " GDBusObjectManagerClientFlags flags,\n" + " const gchar *name,\n" + " const gchar *object_path,\n" + " GCancellable *cancellable,\n" + " GAsyncReadyCallback callback,\n" + " gpointer user_data);\n" % (self.ns_lower) + ) if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('GDBusObjectManager *%sobject_manager_client_new_for_bus_finish (\n' - ' GAsyncResult *res,\n' - ' GError **error);\n' - %(self.ns_lower)) + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "GDBusObjectManager *%sobject_manager_client_new_for_bus_finish (\n" + " GAsyncResult *res,\n" + " GError **error);\n" % (self.ns_lower) + ) if self.symbol_decorator is not None: - self.outfile.write('%s\n' % self.symbol_decorator) - self.outfile.write('GDBusObjectManager *%sobject_manager_client_new_for_bus_sync (\n' - ' GBusType bus_type,\n' - ' GDBusObjectManagerClientFlags flags,\n' - ' const gchar *name,\n' - ' const gchar *object_path,\n' - ' GCancellable *cancellable,\n' - ' GError **error);\n' - %(self.ns_lower)) - self.outfile.write('\n') + self.outfile.write("%s\n" % self.symbol_decorator) + self.outfile.write( + "GDBusObjectManager *%sobject_manager_client_new_for_bus_sync (\n" + " GBusType bus_type,\n" + " GDBusObjectManagerClientFlags flags,\n" + " const gchar *name,\n" + " const gchar *object_path,\n" + " GCancellable *cancellable,\n" + " GError **error);\n" % (self.ns_lower) + ) + self.outfile.write("\n") # ---------------------------------------------------------------------------------------------------- def generate_header_postamble(self): - self.outfile.write('\n') - self.outfile.write('G_END_DECLS\n') + self.outfile.write("\n") + self.outfile.write("G_END_DECLS\n") if not self.use_pragma: - self.outfile.write('\n') - self.outfile.write('#endif /* __{!s}__ */\n'.format(self.header_guard)) + self.outfile.write("\n") + self.outfile.write("#endif /* __{!s}__ */\n".format(self.header_guard)) # ---------------------------------------------------------------------------------------------------- @@ -701,11 +1006,23 @@ class HeaderCodeGenerator: self.declare_types() self.generate_header_postamble() + # ---------------------------------------------------------------------------------------------------- + class InterfaceInfoHeaderCodeGenerator: - def __init__(self, ifaces, namespace, header_name, input_files_basenames, use_pragma, - glib_min_required, symbol_decorator, symbol_decorator_header, outfile): + def __init__( + self, + ifaces, + namespace, + header_name, + input_files_basenames, + use_pragma, + glib_min_required, + symbol_decorator, + symbol_decorator_header, + outfile, + ): self.ifaces = ifaces self.namespace, self.ns_upper, self.ns_lower = generate_namespace(namespace) self.header_guard = generate_header_guard(header_name) @@ -714,49 +1031,51 @@ class InterfaceInfoHeaderCodeGenerator: self.glib_min_required = glib_min_required self.symbol_decorator = symbol_decorator if self.symbol_decorator is None: - self.symbol_decorator = '' + self.symbol_decorator = "" self.symbol_decorator_header = symbol_decorator_header self.outfile = outfile # ---------------------------------------------------------------------------------------------------- def generate_header_preamble(self): - basenames = ', '.join(self.input_files_basenames) + basenames = ", ".join(self.input_files_basenames) self.outfile.write(LICENSE_STR.format(config.VERSION, basenames)) - self.outfile.write('\n') + self.outfile.write("\n") if self.use_pragma: - self.outfile.write('#pragma once\n') + self.outfile.write("#pragma once\n") else: - self.outfile.write('#ifndef __{!s}__\n'.format(self.header_guard)) - self.outfile.write('#define __{!s}__\n'.format(self.header_guard)) + self.outfile.write("#ifndef __{!s}__\n".format(self.header_guard)) + self.outfile.write("#define __{!s}__\n".format(self.header_guard)) if self.symbol_decorator_header is not None: - self.outfile.write('\n') + self.outfile.write("\n") self.outfile.write('#include "%s"\n' % self.symbol_decorator_header) - self.outfile.write('\n') - self.outfile.write('#include <gio/gio.h>\n') - self.outfile.write('\n') - self.outfile.write('G_BEGIN_DECLS\n') - self.outfile.write('\n') + self.outfile.write("\n") + self.outfile.write("#include <gio/gio.h>\n") + self.outfile.write("\n") + self.outfile.write("G_BEGIN_DECLS\n") + self.outfile.write("\n") # ---------------------------------------------------------------------------------------------------- def declare_infos(self): for i in self.ifaces: - self.outfile.write('extern %s const GDBusInterfaceInfo %s_interface;\n' % - (self.symbol_decorator, i.name_lower)) + self.outfile.write( + "extern %s const GDBusInterfaceInfo %s_interface;\n" + % (self.symbol_decorator, i.name_lower) + ) # ---------------------------------------------------------------------------------------------------- def generate_header_postamble(self): - self.outfile.write('\n') - self.outfile.write('G_END_DECLS\n') + self.outfile.write("\n") + self.outfile.write("G_END_DECLS\n") if not self.use_pragma: - self.outfile.write('\n') - self.outfile.write('#endif /* __{!s}__ */\n'.format(self.header_guard)) + self.outfile.write("\n") + self.outfile.write("#endif /* __{!s}__ */\n".format(self.header_guard)) # ---------------------------------------------------------------------------------------------------- @@ -765,11 +1084,21 @@ class InterfaceInfoHeaderCodeGenerator: self.declare_infos() self.generate_header_postamble() + # ---------------------------------------------------------------------------------------------------- + class InterfaceInfoBodyCodeGenerator: - def __init__(self, ifaces, namespace, header_name, input_files_basenames, - glib_min_required, symbol_decoration_define, outfile): + def __init__( + self, + ifaces, + namespace, + header_name, + input_files_basenames, + glib_min_required, + symbol_decoration_define, + outfile, + ): self.ifaces = ifaces self.namespace, self.ns_upper, self.ns_lower = generate_namespace(namespace) self.header_name = header_name @@ -781,34 +1110,37 @@ class InterfaceInfoBodyCodeGenerator: # ---------------------------------------------------------------------------------------------------- def generate_body_preamble(self): - basenames = ', '.join(self.input_files_basenames) + basenames = ", ".join(self.input_files_basenames) self.outfile.write(LICENSE_STR.format(config.VERSION, basenames)) if self.symbol_decoration_define is not None: - self.outfile.write('\n') - self.outfile.write('#define %s\n' % self.symbol_decoration_define) - - self.outfile.write('\n') - self.outfile.write('#ifdef HAVE_CONFIG_H\n' - '# include "config.h"\n' - '#endif\n' - '\n' - '#include "%s"\n' - '\n' - '#include <string.h>\n' - % (self.header_name)) - self.outfile.write('\n') + self.outfile.write("\n") + self.outfile.write("#define %s\n" % self.symbol_decoration_define) + + self.outfile.write("\n") + self.outfile.write( + "#ifdef HAVE_CONFIG_H\n" + '# include "config.h"\n' + "#endif\n" + "\n" + '#include "%s"\n' + "\n" + "#include <string.h>\n" % (self.header_name) + ) + self.outfile.write("\n") # ---------------------------------------------------------------------------------------------------- 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') + self.outfile.write( + "const %s * const %s[] =\n" % (element_type, array_name_lower) + ) + self.outfile.write("{\n") for (_, name) in elements: - self.outfile.write(' &%s,\n' % name) - self.outfile.write(' NULL,\n') - self.outfile.write('};\n') - self.outfile.write('\n') + self.outfile.write(" &%s,\n" % name) + self.outfile.write(" NULL,\n") + self.outfile.write("};\n") + self.outfile.write("\n") def define_annotations(self, array_name_lower, annotations): if len(annotations) == 0: @@ -818,28 +1150,37 @@ class InterfaceInfoBodyCodeGenerator: for a in annotations: # Skip internal annotations. - if a.key.startswith('org.gtk.GDBus'): + if a.key.startswith("org.gtk.GDBus"): continue - self.define_annotations('%s__%s_annotations' % (array_name_lower, a.key_lower), a.annotations) + self.define_annotations( + "%s__%s_annotations" % (array_name_lower, a.key_lower), a.annotations + ) - self.outfile.write('const GDBusAnnotationInfo %s__%s_annotation =\n' % (array_name_lower, a.key_lower)) - self.outfile.write('{\n') - self.outfile.write(' -1, /* ref count */\n') + self.outfile.write( + "const GDBusAnnotationInfo %s__%s_annotation =\n" + % (array_name_lower, a.key_lower) + ) + self.outfile.write("{\n") + self.outfile.write(" -1, /* ref count */\n") self.outfile.write(' (gchar *) "%s",\n' % a.key) self.outfile.write(' (gchar *) "%s",\n' % a.value) if len(a.annotations) > 0: - self.outfile.write(' (GDBusAnnotationInfo **) %s__%s_annotations,\n' % (array_name_lower, a.key_lower)) + self.outfile.write( + " (GDBusAnnotationInfo **) %s__%s_annotations,\n" + % (array_name_lower, a.key_lower) + ) else: - self.outfile.write(' NULL, /* no annotations */\n') - self.outfile.write('};\n') - self.outfile.write('\n') + self.outfile.write(" NULL, /* no annotations */\n") + self.outfile.write("};\n") + self.outfile.write("\n") - key = (a.since, '%s__%s_annotation' % (array_name_lower, a.key_lower)) + key = (a.since, "%s__%s_annotation" % (array_name_lower, a.key_lower)) annotation_pointers.append(key) - self.generate_array(array_name_lower, 'GDBusAnnotationInfo', - annotation_pointers) + self.generate_array( + array_name_lower, "GDBusAnnotationInfo", annotation_pointers + ) def define_args(self, array_name_lower, args): if len(args) == 0: @@ -848,93 +1189,154 @@ class InterfaceInfoBodyCodeGenerator: arg_pointers = [] for a in args: - self.define_annotations('%s__%s_arg_annotations' % (array_name_lower, a.name), a.annotations) - - self.outfile.write('const GDBusArgInfo %s__%s_arg =\n' % (array_name_lower, a.name)) - self.outfile.write('{\n') - self.outfile.write(' -1, /* ref count */\n') + self.define_annotations( + "%s__%s_arg_annotations" % (array_name_lower, a.name), a.annotations + ) + + self.outfile.write( + "const GDBusArgInfo %s__%s_arg =\n" % (array_name_lower, a.name) + ) + self.outfile.write("{\n") + self.outfile.write(" -1, /* ref count */\n") self.outfile.write(' (gchar *) "%s",\n' % a.name) self.outfile.write(' (gchar *) "%s",\n' % a.signature) if len(a.annotations) > 0: - self.outfile.write(' (GDBusAnnotationInfo **) %s__%s_arg_annotations,\n' % (array_name_lower, a.name)) + self.outfile.write( + " (GDBusAnnotationInfo **) %s__%s_arg_annotations,\n" + % (array_name_lower, a.name) + ) else: - self.outfile.write(' NULL, /* no annotations */\n') - self.outfile.write('};\n') - self.outfile.write('\n') + self.outfile.write(" NULL, /* no annotations */\n") + self.outfile.write("};\n") + self.outfile.write("\n") - key = (a.since, '%s__%s_arg' % (array_name_lower, a.name)) + key = (a.since, "%s__%s_arg" % (array_name_lower, a.name)) arg_pointers.append(key) - self.generate_array(array_name_lower, 'GDBusArgInfo', arg_pointers) + self.generate_array(array_name_lower, "GDBusArgInfo", arg_pointers) def define_infos(self): for i in self.ifaces: - self.outfile.write('/* ------------------------------------------------------------------------ */\n') - self.outfile.write('/* Definitions for %s */\n' % i.name) - self.outfile.write('\n') + self.outfile.write( + "/* ------------------------------------------------------------------------ */\n" + ) + self.outfile.write("/* Definitions for %s */\n" % i.name) + self.outfile.write("\n") # GDBusMethodInfos. if len(i.methods) > 0: method_pointers = [] for m in i.methods: - self.define_args('%s_interface__%s_method_in_args' % (i.name_lower, m.name_lower), m.in_args) - self.define_args('%s_interface__%s_method_out_args' % (i.name_lower, m.name_lower), m.out_args) - self.define_annotations('%s_interface__%s_method_annotations' % (i.name_lower, m.name_lower), m.annotations) - - self.outfile.write('const GDBusMethodInfo %s_interface__%s_method =\n' % (i.name_lower, m.name_lower)) - self.outfile.write('{\n') - self.outfile.write(' -1, /* ref count */\n') + self.define_args( + "%s_interface__%s_method_in_args" + % (i.name_lower, m.name_lower), + m.in_args, + ) + self.define_args( + "%s_interface__%s_method_out_args" + % (i.name_lower, m.name_lower), + m.out_args, + ) + self.define_annotations( + "%s_interface__%s_method_annotations" + % (i.name_lower, m.name_lower), + m.annotations, + ) + + self.outfile.write( + "const GDBusMethodInfo %s_interface__%s_method =\n" + % (i.name_lower, m.name_lower) + ) + self.outfile.write("{\n") + self.outfile.write(" -1, /* ref count */\n") self.outfile.write(' (gchar *) "%s",\n' % m.name) if len(m.in_args) > 0: - self.outfile.write(' (GDBusArgInfo **) %s_interface__%s_method_in_args,\n' % (i.name_lower, m.name_lower)) + self.outfile.write( + " (GDBusArgInfo **) %s_interface__%s_method_in_args,\n" + % (i.name_lower, m.name_lower) + ) else: - self.outfile.write(' NULL, /* no in args */\n') + self.outfile.write(" NULL, /* no in args */\n") if len(m.out_args) > 0: - self.outfile.write(' (GDBusArgInfo **) %s_interface__%s_method_out_args,\n' % (i.name_lower, m.name_lower)) + self.outfile.write( + " (GDBusArgInfo **) %s_interface__%s_method_out_args,\n" + % (i.name_lower, m.name_lower) + ) else: - self.outfile.write(' NULL, /* no out args */\n') + self.outfile.write(" NULL, /* no out args */\n") if len(m.annotations) > 0: - self.outfile.write(' (GDBusAnnotationInfo **) %s_interface__%s_method_annotations,\n' % (i.name_lower, m.name_lower)) + self.outfile.write( + " (GDBusAnnotationInfo **) %s_interface__%s_method_annotations,\n" + % (i.name_lower, m.name_lower) + ) else: - self.outfile.write(' NULL, /* no annotations */\n') - self.outfile.write('};\n') - self.outfile.write('\n') - - key = (m.since, '%s_interface__%s_method' % (i.name_lower, m.name_lower)) + self.outfile.write(" NULL, /* no annotations */\n") + self.outfile.write("};\n") + self.outfile.write("\n") + + key = ( + m.since, + "%s_interface__%s_method" % (i.name_lower, m.name_lower), + ) method_pointers.append(key) - self.generate_array('%s_interface_methods' % i.name_lower, - 'GDBusMethodInfo', method_pointers) + self.generate_array( + "%s_interface_methods" % i.name_lower, + "GDBusMethodInfo", + method_pointers, + ) # GDBusSignalInfos. if len(i.signals) > 0: signal_pointers = [] for s in i.signals: - self.define_args('%s_interface__%s_signal_args' % (i.name_lower, s.name_lower), s.args) - self.define_annotations('%s_interface__%s_signal_annotations' % (i.name_lower, s.name_lower), s.annotations) - - self.outfile.write('const GDBusSignalInfo %s_interface__%s_signal =\n' % (i.name_lower, s.name_lower)) - self.outfile.write('{\n') - self.outfile.write(' -1, /* ref count */\n') + self.define_args( + "%s_interface__%s_signal_args" % (i.name_lower, s.name_lower), + s.args, + ) + self.define_annotations( + "%s_interface__%s_signal_annotations" + % (i.name_lower, s.name_lower), + s.annotations, + ) + + self.outfile.write( + "const GDBusSignalInfo %s_interface__%s_signal =\n" + % (i.name_lower, s.name_lower) + ) + self.outfile.write("{\n") + self.outfile.write(" -1, /* ref count */\n") self.outfile.write(' (gchar *) "%s",\n' % s.name) if len(s.args) > 0: - self.outfile.write(' (GDBusArgInfo **) %s_interface__%s_signal_args,\n' % (i.name_lower, s.name_lower)) + self.outfile.write( + " (GDBusArgInfo **) %s_interface__%s_signal_args,\n" + % (i.name_lower, s.name_lower) + ) else: - self.outfile.write(' NULL, /* no args */\n') + self.outfile.write(" NULL, /* no args */\n") if len(s.annotations) > 0: - self.outfile.write(' (GDBusAnnotationInfo **) %s_interface__%s_signal_annotations,\n' % (i.name_lower, s.name_lower)) + self.outfile.write( + " (GDBusAnnotationInfo **) %s_interface__%s_signal_annotations,\n" + % (i.name_lower, s.name_lower) + ) else: - self.outfile.write(' NULL, /* no annotations */\n') - self.outfile.write('};\n') - self.outfile.write('\n') - - key = (s.since, '%s_interface__%s_signal' % (i.name_lower, s.name_lower)) + self.outfile.write(" NULL, /* no annotations */\n") + self.outfile.write("};\n") + self.outfile.write("\n") + + key = ( + s.since, + "%s_interface__%s_signal" % (i.name_lower, s.name_lower), + ) signal_pointers.append(key) - self.generate_array('%s_interface_signals' % i.name_lower, - 'GDBusSignalInfo', signal_pointers) + self.generate_array( + "%s_interface_signals" % i.name_lower, + "GDBusSignalInfo", + signal_pointers, + ) # GDBusPropertyInfos. if len(i.properties) > 0: @@ -942,61 +1344,89 @@ class InterfaceInfoBodyCodeGenerator: for p in i.properties: if p.readable and p.writable: - flags = 'G_DBUS_PROPERTY_INFO_FLAGS_READABLE | G_DBUS_PROPERTY_INFO_FLAGS_WRITABLE' + flags = "G_DBUS_PROPERTY_INFO_FLAGS_READABLE | G_DBUS_PROPERTY_INFO_FLAGS_WRITABLE" elif p.readable: - flags = 'G_DBUS_PROPERTY_INFO_FLAGS_READABLE' + flags = "G_DBUS_PROPERTY_INFO_FLAGS_READABLE" elif p.writable: - flags = 'G_DBUS_PROPERTY_INFO_FLAGS_WRITABLE' + flags = "G_DBUS_PROPERTY_INFO_FLAGS_WRITABLE" else: - flags = 'G_DBUS_PROPERTY_INFO_FLAGS_NONE' - - self.define_annotations('%s_interface__%s_property_annotations' % (i.name_lower, p.name_lower), p.annotations) - - self.outfile.write('const GDBusPropertyInfo %s_interface__%s_property =\n' % (i.name_lower, p.name_lower)) - self.outfile.write('{\n') - self.outfile.write(' -1, /* ref count */\n') + flags = "G_DBUS_PROPERTY_INFO_FLAGS_NONE" + + self.define_annotations( + "%s_interface__%s_property_annotations" + % (i.name_lower, p.name_lower), + p.annotations, + ) + + self.outfile.write( + "const GDBusPropertyInfo %s_interface__%s_property =\n" + % (i.name_lower, p.name_lower) + ) + self.outfile.write("{\n") + self.outfile.write(" -1, /* ref count */\n") self.outfile.write(' (gchar *) "%s",\n' % p.name) self.outfile.write(' (gchar *) "%s",\n' % p.signature) - self.outfile.write(' %s,\n' % flags) + self.outfile.write(" %s,\n" % flags) if len(p.annotations) > 0: - self.outfile.write(' (GDBusAnnotationInfo **) %s_interface__%s_property_annotations,\n' % (i.name_lower, p.name_lower)) + self.outfile.write( + " (GDBusAnnotationInfo **) %s_interface__%s_property_annotations,\n" + % (i.name_lower, p.name_lower) + ) else: - self.outfile.write(' NULL, /* no annotations */\n') - self.outfile.write('};\n') - self.outfile.write('\n') - - key = (p.since, '%s_interface__%s_property' % (i.name_lower, p.name_lower)) + self.outfile.write(" NULL, /* no annotations */\n") + self.outfile.write("};\n") + self.outfile.write("\n") + + key = ( + p.since, + "%s_interface__%s_property" % (i.name_lower, p.name_lower), + ) property_pointers.append(key) - self.generate_array('%s_interface_properties' % i.name_lower, - 'GDBusPropertyInfo', property_pointers) + self.generate_array( + "%s_interface_properties" % i.name_lower, + "GDBusPropertyInfo", + property_pointers, + ) # Finally the GDBusInterfaceInfo. - self.define_annotations('%s_interface_annotations' % i.name_lower, - i.annotations) - - self.outfile.write('const GDBusInterfaceInfo %s_interface =\n' % i.name_lower) - self.outfile.write('{\n') - self.outfile.write(' -1, /* ref count */\n') + self.define_annotations( + "%s_interface_annotations" % i.name_lower, i.annotations + ) + + self.outfile.write( + "const GDBusInterfaceInfo %s_interface =\n" % i.name_lower + ) + self.outfile.write("{\n") + self.outfile.write(" -1, /* ref count */\n") self.outfile.write(' (gchar *) "%s",\n' % i.name) if len(i.methods) > 0: - self.outfile.write(' (GDBusMethodInfo **) %s_interface_methods,\n' % i.name_lower) + self.outfile.write( + " (GDBusMethodInfo **) %s_interface_methods,\n" % i.name_lower + ) else: - self.outfile.write(' NULL, /* no methods */\n') + self.outfile.write(" NULL, /* no methods */\n") if len(i.signals) > 0: - self.outfile.write(' (GDBusSignalInfo **) %s_interface_signals,\n' % i.name_lower) + self.outfile.write( + " (GDBusSignalInfo **) %s_interface_signals,\n" % i.name_lower + ) else: - self.outfile.write(' NULL, /* no signals */\n') + self.outfile.write(" NULL, /* no signals */\n") if len(i.properties) > 0: - self.outfile.write(' (GDBusPropertyInfo **) %s_interface_properties,\n' % i.name_lower) + self.outfile.write( + " (GDBusPropertyInfo **) %s_interface_properties,\n" % i.name_lower + ) else: - self.outfile.write( 'NULL, /* no properties */\n') + self.outfile.write("NULL, /* no properties */\n") if len(i.annotations) > 0: - self.outfile.write(' (GDBusAnnotationInfo **) %s_interface_annotations,\n' % i.name_lower) + self.outfile.write( + " (GDBusAnnotationInfo **) %s_interface_annotations,\n" + % i.name_lower + ) else: - self.outfile.write(' NULL, /* no annotations */\n') - self.outfile.write('};\n') - self.outfile.write('\n') + self.outfile.write(" NULL, /* no annotations */\n") + self.outfile.write("};\n") + self.outfile.write("\n") # ---------------------------------------------------------------------------------------------------- @@ -1004,12 +1434,23 @@ class InterfaceInfoBodyCodeGenerator: self.generate_body_preamble() self.define_infos() + # ---------------------------------------------------------------------------------------------------- + class CodeGenerator: - def __init__(self, ifaces, namespace, generate_objmanager, header_name, - input_files_basenames, docbook_gen, glib_min_required, - symbol_decoration_define, outfile): + def __init__( + self, + ifaces, + namespace, + generate_objmanager, + header_name, + input_files_basenames, + docbook_gen, + glib_min_required, + symbol_decoration_define, + outfile, + ): self.ifaces = ifaces self.namespace, self.ns_upper, self.ns_lower = generate_namespace(namespace) self.generate_objmanager = generate_objmanager @@ -1023,169 +1464,187 @@ class CodeGenerator: # ---------------------------------------------------------------------------------------------------- def generate_body_preamble(self): - basenames = ', '.join(self.input_files_basenames) + basenames = ", ".join(self.input_files_basenames) self.outfile.write(LICENSE_STR.format(config.VERSION, basenames)) if self.symbol_decoration_define is not None: - self.outfile.write('\n') - self.outfile.write('#define %s\n' % self.symbol_decoration_define) - self.outfile.write('\n') - self.outfile.write('#ifdef HAVE_CONFIG_H\n' - '# include "config.h"\n' - '#endif\n' - '\n' - '#include "%s"\n' - '\n' - '#include <string.h>\n' - %(self.header_name)) - - self.outfile.write('#ifdef G_OS_UNIX\n' - '# include <gio/gunixfdlist.h>\n' - '#endif\n' - '\n') - - self.outfile.write('typedef struct\n' - '{\n' - ' GDBusArgInfo parent_struct;\n' - ' gboolean use_gvariant;\n' - '} _ExtendedGDBusArgInfo;\n' - '\n') - - self.outfile.write('typedef struct\n' - '{\n' - ' GDBusMethodInfo parent_struct;\n' - ' const gchar *signal_name;\n' - ' gboolean pass_fdlist;\n' - '} _ExtendedGDBusMethodInfo;\n' - '\n') - - self.outfile.write('typedef struct\n' - '{\n' - ' GDBusSignalInfo parent_struct;\n' - ' const gchar *signal_name;\n' - '} _ExtendedGDBusSignalInfo;\n' - '\n') - - self.outfile.write('typedef struct\n' - '{\n' - ' GDBusPropertyInfo parent_struct;\n' - ' const gchar *hyphen_name;\n' - ' guint use_gvariant : 1;\n' - ' guint emits_changed_signal : 1;\n' - '} _ExtendedGDBusPropertyInfo;\n' - '\n') - - self.outfile.write('typedef struct\n' - '{\n' - ' GDBusInterfaceInfo parent_struct;\n' - ' const gchar *hyphen_name;\n' - '} _ExtendedGDBusInterfaceInfo;\n' - '\n') - - self.outfile.write('typedef struct\n' - '{\n' - ' const _ExtendedGDBusPropertyInfo *info;\n' - ' guint prop_id;\n' - ' GValue orig_value; /* the value before the change */\n' - '} ChangedProperty;\n' - '\n' - 'static void\n' - '_changed_property_free (ChangedProperty *data)\n' - '{\n' - ' g_value_unset (&data->orig_value);\n' - ' g_free (data);\n' - '}\n' - '\n') - - self.outfile.write('static gboolean\n' - '_g_strv_equal0 (gchar **a, gchar **b)\n' - '{\n' - ' gboolean ret = FALSE;\n' - ' guint n;\n' - ' if (a == NULL && b == NULL)\n' - ' {\n' - ' ret = TRUE;\n' - ' goto out;\n' - ' }\n' - ' if (a == NULL || b == NULL)\n' - ' goto out;\n' - ' if (g_strv_length (a) != g_strv_length (b))\n' - ' goto out;\n' - ' for (n = 0; a[n] != NULL; n++)\n' - ' if (g_strcmp0 (a[n], b[n]) != 0)\n' - ' goto out;\n' - ' ret = TRUE;\n' - 'out:\n' - ' return ret;\n' - '}\n' - '\n') - - self.outfile.write('static gboolean\n' - '_g_variant_equal0 (GVariant *a, GVariant *b)\n' - '{\n' - ' gboolean ret = FALSE;\n' - ' if (a == NULL && b == NULL)\n' - ' {\n' - ' ret = TRUE;\n' - ' goto out;\n' - ' }\n' - ' if (a == NULL || b == NULL)\n' - ' goto out;\n' - ' ret = g_variant_equal (a, b);\n' - 'out:\n' - ' return ret;\n' - '}\n' - '\n') + self.outfile.write("\n") + self.outfile.write("#define %s\n" % self.symbol_decoration_define) + self.outfile.write("\n") + self.outfile.write( + "#ifdef HAVE_CONFIG_H\n" + '# include "config.h"\n' + "#endif\n" + "\n" + '#include "%s"\n' + "\n" + "#include <string.h>\n" % (self.header_name) + ) + + self.outfile.write( + "#ifdef G_OS_UNIX\n" "# include <gio/gunixfdlist.h>\n" "#endif\n" "\n" + ) + + self.outfile.write( + "typedef struct\n" + "{\n" + " GDBusArgInfo parent_struct;\n" + " gboolean use_gvariant;\n" + "} _ExtendedGDBusArgInfo;\n" + "\n" + ) + + self.outfile.write( + "typedef struct\n" + "{\n" + " GDBusMethodInfo parent_struct;\n" + " const gchar *signal_name;\n" + " gboolean pass_fdlist;\n" + "} _ExtendedGDBusMethodInfo;\n" + "\n" + ) + + self.outfile.write( + "typedef struct\n" + "{\n" + " GDBusSignalInfo parent_struct;\n" + " const gchar *signal_name;\n" + "} _ExtendedGDBusSignalInfo;\n" + "\n" + ) + + self.outfile.write( + "typedef struct\n" + "{\n" + " GDBusPropertyInfo parent_struct;\n" + " const gchar *hyphen_name;\n" + " guint use_gvariant : 1;\n" + " guint emits_changed_signal : 1;\n" + "} _ExtendedGDBusPropertyInfo;\n" + "\n" + ) + + self.outfile.write( + "typedef struct\n" + "{\n" + " GDBusInterfaceInfo parent_struct;\n" + " const gchar *hyphen_name;\n" + "} _ExtendedGDBusInterfaceInfo;\n" + "\n" + ) + + self.outfile.write( + "typedef struct\n" + "{\n" + " const _ExtendedGDBusPropertyInfo *info;\n" + " guint prop_id;\n" + " GValue orig_value; /* the value before the change */\n" + "} ChangedProperty;\n" + "\n" + "static void\n" + "_changed_property_free (ChangedProperty *data)\n" + "{\n" + " g_value_unset (&data->orig_value);\n" + " g_free (data);\n" + "}\n" + "\n" + ) + + self.outfile.write( + "static gboolean\n" + "_g_strv_equal0 (gchar **a, gchar **b)\n" + "{\n" + " gboolean ret = FALSE;\n" + " guint n;\n" + " if (a == NULL && b == NULL)\n" + " {\n" + " ret = TRUE;\n" + " goto out;\n" + " }\n" + " if (a == NULL || b == NULL)\n" + " goto out;\n" + " if (g_strv_length (a) != g_strv_length (b))\n" + " goto out;\n" + " for (n = 0; a[n] != NULL; n++)\n" + " if (g_strcmp0 (a[n], b[n]) != 0)\n" + " goto out;\n" + " ret = TRUE;\n" + "out:\n" + " return ret;\n" + "}\n" + "\n" + ) + + self.outfile.write( + "static gboolean\n" + "_g_variant_equal0 (GVariant *a, GVariant *b)\n" + "{\n" + " gboolean ret = FALSE;\n" + " if (a == NULL && b == NULL)\n" + " {\n" + " ret = TRUE;\n" + " goto out;\n" + " }\n" + " if (a == NULL || b == NULL)\n" + " goto out;\n" + " ret = g_variant_equal (a, b);\n" + "out:\n" + " return ret;\n" + "}\n" + "\n" + ) # simplified - only supports the types we use - self.outfile.write('G_GNUC_UNUSED static gboolean\n' - '_g_value_equal (const GValue *a, const GValue *b)\n' - '{\n' - ' gboolean ret = FALSE;\n' - ' g_assert (G_VALUE_TYPE (a) == G_VALUE_TYPE (b));\n' - ' switch (G_VALUE_TYPE (a))\n' - ' {\n' - ' case G_TYPE_BOOLEAN:\n' - ' ret = (g_value_get_boolean (a) == g_value_get_boolean (b));\n' - ' break;\n' - ' case G_TYPE_UCHAR:\n' - ' ret = (g_value_get_uchar (a) == g_value_get_uchar (b));\n' - ' break;\n' - ' case G_TYPE_INT:\n' - ' ret = (g_value_get_int (a) == g_value_get_int (b));\n' - ' break;\n' - ' case G_TYPE_UINT:\n' - ' ret = (g_value_get_uint (a) == g_value_get_uint (b));\n' - ' break;\n' - ' case G_TYPE_INT64:\n' - ' ret = (g_value_get_int64 (a) == g_value_get_int64 (b));\n' - ' break;\n' - ' case G_TYPE_UINT64:\n' - ' ret = (g_value_get_uint64 (a) == g_value_get_uint64 (b));\n' - ' break;\n' - ' case G_TYPE_DOUBLE:\n' - ' {\n' - ' /* Avoid -Wfloat-equal warnings by doing a direct bit compare */\n' - ' gdouble da = g_value_get_double (a);\n' - ' gdouble db = g_value_get_double (b);\n' - ' ret = memcmp (&da, &db, sizeof (gdouble)) == 0;\n' - ' }\n' - ' break;\n' - ' case G_TYPE_STRING:\n' - ' ret = (g_strcmp0 (g_value_get_string (a), g_value_get_string (b)) == 0);\n' - ' break;\n' - ' case G_TYPE_VARIANT:\n' - ' ret = _g_variant_equal0 (g_value_get_variant (a), g_value_get_variant (b));\n' - ' break;\n' - ' default:\n' - ' if (G_VALUE_TYPE (a) == G_TYPE_STRV)\n' - ' ret = _g_strv_equal0 (g_value_get_boxed (a), g_value_get_boxed (b));\n' - ' else\n' - ' g_critical ("_g_value_equal() does not handle type %s", g_type_name (G_VALUE_TYPE (a)));\n' - ' break;\n' - ' }\n' - ' return ret;\n' - '}\n' - '\n') + self.outfile.write( + "G_GNUC_UNUSED static gboolean\n" + "_g_value_equal (const GValue *a, const GValue *b)\n" + "{\n" + " gboolean ret = FALSE;\n" + " g_assert (G_VALUE_TYPE (a) == G_VALUE_TYPE (b));\n" + " switch (G_VALUE_TYPE (a))\n" + " {\n" + " case G_TYPE_BOOLEAN:\n" + " ret = (g_value_get_boolean (a) == g_value_get_boolean (b));\n" + " break;\n" + " case G_TYPE_UCHAR:\n" + " ret = (g_value_get_uchar (a) == g_value_get_uchar (b));\n" + " break;\n" + " case G_TYPE_INT:\n" + " ret = (g_value_get_int (a) == g_value_get_int (b));\n" + " break;\n" + " case G_TYPE_UINT:\n" + " ret = (g_value_get_uint (a) == g_value_get_uint (b));\n" + " break;\n" + " case G_TYPE_INT64:\n" + " ret = (g_value_get_int64 (a) == g_value_get_int64 (b));\n" + " break;\n" + " case G_TYPE_UINT64:\n" + " ret = (g_value_get_uint64 (a) == g_value_get_uint64 (b));\n" + " break;\n" + " case G_TYPE_DOUBLE:\n" + " {\n" + " /* Avoid -Wfloat-equal warnings by doing a direct bit compare */\n" + " gdouble da = g_value_get_double (a);\n" + " gdouble db = g_value_get_double (b);\n" + " ret = memcmp (&da, &db, sizeof (gdouble)) == 0;\n" + " }\n" + " break;\n" + " case G_TYPE_STRING:\n" + " ret = (g_strcmp0 (g_value_get_string (a), g_value_get_string (b)) == 0);\n" + " break;\n" + " case G_TYPE_VARIANT:\n" + " ret = _g_variant_equal0 (g_value_get_variant (a), g_value_get_variant (b));\n" + " break;\n" + " default:\n" + " if (G_VALUE_TYPE (a) == G_TYPE_STRV)\n" + " ret = _g_strv_equal0 (g_value_get_boxed (a), g_value_get_boxed (b));\n" + " else\n" + ' g_critical ("_g_value_equal() does not handle type %s", g_type_name (G_VALUE_TYPE (a)));\n' + " break;\n" + " }\n" + " return ret;\n" + "}\n" + "\n" + ) def generate_annotations(self, prefix, annotations): if annotations is None: @@ -1193,457 +1652,664 @@ class CodeGenerator: n = 0 for a in annotations: - #self.generate_annotations('%s_%d'%(prefix, n), a.get_annotations()) + # self.generate_annotations('%s_%d'%(prefix, n), a.get_annotations()) # skip internal annotations - if a.key.startswith('org.gtk.GDBus'): + if a.key.startswith("org.gtk.GDBus"): continue - self.outfile.write('static const GDBusAnnotationInfo %s_%d =\n' - '{\n' - ' -1,\n' - ' (gchar *) "%s",\n' - ' (gchar *) "%s",\n'%(prefix, n, a.key, a.value)) + self.outfile.write( + "static const GDBusAnnotationInfo %s_%d =\n" + "{\n" + " -1,\n" + ' (gchar *) "%s",\n' + ' (gchar *) "%s",\n' % (prefix, n, a.key, a.value) + ) if len(a.annotations) == 0: - self.outfile.write(' NULL\n') + self.outfile.write(" NULL\n") else: - self.outfile.write(' (GDBusAnnotationInfo **) &%s_%d_pointers\n'%(prefix, n)) - self.outfile.write('};\n' - '\n') + self.outfile.write( + " (GDBusAnnotationInfo **) &%s_%d_pointers\n" % (prefix, n) + ) + self.outfile.write("};\n" "\n") n += 1 if n > 0: - self.outfile.write('static const GDBusAnnotationInfo * const %s_pointers[] =\n' - '{\n'%(prefix)) - m = 0; + self.outfile.write( + "static const GDBusAnnotationInfo * const %s_pointers[] =\n" + "{\n" % (prefix) + ) + m = 0 for a in annotations: - if a.key.startswith('org.gtk.GDBus'): + if a.key.startswith("org.gtk.GDBus"): continue - self.outfile.write(' &%s_%d,\n'%(prefix, m)) + self.outfile.write(" &%s_%d,\n" % (prefix, m)) m += 1 - self.outfile.write(' NULL\n' - '};\n' - '\n') + self.outfile.write(" NULL\n" "};\n" "\n") return n def generate_args(self, prefix, args): for a in args: - num_anno = self.generate_annotations('%s_arg_%s_annotation_info'%(prefix, a.name), a.annotations) - - self.outfile.write('static const _ExtendedGDBusArgInfo %s_%s =\n' - '{\n' - ' {\n' - ' -1,\n' - ' (gchar *) "%s",\n' - ' (gchar *) "%s",\n'%(prefix, a.name, a.name, a.signature)) + num_anno = self.generate_annotations( + "%s_arg_%s_annotation_info" % (prefix, a.name), a.annotations + ) + + self.outfile.write( + "static const _ExtendedGDBusArgInfo %s_%s =\n" + "{\n" + " {\n" + " -1,\n" + ' (gchar *) "%s",\n' + ' (gchar *) "%s",\n' % (prefix, a.name, a.name, a.signature) + ) if num_anno == 0: - self.outfile.write(' NULL\n') + self.outfile.write(" NULL\n") else: - self.outfile.write(' (GDBusAnnotationInfo **) &%s_arg_%s_annotation_info_pointers\n'%(prefix, a.name)) - self.outfile.write(' },\n') - if not utils.lookup_annotation(a.annotations, 'org.gtk.GDBus.C.ForceGVariant'): - self.outfile.write(' FALSE\n') + self.outfile.write( + " (GDBusAnnotationInfo **) &%s_arg_%s_annotation_info_pointers\n" + % (prefix, a.name) + ) + self.outfile.write(" },\n") + if not utils.lookup_annotation( + a.annotations, "org.gtk.GDBus.C.ForceGVariant" + ): + self.outfile.write(" FALSE\n") else: - self.outfile.write(' TRUE\n') - self.outfile.write('};\n' - '\n') + self.outfile.write(" TRUE\n") + self.outfile.write("};\n" "\n") if len(args) > 0: - self.outfile.write('static const GDBusArgInfo * const %s_pointers[] =\n' - '{\n'%(prefix)) + self.outfile.write( + "static const GDBusArgInfo * const %s_pointers[] =\n" "{\n" % (prefix) + ) for a in args: - self.outfile.write(' &%s_%s.parent_struct,\n'%(prefix, a.name)) - self.outfile.write(' NULL\n' - '};\n' - '\n') + self.outfile.write(" &%s_%s.parent_struct,\n" % (prefix, a.name)) + self.outfile.write(" NULL\n" "};\n" "\n") def generate_introspection_for_interface(self, i): - self.outfile.write('/* ---- Introspection data for %s ---- */\n' - '\n'%(i.name)) + self.outfile.write( + "/* ---- Introspection data for %s ---- */\n" "\n" % (i.name) + ) - if len(i.methods) > 0: - for m in i.methods: - self.generate_args('_%s_method_info_%s_IN_ARG'%(i.name_lower, m.name_lower), m.in_args) - self.generate_args('_%s_method_info_%s_OUT_ARG'%(i.name_lower, m.name_lower), m.out_args) - - num_anno = self.generate_annotations('_%s_method_%s_annotation_info'%(i.name_lower, m.name_lower), m.annotations) - - self.outfile.write('static const _ExtendedGDBusMethodInfo _%s_method_info_%s =\n' - '{\n' - ' {\n' - ' -1,\n' - ' (gchar *) "%s",\n'%(i.name_lower, m.name_lower, m.name)) - if len(m.in_args) == 0: - self.outfile.write(' NULL,\n') - else: - self.outfile.write(' (GDBusArgInfo **) &_%s_method_info_%s_IN_ARG_pointers,\n'%(i.name_lower, m.name_lower)) - if len(m.out_args) == 0: - self.outfile.write(' NULL,\n') - else: - self.outfile.write(' (GDBusArgInfo **) &_%s_method_info_%s_OUT_ARG_pointers,\n'%(i.name_lower, m.name_lower)) - if num_anno == 0: - self.outfile.write(' NULL\n') - else: - self.outfile.write(' (GDBusAnnotationInfo **) &_%s_method_%s_annotation_info_pointers\n'%(i.name_lower, m.name_lower)) - self.outfile.write(' },\n' - ' "handle-%s",\n' - ' %s\n' - %(m.name_hyphen, 'TRUE' if m.unix_fd else 'FALSE')) - self.outfile.write('};\n' - '\n') - - self.outfile.write('static const GDBusMethodInfo * const _%s_method_info_pointers[] =\n' - '{\n'%(i.name_lower)) - for m in i.methods: - self.outfile.write(' &_%s_method_info_%s.parent_struct,\n'%(i.name_lower, m.name_lower)) - self.outfile.write(' NULL\n' - '};\n' - '\n') + if len(i.methods) > 0: + for m in i.methods: + self.generate_args( + "_%s_method_info_%s_IN_ARG" % (i.name_lower, m.name_lower), + m.in_args, + ) + self.generate_args( + "_%s_method_info_%s_OUT_ARG" % (i.name_lower, m.name_lower), + m.out_args, + ) + + num_anno = self.generate_annotations( + "_%s_method_%s_annotation_info" % (i.name_lower, m.name_lower), + m.annotations, + ) + + self.outfile.write( + "static const _ExtendedGDBusMethodInfo _%s_method_info_%s =\n" + "{\n" + " {\n" + " -1,\n" + ' (gchar *) "%s",\n' % (i.name_lower, m.name_lower, m.name) + ) + if len(m.in_args) == 0: + self.outfile.write(" NULL,\n") + else: + self.outfile.write( + " (GDBusArgInfo **) &_%s_method_info_%s_IN_ARG_pointers,\n" + % (i.name_lower, m.name_lower) + ) + if len(m.out_args) == 0: + self.outfile.write(" NULL,\n") + else: + self.outfile.write( + " (GDBusArgInfo **) &_%s_method_info_%s_OUT_ARG_pointers,\n" + % (i.name_lower, m.name_lower) + ) + if num_anno == 0: + self.outfile.write(" NULL\n") + else: + self.outfile.write( + " (GDBusAnnotationInfo **) &_%s_method_%s_annotation_info_pointers\n" + % (i.name_lower, m.name_lower) + ) + self.outfile.write( + " },\n" + ' "handle-%s",\n' + " %s\n" % (m.name_hyphen, "TRUE" if m.unix_fd else "FALSE") + ) + self.outfile.write("};\n" "\n") + + self.outfile.write( + "static const GDBusMethodInfo * const _%s_method_info_pointers[] =\n" + "{\n" % (i.name_lower) + ) + for m in i.methods: + self.outfile.write( + " &_%s_method_info_%s.parent_struct,\n" + % (i.name_lower, m.name_lower) + ) + self.outfile.write(" NULL\n" "};\n" "\n") - # --- + # --- - if len(i.signals) > 0: - for s in i.signals: - self.generate_args('_%s_signal_info_%s_ARG'%(i.name_lower, s.name_lower), s.args) - - num_anno = self.generate_annotations('_%s_signal_%s_annotation_info'%(i.name_lower, s.name_lower), s.annotations) - self.outfile.write('static const _ExtendedGDBusSignalInfo _%s_signal_info_%s =\n' - '{\n' - ' {\n' - ' -1,\n' - ' (gchar *) "%s",\n'%(i.name_lower, s.name_lower, s.name)) - if len(s.args) == 0: - self.outfile.write(' NULL,\n') - else: - self.outfile.write(' (GDBusArgInfo **) &_%s_signal_info_%s_ARG_pointers,\n'%(i.name_lower, s.name_lower)) - if num_anno == 0: - self.outfile.write(' NULL\n') - else: - self.outfile.write(' (GDBusAnnotationInfo **) &_%s_signal_%s_annotation_info_pointers\n'%(i.name_lower, s.name_lower)) - self.outfile.write(' },\n' - ' "%s"\n' - %(s.name_hyphen)) - self.outfile.write('};\n' - '\n') - - self.outfile.write('static const GDBusSignalInfo * const _%s_signal_info_pointers[] =\n' - '{\n'%(i.name_lower)) - for s in i.signals: - self.outfile.write(' &_%s_signal_info_%s.parent_struct,\n'%(i.name_lower, s.name_lower)) - self.outfile.write(' NULL\n' - '};\n' - '\n') + if len(i.signals) > 0: + for s in i.signals: + self.generate_args( + "_%s_signal_info_%s_ARG" % (i.name_lower, s.name_lower), s.args + ) + + num_anno = self.generate_annotations( + "_%s_signal_%s_annotation_info" % (i.name_lower, s.name_lower), + s.annotations, + ) + self.outfile.write( + "static const _ExtendedGDBusSignalInfo _%s_signal_info_%s =\n" + "{\n" + " {\n" + " -1,\n" + ' (gchar *) "%s",\n' % (i.name_lower, s.name_lower, s.name) + ) + if len(s.args) == 0: + self.outfile.write(" NULL,\n") + else: + self.outfile.write( + " (GDBusArgInfo **) &_%s_signal_info_%s_ARG_pointers,\n" + % (i.name_lower, s.name_lower) + ) + if num_anno == 0: + self.outfile.write(" NULL\n") + else: + self.outfile.write( + " (GDBusAnnotationInfo **) &_%s_signal_%s_annotation_info_pointers\n" + % (i.name_lower, s.name_lower) + ) + self.outfile.write(" },\n" ' "%s"\n' % (s.name_hyphen)) + self.outfile.write("};\n" "\n") + + self.outfile.write( + "static const GDBusSignalInfo * const _%s_signal_info_pointers[] =\n" + "{\n" % (i.name_lower) + ) + for s in i.signals: + self.outfile.write( + " &_%s_signal_info_%s.parent_struct,\n" + % (i.name_lower, s.name_lower) + ) + self.outfile.write(" NULL\n" "};\n" "\n") - # --- + # --- - if len(i.properties) > 0: - for p in i.properties: - if p.readable and p.writable: - access = 'G_DBUS_PROPERTY_INFO_FLAGS_READABLE | G_DBUS_PROPERTY_INFO_FLAGS_WRITABLE' - elif p.readable: - access = 'G_DBUS_PROPERTY_INFO_FLAGS_READABLE' - elif p.writable: - access = 'G_DBUS_PROPERTY_INFO_FLAGS_WRITABLE' - else: - access = 'G_DBUS_PROPERTY_INFO_FLAGS_NONE' - num_anno = self.generate_annotations('_%s_property_%s_annotation_info'%(i.name_lower, p.name_lower), p.annotations) - self.outfile.write('static const _ExtendedGDBusPropertyInfo _%s_property_info_%s =\n' - '{\n' - ' {\n' - ' -1,\n' - ' (gchar *) "%s",\n' - ' (gchar *) "%s",\n' - ' %s,\n'%(i.name_lower, p.name_lower, p.name, p.arg.signature, access)) - if num_anno == 0: - self.outfile.write(' NULL\n') - else: - self.outfile.write(' (GDBusAnnotationInfo **) &_%s_property_%s_annotation_info_pointers\n'%(i.name_lower, p.name_lower)) - self.outfile.write(' },\n' - ' "%s",\n' - %(p.name_hyphen)) - if not utils.lookup_annotation(p.annotations, 'org.gtk.GDBus.C.ForceGVariant'): - self.outfile.write(' FALSE,\n') - else: - self.outfile.write(' TRUE,\n') - if p.emits_changed_signal: - self.outfile.write(' TRUE\n') - else: - self.outfile.write(' FALSE\n') - self.outfile.write('};\n' - '\n') + if len(i.properties) > 0: + for p in i.properties: + if p.readable and p.writable: + access = "G_DBUS_PROPERTY_INFO_FLAGS_READABLE | G_DBUS_PROPERTY_INFO_FLAGS_WRITABLE" + elif p.readable: + access = "G_DBUS_PROPERTY_INFO_FLAGS_READABLE" + elif p.writable: + access = "G_DBUS_PROPERTY_INFO_FLAGS_WRITABLE" + else: + access = "G_DBUS_PROPERTY_INFO_FLAGS_NONE" + num_anno = self.generate_annotations( + "_%s_property_%s_annotation_info" % (i.name_lower, p.name_lower), + p.annotations, + ) + self.outfile.write( + "static const _ExtendedGDBusPropertyInfo _%s_property_info_%s =\n" + "{\n" + " {\n" + " -1,\n" + ' (gchar *) "%s",\n' + ' (gchar *) "%s",\n' + " %s,\n" + % (i.name_lower, p.name_lower, p.name, p.arg.signature, access) + ) + if num_anno == 0: + self.outfile.write(" NULL\n") + else: + self.outfile.write( + " (GDBusAnnotationInfo **) &_%s_property_%s_annotation_info_pointers\n" + % (i.name_lower, p.name_lower) + ) + self.outfile.write(" },\n" ' "%s",\n' % (p.name_hyphen)) + if not utils.lookup_annotation( + p.annotations, "org.gtk.GDBus.C.ForceGVariant" + ): + self.outfile.write(" FALSE,\n") + else: + self.outfile.write(" TRUE,\n") + if p.emits_changed_signal: + self.outfile.write(" TRUE\n") + else: + self.outfile.write(" FALSE\n") + self.outfile.write("};\n" "\n") - self.outfile.write('static const GDBusPropertyInfo * const _%s_property_info_pointers[] =\n' - '{\n'%(i.name_lower)) - for p in i.properties: - self.outfile.write(' &_%s_property_info_%s.parent_struct,\n'%(i.name_lower, p.name_lower)) - self.outfile.write(' NULL\n' - '};\n' - '\n') - - num_anno = self.generate_annotations('_%s_annotation_info'%(i.name_lower), i.annotations) - self.outfile.write('static const _ExtendedGDBusInterfaceInfo _%s_interface_info =\n' - '{\n' - ' {\n' - ' -1,\n' - ' (gchar *) "%s",\n'%(i.name_lower, i.name)) - if len(i.methods) == 0: - self.outfile.write(' NULL,\n') - else: - self.outfile.write(' (GDBusMethodInfo **) &_%s_method_info_pointers,\n'%(i.name_lower)) - if len(i.signals) == 0: - self.outfile.write(' NULL,\n') - else: - self.outfile.write(' (GDBusSignalInfo **) &_%s_signal_info_pointers,\n'%(i.name_lower)) - if len(i.properties) == 0: - self.outfile.write(' NULL,\n') - else: - self.outfile.write(' (GDBusPropertyInfo **) &_%s_property_info_pointers,\n'%(i.name_lower)) - if num_anno == 0: - self.outfile.write(' NULL\n') - else: - self.outfile.write(' (GDBusAnnotationInfo **) &_%s_annotation_info_pointers\n'%(i.name_lower)) - self.outfile.write(' },\n' - ' "%s",\n' - '};\n' - '\n' - %(i.name_hyphen)) - self.outfile.write('\n') - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %s_interface_info:\n' - ' *\n' - ' * Gets a machine-readable description of the #%s D-Bus interface.\n' - ' *\n' - ' * Returns: (transfer none): A #GDBusInterfaceInfo. Do not free.\n' - %(i.name_lower, i.name), False)) - self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('GDBusInterfaceInfo *\n' - '%s_interface_info (void)\n' - '{\n' - ' return (GDBusInterfaceInfo *) &_%s_interface_info.parent_struct;\n' - '}\n' - '\n'%(i.name_lower, i.name_lower)) - - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %s_override_properties:\n' - ' * @klass: The class structure for a #GObject derived class.\n' - ' * @property_id_begin: The property id to assign to the first overridden property.\n' - ' *\n' - ' * Overrides all #GObject properties in the #%s interface for a concrete class.\n' - ' * The properties are overridden in the order they are defined.\n' - ' *\n' - ' * Returns: The last property id.\n' - %(i.name_lower, i.camel_name), False)) - self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('guint\n' - '%s_override_properties (GObjectClass *klass, guint property_id_begin)\n' - '{\n'%(i.name_lower)) + self.outfile.write( + "static const GDBusPropertyInfo * const _%s_property_info_pointers[] =\n" + "{\n" % (i.name_lower) + ) for p in i.properties: - self.outfile.write(' g_object_class_override_property (klass, property_id_begin++, "%s");\n'%(p.name_hyphen)) - self.outfile.write(' return property_id_begin - 1;\n' - '}\n' - '\n') - self.outfile.write('\n') + self.outfile.write( + " &_%s_property_info_%s.parent_struct,\n" + % (i.name_lower, p.name_lower) + ) + self.outfile.write(" NULL\n" "};\n" "\n") + + num_anno = self.generate_annotations( + "_%s_annotation_info" % (i.name_lower), i.annotations + ) + self.outfile.write( + "static const _ExtendedGDBusInterfaceInfo _%s_interface_info =\n" + "{\n" + " {\n" + " -1,\n" + ' (gchar *) "%s",\n' % (i.name_lower, i.name) + ) + if len(i.methods) == 0: + self.outfile.write(" NULL,\n") + else: + self.outfile.write( + " (GDBusMethodInfo **) &_%s_method_info_pointers,\n" % (i.name_lower) + ) + if len(i.signals) == 0: + self.outfile.write(" NULL,\n") + else: + self.outfile.write( + " (GDBusSignalInfo **) &_%s_signal_info_pointers,\n" % (i.name_lower) + ) + if len(i.properties) == 0: + self.outfile.write(" NULL,\n") + else: + self.outfile.write( + " (GDBusPropertyInfo **) &_%s_property_info_pointers,\n" + % (i.name_lower) + ) + if num_anno == 0: + self.outfile.write(" NULL\n") + else: + self.outfile.write( + " (GDBusAnnotationInfo **) &_%s_annotation_info_pointers\n" + % (i.name_lower) + ) + self.outfile.write(" },\n" ' "%s",\n' "};\n" "\n" % (i.name_hyphen)) + self.outfile.write("\n") + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %s_interface_info:\n" + " *\n" + " * Gets a machine-readable description of the #%s D-Bus interface.\n" + " *\n" + " * Returns: (transfer none): A #GDBusInterfaceInfo. Do not free.\n" + % (i.name_lower, i.name), + False, + ) + ) + self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) + self.outfile.write( + "GDBusInterfaceInfo *\n" + "%s_interface_info (void)\n" + "{\n" + " return (GDBusInterfaceInfo *) &_%s_interface_info.parent_struct;\n" + "}\n" + "\n" % (i.name_lower, i.name_lower) + ) + + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %s_override_properties:\n" + " * @klass: The class structure for a #GObject derived class.\n" + " * @property_id_begin: The property id to assign to the first overridden property.\n" + " *\n" + " * Overrides all #GObject properties in the #%s interface for a concrete class.\n" + " * The properties are overridden in the order they are defined.\n" + " *\n" + " * Returns: The last property id.\n" % (i.name_lower, i.camel_name), + False, + ) + ) + self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) + self.outfile.write( + "guint\n" + "%s_override_properties (GObjectClass *klass, guint property_id_begin)\n" + "{\n" % (i.name_lower) + ) + for p in i.properties: + self.outfile.write( + ' g_object_class_override_property (klass, property_id_begin++, "%s");\n' + % (p.name_hyphen) + ) + self.outfile.write(" return property_id_begin - 1;\n" "}\n" "\n") + self.outfile.write("\n") # ---------------------------------------------------------------------------------------------------- def generate_interface(self, i): - self.outfile.write('\n') - - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %s:\n' - ' *\n' - ' * Abstract interface type for the D-Bus interface #%s.\n' - %(i.camel_name, i.name), False)) + self.outfile.write("\n") + + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %s:\n" + " *\n" + " * Abstract interface type for the D-Bus interface #%s.\n" + % (i.camel_name, i.name), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('\n') + self.outfile.write("\n") - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sIface:\n' - ' * @parent_iface: The parent interface.\n' - %(i.camel_name), False)) + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sIface:\n" + " * @parent_iface: The parent interface.\n" % (i.camel_name), + False, + ) + ) doc_bits = {} if len(i.methods) > 0: for m in i.methods: - key = (m.since, '_method_%s'%m.name_lower) - value = '@handle_%s: '%(m.name_lower) - value += 'Handler for the #%s::handle-%s signal.'%(i.camel_name, m.name_hyphen) + key = (m.since, "_method_%s" % m.name_lower) + value = "@handle_%s: " % (m.name_lower) + value += "Handler for the #%s::handle-%s signal." % ( + i.camel_name, + m.name_hyphen, + ) doc_bits[key] = value if len(i.signals) > 0: for s in i.signals: - key = (s.since, '_signal_%s'%s.name_lower) - value = '@%s: '%(s.name_lower) - value += 'Handler for the #%s::%s signal.'%(i.camel_name, s.name_hyphen) + key = (s.since, "_signal_%s" % s.name_lower) + value = "@%s: " % (s.name_lower) + value += "Handler for the #%s::%s signal." % ( + i.camel_name, + s.name_hyphen, + ) doc_bits[key] = value if len(i.properties) > 0: for p in i.properties: - key = (p.since, '_prop_get_%s'%p.name_lower) - value = '@get_%s: '%(p.name_lower) - value += 'Getter for the #%s:%s property.'%(i.camel_name, p.name_hyphen) + key = (p.since, "_prop_get_%s" % p.name_lower) + value = "@get_%s: " % (p.name_lower) + value += "Getter for the #%s:%s property." % ( + i.camel_name, + p.name_hyphen, + ) doc_bits[key] = value for key in sorted(doc_bits.keys(), key=utils.version_cmp_key): - self.outfile.write(' * %s\n'%doc_bits[key]) - - self.outfile.write(self.docbook_gen.expand( - ' *\n' - ' * Virtual table for the D-Bus interface #%s.\n' - %(i.name), False)) + self.outfile.write(" * %s\n" % doc_bits[key]) + + self.outfile.write( + self.docbook_gen.expand( + " *\n" " * Virtual table for the D-Bus interface #%s.\n" % (i.name), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('\n') - - self.outfile.write('typedef %sIface %sInterface;\n'%(i.camel_name, i.camel_name)) - self.outfile.write('G_DEFINE_INTERFACE (%s, %s, G_TYPE_OBJECT)\n'%(i.camel_name, i.name_lower)) - self.outfile.write('\n') - - self.outfile.write('static void\n' - '%s_default_init (%sIface *iface)\n' - '{\n'%(i.name_lower, i.camel_name)); + self.outfile.write("\n") + + self.outfile.write( + "typedef %sIface %sInterface;\n" % (i.camel_name, i.camel_name) + ) + self.outfile.write( + "G_DEFINE_INTERFACE (%s, %s, G_TYPE_OBJECT)\n" + % (i.camel_name, i.name_lower) + ) + self.outfile.write("\n") + + self.outfile.write( + "static void\n" + "%s_default_init (%sIface *iface)\n" + "{\n" % (i.name_lower, i.camel_name) + ) if len(i.methods) > 0: - self.outfile.write(' /* GObject signals for incoming D-Bus method calls: */\n') + self.outfile.write( + " /* GObject signals for incoming D-Bus method calls: */\n" + ) for m in i.methods: - self.outfile.write(self.docbook_gen.expand( - ' /**\n' - ' * %s::handle-%s:\n' - ' * @object: A #%s.\n' - ' * @invocation: A #GDBusMethodInvocation.\n' - %(i.camel_name, m.name_hyphen, i.camel_name), False)) + self.outfile.write( + self.docbook_gen.expand( + " /**\n" + " * %s::handle-%s:\n" + " * @object: A #%s.\n" + " * @invocation: A #GDBusMethodInvocation.\n" + % (i.camel_name, m.name_hyphen, i.camel_name), + False, + ) + ) if m.unix_fd: - self.outfile.write(' * @fd_list: (nullable): A #GUnixFDList or %NULL.\n') + self.outfile.write( + " * @fd_list: (nullable): A #GUnixFDList or %NULL.\n" + ) for a in m.in_args: - self.outfile.write(' * @arg_%s: Argument passed by remote caller.\n'%(a.name)) - self.outfile.write(self.docbook_gen.expand( - ' *\n' - ' * Signal emitted when a remote caller is invoking the %s.%s() D-Bus method.\n' - ' *\n' - ' * If a signal handler returns %%TRUE, it means the signal handler will handle the invocation (e.g. take a reference to @invocation and eventually call %s_complete_%s() or e.g. g_dbus_method_invocation_return_error() on it) and no order signal handlers will run. If no signal handler handles the invocation, the %%G_DBUS_ERROR_UNKNOWN_METHOD error is returned.\n' - ' *\n' - ' * Returns: %%G_DBUS_METHOD_INVOCATION_HANDLED or %%TRUE if the invocation was handled, %%G_DBUS_METHOD_INVOCATION_UNHANDLED or %%FALSE to let other signal handlers run.\n' - %(i.name, m.name, i.name_lower, m.name_lower), False)) + self.outfile.write( + " * @arg_%s: Argument passed by remote caller.\n" % (a.name) + ) + self.outfile.write( + self.docbook_gen.expand( + " *\n" + " * Signal emitted when a remote caller is invoking the %s.%s() D-Bus method.\n" + " *\n" + " * If a signal handler returns %%TRUE, it means the signal handler will handle the invocation (e.g. take a reference to @invocation and eventually call %s_complete_%s() or e.g. g_dbus_method_invocation_return_error() on it) and no order signal handlers will run. If no signal handler handles the invocation, the %%G_DBUS_ERROR_UNKNOWN_METHOD error is returned.\n" + " *\n" + " * Returns: %%G_DBUS_METHOD_INVOCATION_HANDLED or %%TRUE if the invocation was handled, %%G_DBUS_METHOD_INVOCATION_UNHANDLED or %%FALSE to let other signal handlers run.\n" + % (i.name, m.name, i.name_lower, m.name_lower), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(m, self.outfile, 2) if m.unix_fd: extra_args = 2 else: extra_args = 1 - self.outfile.write(' g_signal_new ("handle-%s",\n' - ' G_TYPE_FROM_INTERFACE (iface),\n' - ' G_SIGNAL_RUN_LAST,\n' - ' G_STRUCT_OFFSET (%sIface, handle_%s),\n' - ' g_signal_accumulator_true_handled,\n' - ' NULL,\n' # accu_data - ' g_cclosure_marshal_generic,\n' - ' G_TYPE_BOOLEAN,\n' - ' %d,\n' - ' G_TYPE_DBUS_METHOD_INVOCATION' - %(m.name_hyphen, i.camel_name, m.name_lower, len(m.in_args) + extra_args)) + self.outfile.write( + ' g_signal_new ("handle-%s",\n' + " G_TYPE_FROM_INTERFACE (iface),\n" + " G_SIGNAL_RUN_LAST,\n" + " G_STRUCT_OFFSET (%sIface, handle_%s),\n" + " g_signal_accumulator_true_handled,\n" + " NULL,\n" # accu_data + " g_cclosure_marshal_generic,\n" + " G_TYPE_BOOLEAN,\n" + " %d,\n" + " G_TYPE_DBUS_METHOD_INVOCATION" + % ( + m.name_hyphen, + i.camel_name, + m.name_lower, + len(m.in_args) + extra_args, + ) + ) if m.unix_fd: - self.outfile.write(', G_TYPE_UNIX_FD_LIST') + self.outfile.write(", G_TYPE_UNIX_FD_LIST") for a in m.in_args: - self.outfile.write(', %s'%(a.gtype)) - self.outfile.write(');\n') - self.outfile.write('\n') + self.outfile.write(", %s" % (a.gtype)) + self.outfile.write(");\n") + self.outfile.write("\n") if len(i.signals) > 0: - self.outfile.write(' /* GObject signals for received D-Bus signals: */\n') + self.outfile.write(" /* GObject signals for received D-Bus signals: */\n") for s in i.signals: - self.outfile.write(self.docbook_gen.expand( - ' /**\n' - ' * %s::%s:\n' - ' * @object: A #%s.\n' - %(i.camel_name, s.name_hyphen, i.camel_name), False)) + self.outfile.write( + self.docbook_gen.expand( + " /**\n" + " * %s::%s:\n" + " * @object: A #%s.\n" + % (i.camel_name, s.name_hyphen, i.camel_name), + False, + ) + ) for a in s.args: - self.outfile.write(' * @arg_%s: Argument.\n'%(a.name)) - self.outfile.write(self.docbook_gen.expand( - ' *\n' - ' * On the client-side, this signal is emitted whenever the D-Bus signal #%s::%s is received.\n' - ' *\n' - ' * On the service-side, this signal can be used with e.g. g_signal_emit_by_name() to make the object emit the D-Bus signal.\n' - %(i.name, s.name), False)) + self.outfile.write(" * @arg_%s: Argument.\n" % (a.name)) + self.outfile.write( + self.docbook_gen.expand( + " *\n" + " * On the client-side, this signal is emitted whenever the D-Bus signal #%s::%s is received.\n" + " *\n" + " * On the service-side, this signal can be used with e.g. g_signal_emit_by_name() to make the object emit the D-Bus signal.\n" + % (i.name, s.name), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(s, self.outfile, 2) - self.outfile.write(' g_signal_new ("%s",\n' - ' G_TYPE_FROM_INTERFACE (iface),\n' - ' G_SIGNAL_RUN_LAST,\n' - ' G_STRUCT_OFFSET (%sIface, %s),\n' - ' NULL,\n' # accumulator - ' NULL,\n' # accu_data - ' g_cclosure_marshal_generic,\n' - ' G_TYPE_NONE,\n' - ' %d' - %(s.name_hyphen, i.camel_name, s.name_lower, len(s.args))) + self.outfile.write( + ' g_signal_new ("%s",\n' + " G_TYPE_FROM_INTERFACE (iface),\n" + " G_SIGNAL_RUN_LAST,\n" + " G_STRUCT_OFFSET (%sIface, %s),\n" + " NULL,\n" # accumulator + " NULL,\n" # accu_data + " g_cclosure_marshal_generic,\n" + " G_TYPE_NONE,\n" + " %d" % (s.name_hyphen, i.camel_name, s.name_lower, len(s.args)) + ) for a in s.args: - self.outfile.write(', %s'%(a.gtype)) - self.outfile.write(');\n') - self.outfile.write('\n') + self.outfile.write(", %s" % (a.gtype)) + self.outfile.write(");\n") + self.outfile.write("\n") if len(i.properties) > 0: - self.outfile.write(' /* GObject properties for D-Bus properties: */\n') + self.outfile.write(" /* GObject properties for D-Bus properties: */\n") for p in i.properties: if p.readable and p.writable: - hint = 'Since the D-Bus property for this #GObject property is both readable and writable, it is meaningful to both read from it and write to it on both the service- and client-side.' + hint = "Since the D-Bus property for this #GObject property is both readable and writable, it is meaningful to both read from it and write to it on both the service- and client-side." elif p.readable: - hint = 'Since the D-Bus property for this #GObject property is readable but not writable, it is meaningful to read from it on both the client- and service-side. It is only meaningful, however, to write to it on the service-side.' + hint = "Since the D-Bus property for this #GObject property is readable but not writable, it is meaningful to read from it on both the client- and service-side. It is only meaningful, however, to write to it on the service-side." elif p.writable: - hint = 'Since the D-Bus property for this #GObject property is writable but not readable, it is meaningful to write to it on both the client- and service-side. It is only meaningful, however, to read from it on the service-side.' + hint = "Since the D-Bus property for this #GObject property is writable but not readable, it is meaningful to write to it on both the client- and service-side. It is only meaningful, however, to read from it on the service-side." else: - print_error('Cannot handle property "{}" that neither readable nor writable'.format(p.name)) - self.outfile.write(self.docbook_gen.expand( - ' /**\n' - ' * %s:%s:\n' - ' *\n' - ' * Represents the D-Bus property #%s:%s.\n' - ' *\n' - ' * %s\n' - %(i.camel_name, p.name_hyphen, i.name, p.name, hint), False)) + print_error( + 'Cannot handle property "{}" that neither readable nor writable'.format( + p.name + ) + ) + self.outfile.write( + self.docbook_gen.expand( + " /**\n" + " * %s:%s:\n" + " *\n" + " * Represents the D-Bus property #%s:%s.\n" + " *\n" + " * %s\n" + % (i.camel_name, p.name_hyphen, i.name, p.name, hint), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(p, self.outfile, 2) - self.outfile.write(' g_object_interface_install_property (iface,\n') - if p.arg.gtype == 'G_TYPE_VARIANT': - s = 'g_param_spec_variant ("%s", "%s", "%s", G_VARIANT_TYPE ("%s"), NULL'%(p.name_hyphen, p.name, p.name, p.arg.signature) - elif p.arg.signature == 'b': - s = 'g_param_spec_boolean ("%s", "%s", "%s", FALSE'%(p.name_hyphen, p.name, p.name) - elif p.arg.signature == 'y': - s = 'g_param_spec_uchar ("%s", "%s", "%s", 0, 255, 0'%(p.name_hyphen, p.name, p.name) - elif p.arg.signature == 'n': - s = 'g_param_spec_int ("%s", "%s", "%s", G_MININT16, G_MAXINT16, 0'%(p.name_hyphen, p.name, p.name) - elif p.arg.signature == 'q': - s = 'g_param_spec_uint ("%s", "%s", "%s", 0, G_MAXUINT16, 0'%(p.name_hyphen, p.name, p.name) - elif p.arg.signature == 'i': - s = 'g_param_spec_int ("%s", "%s", "%s", G_MININT32, G_MAXINT32, 0'%(p.name_hyphen, p.name, p.name) - elif p.arg.signature == 'u': - s = 'g_param_spec_uint ("%s", "%s", "%s", 0, G_MAXUINT32, 0'%(p.name_hyphen, p.name, p.name) - elif p.arg.signature == 'x': - s = 'g_param_spec_int64 ("%s", "%s", "%s", G_MININT64, G_MAXINT64, 0'%(p.name_hyphen, p.name, p.name) - elif p.arg.signature == 't': - s = 'g_param_spec_uint64 ("%s", "%s", "%s", 0, G_MAXUINT64, 0'%(p.name_hyphen, p.name, p.name) - elif p.arg.signature == 'd': - s = 'g_param_spec_double ("%s", "%s", "%s", -G_MAXDOUBLE, G_MAXDOUBLE, 0.0'%(p.name_hyphen, p.name, p.name) - elif p.arg.signature == 's': - s = 'g_param_spec_string ("%s", "%s", "%s", NULL'%(p.name_hyphen, p.name, p.name) - elif p.arg.signature == 'o': - s = 'g_param_spec_string ("%s", "%s", "%s", NULL'%(p.name_hyphen, p.name, p.name) - elif p.arg.signature == 'g': - s = 'g_param_spec_string ("%s", "%s", "%s", NULL'%(p.name_hyphen, p.name, p.name) - elif p.arg.signature == 'ay': - s = 'g_param_spec_string ("%s", "%s", "%s", NULL'%(p.name_hyphen, p.name, p.name) - elif p.arg.signature == 'as': - s = 'g_param_spec_boxed ("%s", "%s", "%s", G_TYPE_STRV'%(p.name_hyphen, p.name, p.name) - elif p.arg.signature == 'ao': - s = 'g_param_spec_boxed ("%s", "%s", "%s", G_TYPE_STRV'%(p.name_hyphen, p.name, p.name) - elif p.arg.signature == 'aay': - s = 'g_param_spec_boxed ("%s", "%s", "%s", G_TYPE_STRV'%(p.name_hyphen, p.name, p.name) + self.outfile.write(" g_object_interface_install_property (iface,\n") + if p.arg.gtype == "G_TYPE_VARIANT": + s = ( + 'g_param_spec_variant ("%s", "%s", "%s", G_VARIANT_TYPE ("%s"), NULL' + % (p.name_hyphen, p.name, p.name, p.arg.signature) + ) + elif p.arg.signature == "b": + s = 'g_param_spec_boolean ("%s", "%s", "%s", FALSE' % ( + p.name_hyphen, + p.name, + p.name, + ) + elif p.arg.signature == "y": + s = 'g_param_spec_uchar ("%s", "%s", "%s", 0, 255, 0' % ( + p.name_hyphen, + p.name, + p.name, + ) + elif p.arg.signature == "n": + s = ( + 'g_param_spec_int ("%s", "%s", "%s", G_MININT16, G_MAXINT16, 0' + % (p.name_hyphen, p.name, p.name) + ) + elif p.arg.signature == "q": + s = 'g_param_spec_uint ("%s", "%s", "%s", 0, G_MAXUINT16, 0' % ( + p.name_hyphen, + p.name, + p.name, + ) + elif p.arg.signature == "i": + s = ( + 'g_param_spec_int ("%s", "%s", "%s", G_MININT32, G_MAXINT32, 0' + % (p.name_hyphen, p.name, p.name) + ) + elif p.arg.signature == "u": + s = 'g_param_spec_uint ("%s", "%s", "%s", 0, G_MAXUINT32, 0' % ( + p.name_hyphen, + p.name, + p.name, + ) + elif p.arg.signature == "x": + s = ( + 'g_param_spec_int64 ("%s", "%s", "%s", G_MININT64, G_MAXINT64, 0' + % (p.name_hyphen, p.name, p.name) + ) + elif p.arg.signature == "t": + s = 'g_param_spec_uint64 ("%s", "%s", "%s", 0, G_MAXUINT64, 0' % ( + p.name_hyphen, + p.name, + p.name, + ) + elif p.arg.signature == "d": + s = ( + 'g_param_spec_double ("%s", "%s", "%s", -G_MAXDOUBLE, G_MAXDOUBLE, 0.0' + % (p.name_hyphen, p.name, p.name) + ) + elif p.arg.signature == "s": + s = 'g_param_spec_string ("%s", "%s", "%s", NULL' % ( + p.name_hyphen, + p.name, + p.name, + ) + elif p.arg.signature == "o": + s = 'g_param_spec_string ("%s", "%s", "%s", NULL' % ( + p.name_hyphen, + p.name, + p.name, + ) + elif p.arg.signature == "g": + s = 'g_param_spec_string ("%s", "%s", "%s", NULL' % ( + p.name_hyphen, + p.name, + p.name, + ) + elif p.arg.signature == "ay": + s = 'g_param_spec_string ("%s", "%s", "%s", NULL' % ( + p.name_hyphen, + p.name, + p.name, + ) + elif p.arg.signature == "as": + s = 'g_param_spec_boxed ("%s", "%s", "%s", G_TYPE_STRV' % ( + p.name_hyphen, + p.name, + p.name, + ) + elif p.arg.signature == "ao": + s = 'g_param_spec_boxed ("%s", "%s", "%s", G_TYPE_STRV' % ( + p.name_hyphen, + p.name, + p.name, + ) + elif p.arg.signature == "aay": + s = 'g_param_spec_boxed ("%s", "%s", "%s", G_TYPE_STRV' % ( + p.name_hyphen, + p.name, + p.name, + ) else: - print_error('Unsupported gtype "{}" for GParamSpec'.format(p.arg.gtype)) - flags = 'G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS' + print_error( + 'Unsupported gtype "{}" for GParamSpec'.format(p.arg.gtype) + ) + flags = "G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS" if p.deprecated: - flags = 'G_PARAM_DEPRECATED | ' + flags - self.outfile.write(' %s, %s));'%(s, flags)); - self.outfile.write('\n') + flags = "G_PARAM_DEPRECATED | " + flags + self.outfile.write(" %s, %s));" % (s, flags)) + self.outfile.write("\n") - self.outfile.write('}\n' - '\n') + self.outfile.write("}\n" "\n") # ---------------------------------------------------------------------------------------------------- @@ -1651,1237 +2317,1585 @@ class CodeGenerator: for p in i.properties: # getter if p.readable and p.writable: - hint = 'Since this D-Bus property is both readable and writable, it is meaningful to use this function on both the client- and service-side.' + hint = "Since this D-Bus property is both readable and writable, it is meaningful to use this function on both the client- and service-side." elif p.readable: - hint = 'Since this D-Bus property is readable, it is meaningful to use this function on both the client- and service-side.' + hint = "Since this D-Bus property is readable, it is meaningful to use this function on both the client- and service-side." elif p.writable: - hint = 'Since this D-Bus property is not readable, it is only meaningful to use this function on the service-side.' + hint = "Since this D-Bus property is not readable, it is only meaningful to use this function on the service-side." else: - print_error('Cannot handle property "{}" that neither readable nor writable'.format(p.name)) - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %s_get_%s: (skip)\n' - ' * @object: A #%s.\n' - ' *\n' - ' * Gets the value of the #%s:%s D-Bus property.\n' - ' *\n' - ' * %s\n' - ' *\n' - %(i.name_lower, p.name_lower, i.camel_name, i.name, p.name, hint), False)) + print_error( + 'Cannot handle property "{}" that neither readable nor writable'.format( + p.name + ) + ) + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %s_get_%s: (skip)\n" + " * @object: A #%s.\n" + " *\n" + " * Gets the value of the #%s:%s D-Bus property.\n" + " *\n" + " * %s\n" + " *\n" + % (i.name_lower, p.name_lower, i.camel_name, i.name, p.name, hint), + False, + ) + ) if p.arg.free_func != None: - self.outfile.write(' * The returned value is only valid until the property changes so on the client-side it is only safe to use this function on the thread where @object was constructed. Use %s_dup_%s() if on another thread.\n' - ' *\n' - ' * Returns: (transfer none) (nullable): The property value or %%NULL if the property is not set. Do not free the returned value, it belongs to @object.\n' - %(i.name_lower, p.name_lower)) + self.outfile.write( + " * The returned value is only valid until the property changes so on the client-side it is only safe to use this function on the thread where @object was constructed. Use %s_dup_%s() if on another thread.\n" + " *\n" + " * Returns: (transfer none) (nullable): The property value or %%NULL if the property is not set. Do not free the returned value, it belongs to @object.\n" + % (i.name_lower, p.name_lower) + ) else: - self.outfile.write(' * Returns: The property value.\n') + self.outfile.write(" * Returns: The property value.\n") self.write_gtkdoc_deprecated_and_since_and_close(p, self.outfile, 0) - self.outfile.write('%s\n' - '%s_get_%s (%s *object)\n' - '{\n'%(p.arg.ctype_in, i.name_lower, p.name_lower, i.camel_name)) - self.outfile.write(' return %s%s_GET_IFACE (object)->get_%s (object);\n'%(i.ns_upper, i.name_upper, p.name_lower)) - self.outfile.write('}\n') - self.outfile.write('\n') + self.outfile.write( + "%s\n" + "%s_get_%s (%s *object)\n" + "{\n" % (p.arg.ctype_in, i.name_lower, p.name_lower, i.camel_name) + ) + self.outfile.write( + " return %s%s_GET_IFACE (object)->get_%s (object);\n" + % (i.ns_upper, i.name_upper, p.name_lower) + ) + self.outfile.write("}\n") + self.outfile.write("\n") if p.arg.free_func != None: - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %s_dup_%s: (skip)\n' - ' * @object: A #%s.\n' - ' *\n' - ' * Gets a copy of the #%s:%s D-Bus property.\n' - ' *\n' - ' * %s\n' - ' *\n' - ' * Returns: (transfer full) (nullable): The property value or %%NULL if the property is not set. The returned value should be freed with %s().\n' - %(i.name_lower, p.name_lower, i.camel_name, i.name, p.name, hint, p.arg.free_func), False)) + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %s_dup_%s: (skip)\n" + " * @object: A #%s.\n" + " *\n" + " * Gets a copy of the #%s:%s D-Bus property.\n" + " *\n" + " * %s\n" + " *\n" + " * Returns: (transfer full) (nullable): The property value or %%NULL if the property is not set. The returned value should be freed with %s().\n" + % ( + i.name_lower, + p.name_lower, + i.camel_name, + i.name, + p.name, + hint, + p.arg.free_func, + ), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(p, self.outfile, 0) - self.outfile.write('%s\n' - '%s_dup_%s (%s *object)\n' - '{\n' - ' %svalue;\n'%(p.arg.ctype_in_dup, i.name_lower, p.name_lower, i.camel_name, p.arg.ctype_in_dup)) - self.outfile.write(' g_object_get (G_OBJECT (object), "%s", &value, NULL);\n'%(p.name_hyphen)) - self.outfile.write(' return value;\n') - self.outfile.write('}\n') - self.outfile.write('\n') + self.outfile.write( + "%s\n" + "%s_dup_%s (%s *object)\n" + "{\n" + " %svalue;\n" + % ( + p.arg.ctype_in_dup, + i.name_lower, + p.name_lower, + i.camel_name, + p.arg.ctype_in_dup, + ) + ) + self.outfile.write( + ' g_object_get (G_OBJECT (object), "%s", &value, NULL);\n' + % (p.name_hyphen) + ) + self.outfile.write(" return value;\n") + self.outfile.write("}\n") + self.outfile.write("\n") # setter if p.readable and p.writable: - hint = 'Since this D-Bus property is both readable and writable, it is meaningful to use this function on both the client- and service-side.' + hint = "Since this D-Bus property is both readable and writable, it is meaningful to use this function on both the client- and service-side." elif p.readable: - hint = 'Since this D-Bus property is not writable, it is only meaningful to use this function on the service-side.' + hint = "Since this D-Bus property is not writable, it is only meaningful to use this function on the service-side." elif p.writable: - hint = 'Since this D-Bus property is writable, it is meaningful to use this function on both the client- and service-side.' + hint = "Since this D-Bus property is writable, it is meaningful to use this function on both the client- and service-side." else: - print_error('Cannot handle property "{}" that neither readable nor writable'.format(p.name)) - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %s_set_%s: (skip)\n' - ' * @object: A #%s.\n' - ' * @value: The value to set.\n' - ' *\n' - ' * Sets the #%s:%s D-Bus property to @value.\n' - ' *\n' - ' * %s\n' - %(i.name_lower, p.name_lower, i.camel_name, i.name, p.name, hint), False)) + print_error( + 'Cannot handle property "{}" that neither readable nor writable'.format( + p.name + ) + ) + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %s_set_%s: (skip)\n" + " * @object: A #%s.\n" + " * @value: The value to set.\n" + " *\n" + " * Sets the #%s:%s D-Bus property to @value.\n" + " *\n" + " * %s\n" + % (i.name_lower, p.name_lower, i.camel_name, i.name, p.name, hint), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(p, self.outfile, 0) - self.outfile.write('void\n' - '%s_set_%s (%s *object, %svalue)\n' - '{\n'%(i.name_lower, p.name_lower, i.camel_name, p.arg.ctype_in, )) - self.outfile.write(' g_object_set (G_OBJECT (object), "%s", value, NULL);\n'%(p.name_hyphen)) - self.outfile.write('}\n') - self.outfile.write('\n') + self.outfile.write( + "void\n" + "%s_set_%s (%s *object, %svalue)\n" + "{\n" % (i.name_lower, p.name_lower, i.camel_name, p.arg.ctype_in,) + ) + self.outfile.write( + ' g_object_set (G_OBJECT (object), "%s", value, NULL);\n' + % (p.name_hyphen) + ) + self.outfile.write("}\n") + self.outfile.write("\n") # --------------------------------------------------------------------------------------------------- def generate_signal_emitters(self, i): for s in i.signals: - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %s_emit_%s:\n' - ' * @object: A #%s.\n' - %(i.name_lower, s.name_lower, i.camel_name), False)) + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %s_emit_%s:\n" + " * @object: A #%s.\n" % (i.name_lower, s.name_lower, i.camel_name), + False, + ) + ) for a in s.args: - self.outfile.write(' * @arg_%s: Argument to pass with the signal.\n'%(a.name)) - self.outfile.write(self.docbook_gen.expand( - ' *\n' - ' * Emits the #%s::%s D-Bus signal.\n' - %(i.name, s.name), False)) + self.outfile.write( + " * @arg_%s: Argument to pass with the signal.\n" % (a.name) + ) + self.outfile.write( + self.docbook_gen.expand( + " *\n" " * Emits the #%s::%s D-Bus signal.\n" % (i.name, s.name), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(s, self.outfile, 0) - self.outfile.write('void\n' - '%s_emit_%s (\n' - ' %s *object'%(i.name_lower, s.name_lower, i.camel_name)) + self.outfile.write( + "void\n" + "%s_emit_%s (\n" + " %s *object" % (i.name_lower, s.name_lower, i.camel_name) + ) for a in s.args: - self.outfile.write(',\n %sarg_%s'%(a.ctype_in, a.name)) - self.outfile.write(')\n' - '{\n' - ' g_signal_emit_by_name (object, "%s"'%(s.name_hyphen)) + self.outfile.write(",\n %sarg_%s" % (a.ctype_in, a.name)) + self.outfile.write( + ")\n" "{\n" ' g_signal_emit_by_name (object, "%s"' % (s.name_hyphen) + ) for a in s.args: - self.outfile.write(', arg_%s'%a.name) - self.outfile.write(');\n') - self.outfile.write('}\n' - '\n') + self.outfile.write(", arg_%s" % a.name) + self.outfile.write(");\n") + self.outfile.write("}\n" "\n") # --------------------------------------------------------------------------------------------------- def generate_method_calls(self, i): for m in i.methods: # async begin - self.outfile.write('/**\n' - ' * %s_call_%s:\n' - ' * @proxy: A #%sProxy.\n' - %(i.name_lower, m.name_lower, i.camel_name)) + self.outfile.write( + "/**\n" + " * %s_call_%s:\n" + " * @proxy: A #%sProxy.\n" % (i.name_lower, m.name_lower, i.camel_name) + ) for a in m.in_args: - self.outfile.write(' * @arg_%s: Argument to pass with the method invocation.\n'%(a.name)) + self.outfile.write( + " * @arg_%s: Argument to pass with the method invocation.\n" + % (a.name) + ) if self.glib_min_required >= (2, 64): - self.outfile.write(' * @call_flags: Flags from the #GDBusCallFlags enumeration. If you want to allow interactive\n' - ' authorization be sure to set %G_DBUS_CALL_FLAGS_ALLOW_INTERACTIVE_AUTHORIZATION.\n' - ' * @timeout_msec: The timeout in milliseconds (with %G_MAXINT meaning "infinite") or\n' - ' -1 to use the proxy default timeout.\n') + self.outfile.write( + " * @call_flags: Flags from the #GDBusCallFlags enumeration. If you want to allow interactive\n" + " authorization be sure to set %G_DBUS_CALL_FLAGS_ALLOW_INTERACTIVE_AUTHORIZATION.\n" + ' * @timeout_msec: The timeout in milliseconds (with %G_MAXINT meaning "infinite") or\n' + " -1 to use the proxy default timeout.\n" + ) if m.unix_fd: - self.outfile.write(' * @fd_list: (nullable): A #GUnixFDList or %NULL.\n') - self.outfile.write(self.docbook_gen.expand( - ' * @cancellable: (nullable): A #GCancellable or %%NULL.\n' - ' * @callback: A #GAsyncReadyCallback to call when the request is satisfied or %%NULL.\n' - ' * @user_data: User data to pass to @callback.\n' - ' *\n' - ' * Asynchronously invokes the %s.%s() D-Bus method on @proxy.\n' - ' * When the operation is finished, @callback will be invoked in the thread-default main loop of the thread you are calling this method from (see g_main_context_push_thread_default()).\n' - ' * You can then call %s_call_%s_finish() to get the result of the operation.\n' - ' *\n' - ' * See %s_call_%s_sync() for the synchronous, blocking version of this method.\n' - %(i.name, m.name, i.name_lower, m.name_lower, i.name_lower, m.name_lower), False)) + self.outfile.write( + " * @fd_list: (nullable): A #GUnixFDList or %NULL.\n" + ) + self.outfile.write( + self.docbook_gen.expand( + " * @cancellable: (nullable): A #GCancellable or %%NULL.\n" + " * @callback: A #GAsyncReadyCallback to call when the request is satisfied or %%NULL.\n" + " * @user_data: User data to pass to @callback.\n" + " *\n" + " * Asynchronously invokes the %s.%s() D-Bus method on @proxy.\n" + " * When the operation is finished, @callback will be invoked in the thread-default main loop of the thread you are calling this method from (see g_main_context_push_thread_default()).\n" + " * You can then call %s_call_%s_finish() to get the result of the operation.\n" + " *\n" + " * See %s_call_%s_sync() for the synchronous, blocking version of this method.\n" + % ( + i.name, + m.name, + i.name_lower, + m.name_lower, + i.name_lower, + m.name_lower, + ), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(m, self.outfile, 0) - self.outfile.write('void\n' - '%s_call_%s (\n' - ' %s *proxy'%(i.name_lower, m.name_lower, i.camel_name)) + self.outfile.write( + "void\n" + "%s_call_%s (\n" + " %s *proxy" % (i.name_lower, m.name_lower, i.camel_name) + ) for a in m.in_args: - self.outfile.write(',\n %sarg_%s'%(a.ctype_in, a.name)) + self.outfile.write(",\n %sarg_%s" % (a.ctype_in, a.name)) if self.glib_min_required >= (2, 64): - self.outfile.write(',\n GDBusCallFlags call_flags' - ',\n gint timeout_msec') + self.outfile.write( + ",\n GDBusCallFlags call_flags" ",\n gint timeout_msec" + ) if m.unix_fd: - self.outfile.write(',\n GUnixFDList *fd_list') - self.outfile.write(',\n' - ' GCancellable *cancellable,\n' - ' GAsyncReadyCallback callback,\n' - ' gpointer user_data)\n' - '{\n') + self.outfile.write(",\n GUnixFDList *fd_list") + self.outfile.write( + ",\n" + " GCancellable *cancellable,\n" + " GAsyncReadyCallback callback,\n" + " gpointer user_data)\n" + "{\n" + ) if m.unix_fd: - self.outfile.write(' g_dbus_proxy_call_with_unix_fd_list (G_DBUS_PROXY (proxy),\n') + self.outfile.write( + " g_dbus_proxy_call_with_unix_fd_list (G_DBUS_PROXY (proxy),\n" + ) else: - self.outfile.write(' g_dbus_proxy_call (G_DBUS_PROXY (proxy),\n') - self.outfile.write(' "%s",\n' - ' g_variant_new ("('%(m.name)) + self.outfile.write(" g_dbus_proxy_call (G_DBUS_PROXY (proxy),\n") + self.outfile.write(' "%s",\n' ' g_variant_new ("(' % (m.name)) for a in m.in_args: - self.outfile.write('%s'%(a.format_in)) + self.outfile.write("%s" % (a.format_in)) self.outfile.write(')"') for a in m.in_args: - self.outfile.write(',\n arg_%s'%(a.name)) - self.outfile.write('),\n') + self.outfile.write(",\n arg_%s" % (a.name)) + self.outfile.write("),\n") if self.glib_min_required >= (2, 64): - self.outfile.write(' call_flags,\n' - ' timeout_msec,\n') + self.outfile.write(" call_flags,\n" " timeout_msec,\n") else: - self.outfile.write(' G_DBUS_CALL_FLAGS_NONE,\n' - ' -1,\n') + self.outfile.write(" G_DBUS_CALL_FLAGS_NONE,\n" " -1,\n") if m.unix_fd: - self.outfile.write(' fd_list,\n') - self.outfile.write(' cancellable,\n' - ' callback,\n' - ' user_data);\n') - self.outfile.write('}\n' - '\n') + self.outfile.write(" fd_list,\n") + self.outfile.write( + " cancellable,\n" " callback,\n" " user_data);\n" + ) + self.outfile.write("}\n" "\n") # async finish - self.outfile.write('/**\n' - ' * %s_call_%s_finish:\n' - ' * @proxy: A #%sProxy.\n' - %(i.name_lower, m.name_lower, i.camel_name)) + self.outfile.write( + "/**\n" + " * %s_call_%s_finish:\n" + " * @proxy: A #%sProxy.\n" % (i.name_lower, m.name_lower, i.camel_name) + ) for a in m.out_args: - self.outfile.write(' * @out_%s: (out) (optional)%s: Return location for return parameter or %%NULL to ignore.\n'%(a.name, ' ' + a.array_annotation if a.array_annotation else '')) + self.outfile.write( + " * @out_%s: (out) (optional)%s: Return location for return parameter or %%NULL to ignore.\n" + % (a.name, " " + a.array_annotation if a.array_annotation else "") + ) if m.unix_fd: - self.outfile.write(' * @out_fd_list: (out) (optional): Return location for a #GUnixFDList or %NULL to ignore.\n') - self.outfile.write(self.docbook_gen.expand( - ' * @res: The #GAsyncResult obtained from the #GAsyncReadyCallback passed to %s_call_%s().\n' - ' * @error: Return location for error or %%NULL.\n' - ' *\n' - ' * Finishes an operation started with %s_call_%s().\n' - ' *\n' - ' * Returns: (skip): %%TRUE if the call succeeded, %%FALSE if @error is set.\n' - %(i.name_lower, m.name_lower, i.name_lower, m.name_lower), False)) + self.outfile.write( + " * @out_fd_list: (out) (optional): Return location for a #GUnixFDList or %NULL to ignore.\n" + ) + self.outfile.write( + self.docbook_gen.expand( + " * @res: The #GAsyncResult obtained from the #GAsyncReadyCallback passed to %s_call_%s().\n" + " * @error: Return location for error or %%NULL.\n" + " *\n" + " * Finishes an operation started with %s_call_%s().\n" + " *\n" + " * Returns: (skip): %%TRUE if the call succeeded, %%FALSE if @error is set.\n" + % (i.name_lower, m.name_lower, i.name_lower, m.name_lower), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(m, self.outfile, 0) - self.outfile.write('gboolean\n' - '%s_call_%s_finish (\n' - ' %s *proxy'%(i.name_lower, m.name_lower, i.camel_name)) + self.outfile.write( + "gboolean\n" + "%s_call_%s_finish (\n" + " %s *proxy" % (i.name_lower, m.name_lower, i.camel_name) + ) for a in m.out_args: - self.outfile.write(',\n %sout_%s'%(a.ctype_out, a.name)) + self.outfile.write(",\n %sout_%s" % (a.ctype_out, a.name)) if m.unix_fd: - self.outfile.write(',\n GUnixFDList **out_fd_list') - self.outfile.write(',\n' - ' GAsyncResult *res,\n' - ' GError **error)\n' - '{\n' - ' GVariant *_ret;\n') + self.outfile.write(",\n GUnixFDList **out_fd_list") + self.outfile.write( + ",\n" + " GAsyncResult *res,\n" + " GError **error)\n" + "{\n" + " GVariant *_ret;\n" + ) if m.unix_fd: - self.outfile.write(' _ret = g_dbus_proxy_call_with_unix_fd_list_finish (G_DBUS_PROXY (proxy), out_fd_list, res, error);\n') + self.outfile.write( + " _ret = g_dbus_proxy_call_with_unix_fd_list_finish (G_DBUS_PROXY (proxy), out_fd_list, res, error);\n" + ) else: - self.outfile.write(' _ret = g_dbus_proxy_call_finish (G_DBUS_PROXY (proxy), res, error);\n') - self.outfile.write(' if (_ret == NULL)\n' - ' goto _out;\n') - self.outfile.write(' g_variant_get (_ret,\n' - ' \"(') + self.outfile.write( + " _ret = g_dbus_proxy_call_finish (G_DBUS_PROXY (proxy), res, error);\n" + ) + self.outfile.write(" if (_ret == NULL)\n" " goto _out;\n") + self.outfile.write(" g_variant_get (_ret,\n" ' "(') for a in m.out_args: - self.outfile.write('%s'%(a.format_out)) + self.outfile.write("%s" % (a.format_out)) self.outfile.write(')"') for a in m.out_args: - self.outfile.write(',\n out_%s'%(a.name)) - self.outfile.write(');\n' - ' g_variant_unref (_ret);\n') - self.outfile.write('_out:\n' - ' return _ret != NULL;\n' - '}\n' - '\n') - + self.outfile.write(",\n out_%s" % (a.name)) + self.outfile.write(");\n" " g_variant_unref (_ret);\n") + self.outfile.write("_out:\n" " return _ret != NULL;\n" "}\n" "\n") # sync - self.outfile.write('/**\n' - ' * %s_call_%s_sync:\n' - ' * @proxy: A #%sProxy.\n' - %(i.name_lower, m.name_lower, i.camel_name)) + self.outfile.write( + "/**\n" + " * %s_call_%s_sync:\n" + " * @proxy: A #%sProxy.\n" % (i.name_lower, m.name_lower, i.camel_name) + ) for a in m.in_args: - self.outfile.write(' * @arg_%s: Argument to pass with the method invocation.\n'%(a.name)) + self.outfile.write( + " * @arg_%s: Argument to pass with the method invocation.\n" + % (a.name) + ) if self.glib_min_required >= (2, 64): - self.outfile.write(' * @call_flags: Flags from the #GDBusCallFlags enumeration. If you want to allow interactive\n' - ' authorization be sure to set %G_DBUS_CALL_FLAGS_ALLOW_INTERACTIVE_AUTHORIZATION.\n' - ' * @timeout_msec: The timeout in milliseconds (with %G_MAXINT meaning "infinite") or\n' - ' -1 to use the proxy default timeout.\n') + self.outfile.write( + " * @call_flags: Flags from the #GDBusCallFlags enumeration. If you want to allow interactive\n" + " authorization be sure to set %G_DBUS_CALL_FLAGS_ALLOW_INTERACTIVE_AUTHORIZATION.\n" + ' * @timeout_msec: The timeout in milliseconds (with %G_MAXINT meaning "infinite") or\n' + " -1 to use the proxy default timeout.\n" + ) if m.unix_fd: - self.outfile.write(' * @fd_list: (nullable): A #GUnixFDList or %NULL.\n') + self.outfile.write( + " * @fd_list: (nullable): A #GUnixFDList or %NULL.\n" + ) for a in m.out_args: - self.outfile.write(' * @out_%s: (out) (optional)%s: Return location for return parameter or %%NULL to ignore.\n'%(a.name, ' ' + a.array_annotation if a.array_annotation else '')) + self.outfile.write( + " * @out_%s: (out) (optional)%s: Return location for return parameter or %%NULL to ignore.\n" + % (a.name, " " + a.array_annotation if a.array_annotation else "") + ) if m.unix_fd: - self.outfile.write(' * @out_fd_list: (out): Return location for a #GUnixFDList or %NULL.\n') - self.outfile.write(self.docbook_gen.expand( - ' * @cancellable: (nullable): A #GCancellable or %%NULL.\n' - ' * @error: Return location for error or %%NULL.\n' - ' *\n' - ' * Synchronously invokes the %s.%s() D-Bus method on @proxy. The calling thread is blocked until a reply is received.\n' - ' *\n' - ' * See %s_call_%s() for the asynchronous version of this method.\n' - ' *\n' - ' * Returns: (skip): %%TRUE if the call succeeded, %%FALSE if @error is set.\n' - %(i.name, m.name, i.name_lower, m.name_lower), False)) + self.outfile.write( + " * @out_fd_list: (out): Return location for a #GUnixFDList or %NULL.\n" + ) + self.outfile.write( + self.docbook_gen.expand( + " * @cancellable: (nullable): A #GCancellable or %%NULL.\n" + " * @error: Return location for error or %%NULL.\n" + " *\n" + " * Synchronously invokes the %s.%s() D-Bus method on @proxy. The calling thread is blocked until a reply is received.\n" + " *\n" + " * See %s_call_%s() for the asynchronous version of this method.\n" + " *\n" + " * Returns: (skip): %%TRUE if the call succeeded, %%FALSE if @error is set.\n" + % (i.name, m.name, i.name_lower, m.name_lower), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(m, self.outfile, 0) - self.outfile.write('gboolean\n' - '%s_call_%s_sync (\n' - ' %s *proxy'%(i.name_lower, m.name_lower, i.camel_name)) + self.outfile.write( + "gboolean\n" + "%s_call_%s_sync (\n" + " %s *proxy" % (i.name_lower, m.name_lower, i.camel_name) + ) for a in m.in_args: - self.outfile.write(',\n %sarg_%s'%(a.ctype_in, a.name)) + self.outfile.write(",\n %sarg_%s" % (a.ctype_in, a.name)) if self.glib_min_required >= (2, 64): - self.outfile.write(',\n GDBusCallFlags call_flags' - ',\n gint timeout_msec') + self.outfile.write( + ",\n GDBusCallFlags call_flags" ",\n gint timeout_msec" + ) if m.unix_fd: - self.outfile.write(',\n GUnixFDList *fd_list') + self.outfile.write(",\n GUnixFDList *fd_list") for a in m.out_args: - self.outfile.write(',\n %sout_%s'%(a.ctype_out, a.name)) + self.outfile.write(",\n %sout_%s" % (a.ctype_out, a.name)) if m.unix_fd: - self.outfile.write(',\n GUnixFDList **out_fd_list') - self.outfile.write(',\n' - ' GCancellable *cancellable,\n' - ' GError **error)\n' - '{\n' - ' GVariant *_ret;\n') + self.outfile.write(",\n GUnixFDList **out_fd_list") + self.outfile.write( + ",\n" + " GCancellable *cancellable,\n" + " GError **error)\n" + "{\n" + " GVariant *_ret;\n" + ) if m.unix_fd: - self.outfile.write(' _ret = g_dbus_proxy_call_with_unix_fd_list_sync (G_DBUS_PROXY (proxy),\n') + self.outfile.write( + " _ret = g_dbus_proxy_call_with_unix_fd_list_sync (G_DBUS_PROXY (proxy),\n" + ) else: - self.outfile.write(' _ret = g_dbus_proxy_call_sync (G_DBUS_PROXY (proxy),\n') - self.outfile.write(' "%s",\n' - ' g_variant_new ("('%(m.name)) + self.outfile.write( + " _ret = g_dbus_proxy_call_sync (G_DBUS_PROXY (proxy),\n" + ) + self.outfile.write(' "%s",\n' ' g_variant_new ("(' % (m.name)) for a in m.in_args: - self.outfile.write('%s'%(a.format_in)) + self.outfile.write("%s" % (a.format_in)) self.outfile.write(')"') for a in m.in_args: - self.outfile.write(',\n arg_%s'%(a.name)) - self.outfile.write('),\n') + self.outfile.write(",\n arg_%s" % (a.name)) + self.outfile.write("),\n") if self.glib_min_required >= (2, 64): - self.outfile.write(' call_flags,\n' - ' timeout_msec,\n') + self.outfile.write(" call_flags,\n" " timeout_msec,\n") else: - self.outfile.write(' G_DBUS_CALL_FLAGS_NONE,\n' - ' -1,\n') + self.outfile.write(" G_DBUS_CALL_FLAGS_NONE,\n" " -1,\n") if m.unix_fd: - self.outfile.write(' fd_list,\n' - ' out_fd_list,\n') - self.outfile.write(' cancellable,\n' - ' error);\n' - ' if (_ret == NULL)\n' - ' goto _out;\n') - self.outfile.write(' g_variant_get (_ret,\n' - ' \"(') + self.outfile.write(" fd_list,\n" " out_fd_list,\n") + self.outfile.write( + " cancellable,\n" + " error);\n" + " if (_ret == NULL)\n" + " goto _out;\n" + ) + self.outfile.write(" g_variant_get (_ret,\n" ' "(') for a in m.out_args: - self.outfile.write('%s'%(a.format_out)) + self.outfile.write("%s" % (a.format_out)) self.outfile.write(')"') for a in m.out_args: - self.outfile.write(',\n out_%s'%(a.name)) - self.outfile.write(');\n' - ' g_variant_unref (_ret);\n') - self.outfile.write('_out:\n' - ' return _ret != NULL;\n' - '}\n' - '\n') + self.outfile.write(",\n out_%s" % (a.name)) + self.outfile.write(");\n" " g_variant_unref (_ret);\n") + self.outfile.write("_out:\n" " return _ret != NULL;\n" "}\n" "\n") # --------------------------------------------------------------------------------------------------- def generate_method_completers(self, i): for m in i.methods: - self.outfile.write('/**\n' - ' * %s_complete_%s:\n' - ' * @object: A #%s.\n' - ' * @invocation: (transfer full): A #GDBusMethodInvocation.\n' - %(i.name_lower, m.name_lower, i.camel_name)) + self.outfile.write( + "/**\n" + " * %s_complete_%s:\n" + " * @object: A #%s.\n" + " * @invocation: (transfer full): A #GDBusMethodInvocation.\n" + % (i.name_lower, m.name_lower, i.camel_name) + ) if m.unix_fd: - self.outfile.write(' * @fd_list: (nullable): A #GUnixFDList or %NULL.\n') + self.outfile.write( + " * @fd_list: (nullable): A #GUnixFDList or %NULL.\n" + ) for a in m.out_args: - self.outfile.write(' * @%s: Parameter to return.\n'%(a.name)) - self.outfile.write(self.docbook_gen.expand( - ' *\n' - ' * Helper function used in service implementations to finish handling invocations of the %s.%s() D-Bus method. If you instead want to finish handling an invocation by returning an error, use g_dbus_method_invocation_return_error() or similar.\n' - ' *\n' - ' * This method will free @invocation, you cannot use it afterwards.\n' - %(i.name, m.name), False)) + self.outfile.write(" * @%s: Parameter to return.\n" % (a.name)) + self.outfile.write( + self.docbook_gen.expand( + " *\n" + " * Helper function used in service implementations to finish handling invocations of the %s.%s() D-Bus method. If you instead want to finish handling an invocation by returning an error, use g_dbus_method_invocation_return_error() or similar.\n" + " *\n" + " * This method will free @invocation, you cannot use it afterwards.\n" + % (i.name, m.name), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(m, self.outfile, 0) - self.outfile.write('void\n' - '%s_complete_%s (\n' - ' %s *object,\n' - ' GDBusMethodInvocation *invocation'%(i.name_lower, m.name_lower, i.camel_name)) + self.outfile.write( + "void\n" + "%s_complete_%s (\n" + " %s *object,\n" + " GDBusMethodInvocation *invocation" + % (i.name_lower, m.name_lower, i.camel_name) + ) if m.unix_fd: - self.outfile.write(',\n GUnixFDList *fd_list') + self.outfile.write(",\n GUnixFDList *fd_list") for a in m.out_args: - self.outfile.write(',\n %s%s'%(a.ctype_in, a.name)) - self.outfile.write(')\n' - '{\n') + self.outfile.write(",\n %s%s" % (a.ctype_in, a.name)) + self.outfile.write(")\n" "{\n") if m.unix_fd: - self.outfile.write(' g_dbus_method_invocation_return_value_with_unix_fd_list (invocation,\n' - ' g_variant_new ("(') + self.outfile.write( + " g_dbus_method_invocation_return_value_with_unix_fd_list (invocation,\n" + ' g_variant_new ("(' + ) else: - self.outfile.write(' g_dbus_method_invocation_return_value (invocation,\n' - ' g_variant_new ("(') + self.outfile.write( + " g_dbus_method_invocation_return_value (invocation,\n" + ' g_variant_new ("(' + ) for a in m.out_args: - self.outfile.write('%s'%(a.format_in)) + self.outfile.write("%s" % (a.format_in)) self.outfile.write(')"') for a in m.out_args: - self.outfile.write(',\n %s'%(a.name)) + self.outfile.write(",\n %s" % (a.name)) if m.unix_fd: - self.outfile.write('),\n fd_list);\n') + self.outfile.write("),\n fd_list);\n") else: - self.outfile.write('));\n') - self.outfile.write('}\n' - '\n') + self.outfile.write("));\n") + self.outfile.write("}\n" "\n") # --------------------------------------------------------------------------------------------------- def generate_proxy(self, i): # class boilerplate - self.outfile.write('/* ------------------------------------------------------------------------ */\n' - '\n') - - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sProxy:\n' - ' *\n' - ' * The #%sProxy structure contains only private data and should only be accessed using the provided API.\n' - %(i.camel_name, i.camel_name), False)) + self.outfile.write( + "/* ------------------------------------------------------------------------ */\n" + "\n" + ) + + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sProxy:\n" + " *\n" + " * The #%sProxy structure contains only private data and should only be accessed using the provided API.\n" + % (i.camel_name, i.camel_name), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('\n') - - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sProxyClass:\n' - ' * @parent_class: The parent class.\n' - ' *\n' - ' * Class structure for #%sProxy.\n' - %(i.camel_name, i.camel_name), False)) + self.outfile.write("\n") + + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sProxyClass:\n" + " * @parent_class: The parent class.\n" + " *\n" + " * Class structure for #%sProxy.\n" % (i.camel_name, i.camel_name), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('\n') - - self.outfile.write('struct _%sProxyPrivate\n' - '{\n' - ' GData *qdata;\n' - '};\n' - '\n'%i.camel_name) - - self.outfile.write('static void %s_proxy_iface_init (%sIface *iface);\n' - '\n'%(i.name_lower, i.camel_name)) - self.outfile.write('#if GLIB_VERSION_MAX_ALLOWED >= GLIB_VERSION_2_38\n') - self.outfile.write('G_DEFINE_TYPE_WITH_CODE (%sProxy, %s_proxy, G_TYPE_DBUS_PROXY,\n'%(i.camel_name, i.name_lower)) - self.outfile.write(' G_ADD_PRIVATE (%sProxy)\n'%(i.camel_name)) - self.outfile.write(' G_IMPLEMENT_INTERFACE (%sTYPE_%s, %s_proxy_iface_init))\n\n'%(i.ns_upper, i.name_upper, i.name_lower)) - self.outfile.write('#else\n') - self.outfile.write('G_DEFINE_TYPE_WITH_CODE (%sProxy, %s_proxy, G_TYPE_DBUS_PROXY,\n'%(i.camel_name, i.name_lower)) - self.outfile.write(' G_IMPLEMENT_INTERFACE (%sTYPE_%s, %s_proxy_iface_init))\n\n'%(i.ns_upper, i.name_upper, i.name_lower)) - self.outfile.write('#endif\n') + self.outfile.write("\n") + + self.outfile.write( + "struct _%sProxyPrivate\n" + "{\n" + " GData *qdata;\n" + "};\n" + "\n" % i.camel_name + ) + + self.outfile.write( + "static void %s_proxy_iface_init (%sIface *iface);\n" + "\n" % (i.name_lower, i.camel_name) + ) + self.outfile.write("#if GLIB_VERSION_MAX_ALLOWED >= GLIB_VERSION_2_38\n") + self.outfile.write( + "G_DEFINE_TYPE_WITH_CODE (%sProxy, %s_proxy, G_TYPE_DBUS_PROXY,\n" + % (i.camel_name, i.name_lower) + ) + self.outfile.write( + " G_ADD_PRIVATE (%sProxy)\n" % (i.camel_name) + ) + self.outfile.write( + " G_IMPLEMENT_INTERFACE (%sTYPE_%s, %s_proxy_iface_init))\n\n" + % (i.ns_upper, i.name_upper, i.name_lower) + ) + self.outfile.write("#else\n") + self.outfile.write( + "G_DEFINE_TYPE_WITH_CODE (%sProxy, %s_proxy, G_TYPE_DBUS_PROXY,\n" + % (i.camel_name, i.name_lower) + ) + self.outfile.write( + " G_IMPLEMENT_INTERFACE (%sTYPE_%s, %s_proxy_iface_init))\n\n" + % (i.ns_upper, i.name_upper, i.name_lower) + ) + self.outfile.write("#endif\n") # finalize - self.outfile.write('static void\n' - '%s_proxy_finalize (GObject *object)\n' - '{\n'%(i.name_lower)) - self.outfile.write(' %sProxy *proxy = %s%s_PROXY (object);\n'%(i.camel_name, i.ns_upper, i.name_upper)) - self.outfile.write(' g_datalist_clear (&proxy->priv->qdata);\n') - self.outfile.write(' G_OBJECT_CLASS (%s_proxy_parent_class)->finalize (object);\n' - '}\n' - '\n'%(i.name_lower)) + self.outfile.write( + "static void\n" + "%s_proxy_finalize (GObject *object)\n" + "{\n" % (i.name_lower) + ) + self.outfile.write( + " %sProxy *proxy = %s%s_PROXY (object);\n" + % (i.camel_name, i.ns_upper, i.name_upper) + ) + self.outfile.write(" g_datalist_clear (&proxy->priv->qdata);\n") + self.outfile.write( + " G_OBJECT_CLASS (%s_proxy_parent_class)->finalize (object);\n" + "}\n" + "\n" % (i.name_lower) + ) # property accessors # # Note that we are guaranteed that prop_id starts at 1 and is # laid out in the same order as introspection data pointers # - self.outfile.write('static void\n' - '%s_proxy_get_property (GObject *object,\n' - ' guint prop_id,\n' - ' GValue *value,\n' - ' GParamSpec *pspec G_GNUC_UNUSED)\n' - '{\n'%(i.name_lower)) + self.outfile.write( + "static void\n" + "%s_proxy_get_property (GObject *object,\n" + " guint prop_id,\n" + " GValue *value,\n" + " GParamSpec *pspec G_GNUC_UNUSED)\n" + "{\n" % (i.name_lower) + ) if len(i.properties) > 0: - self.outfile.write(' const _ExtendedGDBusPropertyInfo *info;\n' - ' GVariant *variant;\n' - ' g_assert (prop_id != 0 && prop_id - 1 < %d);\n' - ' info = (const _ExtendedGDBusPropertyInfo *) _%s_property_info_pointers[prop_id - 1];\n' - ' variant = g_dbus_proxy_get_cached_property (G_DBUS_PROXY (object), info->parent_struct.name);\n' - ' if (info->use_gvariant)\n' - ' {\n' - ' g_value_set_variant (value, variant);\n' - ' }\n' - ' else\n' - ' {\n' - # could be that we don't have the value in cache - in that case, we do - # nothing and the user gets the default value for the GType - ' if (variant != NULL)\n' - ' g_dbus_gvariant_to_gvalue (variant, value);\n' - ' }\n' - ' if (variant != NULL)\n' - ' g_variant_unref (variant);\n' - %(len(i.properties), i.name_lower)) - self.outfile.write('}\n' - '\n') + self.outfile.write( + " const _ExtendedGDBusPropertyInfo *info;\n" + " GVariant *variant;\n" + " g_assert (prop_id != 0 && prop_id - 1 < %d);\n" + " info = (const _ExtendedGDBusPropertyInfo *) _%s_property_info_pointers[prop_id - 1];\n" + " variant = g_dbus_proxy_get_cached_property (G_DBUS_PROXY (object), info->parent_struct.name);\n" + " if (info->use_gvariant)\n" + " {\n" + " g_value_set_variant (value, variant);\n" + " }\n" + " else\n" + " {\n" + # could be that we don't have the value in cache - in that case, we do + # nothing and the user gets the default value for the GType + " if (variant != NULL)\n" + " g_dbus_gvariant_to_gvalue (variant, value);\n" + " }\n" + " if (variant != NULL)\n" + " g_variant_unref (variant);\n" % (len(i.properties), i.name_lower) + ) + self.outfile.write("}\n" "\n") if len(i.properties) > 0: - self.outfile.write('static void\n' - '%s_proxy_set_property_cb (GDBusProxy *proxy,\n' - ' GAsyncResult *res,\n' - ' gpointer user_data)\n' - '{\n'%(i.name_lower)) - self.outfile.write(' const _ExtendedGDBusPropertyInfo *info = user_data;\n' - ' GError *error;\n' - ' GVariant *_ret;\n' - ' error = NULL;\n' - ' _ret = g_dbus_proxy_call_finish (proxy, res, &error);\n' - ' if (!_ret)\n' - ' {\n' - ' g_warning ("Error setting property \'%%s\' on interface %s: %%s (%%s, %%d)",\n' - ' info->parent_struct.name, \n' - ' error->message, g_quark_to_string (error->domain), error->code);\n' - ' g_error_free (error);\n' - ' }\n' - ' else\n' - ' {\n' - ' g_variant_unref (_ret);\n' - ' }\n' - %(i.name)) - self.outfile.write('}\n' - '\n') - self.outfile.write('static void\n' - '%s_proxy_set_property (GObject *object,\n' - ' guint prop_id,\n' - ' const GValue *value,\n' - ' GParamSpec *pspec G_GNUC_UNUSED)\n' - '{\n'%(i.name_lower)) + self.outfile.write( + "static void\n" + "%s_proxy_set_property_cb (GDBusProxy *proxy,\n" + " GAsyncResult *res,\n" + " gpointer user_data)\n" + "{\n" % (i.name_lower) + ) + self.outfile.write( + " const _ExtendedGDBusPropertyInfo *info = user_data;\n" + " GError *error;\n" + " GVariant *_ret;\n" + " error = NULL;\n" + " _ret = g_dbus_proxy_call_finish (proxy, res, &error);\n" + " if (!_ret)\n" + " {\n" + " g_warning (\"Error setting property '%%s' on interface %s: %%s (%%s, %%d)\",\n" + " info->parent_struct.name, \n" + " error->message, g_quark_to_string (error->domain), error->code);\n" + " g_error_free (error);\n" + " }\n" + " else\n" + " {\n" + " g_variant_unref (_ret);\n" + " }\n" % (i.name) + ) + self.outfile.write("}\n" "\n") + self.outfile.write( + "static void\n" + "%s_proxy_set_property (GObject *object,\n" + " guint prop_id,\n" + " const GValue *value,\n" + " GParamSpec *pspec G_GNUC_UNUSED)\n" + "{\n" % (i.name_lower) + ) if len(i.properties) > 0: - self.outfile.write(' const _ExtendedGDBusPropertyInfo *info;\n' - ' GVariant *variant;\n' - ' g_assert (prop_id != 0 && prop_id - 1 < %d);\n' - ' info = (const _ExtendedGDBusPropertyInfo *) _%s_property_info_pointers[prop_id - 1];\n' - ' variant = g_dbus_gvalue_to_gvariant (value, G_VARIANT_TYPE (info->parent_struct.signature));\n' - ' g_dbus_proxy_call (G_DBUS_PROXY (object),\n' - ' "org.freedesktop.DBus.Properties.Set",\n' - ' g_variant_new ("(ssv)", "%s", info->parent_struct.name, variant),\n' - ' G_DBUS_CALL_FLAGS_NONE,\n' - ' -1,\n' - ' NULL, (GAsyncReadyCallback) %s_proxy_set_property_cb, (GDBusPropertyInfo *) &info->parent_struct);\n' - ' g_variant_unref (variant);\n' - %(len(i.properties), i.name_lower, i.name, i.name_lower)) - self.outfile.write('}\n' - '\n') + self.outfile.write( + " const _ExtendedGDBusPropertyInfo *info;\n" + " GVariant *variant;\n" + " g_assert (prop_id != 0 && prop_id - 1 < %d);\n" + " info = (const _ExtendedGDBusPropertyInfo *) _%s_property_info_pointers[prop_id - 1];\n" + " variant = g_dbus_gvalue_to_gvariant (value, G_VARIANT_TYPE (info->parent_struct.signature));\n" + " g_dbus_proxy_call (G_DBUS_PROXY (object),\n" + ' "org.freedesktop.DBus.Properties.Set",\n' + ' g_variant_new ("(ssv)", "%s", info->parent_struct.name, variant),\n' + " G_DBUS_CALL_FLAGS_NONE,\n" + " -1,\n" + " NULL, (GAsyncReadyCallback) %s_proxy_set_property_cb, (GDBusPropertyInfo *) &info->parent_struct);\n" + " g_variant_unref (variant);\n" + % (len(i.properties), i.name_lower, i.name, i.name_lower) + ) + self.outfile.write("}\n" "\n") # signal received - self.outfile.write('static void\n' - '%s_proxy_g_signal (GDBusProxy *proxy,\n' - ' const gchar *sender_name G_GNUC_UNUSED,\n' - ' const gchar *signal_name,\n' - ' GVariant *parameters)\n' - '{\n'%(i.name_lower)) - self.outfile.write(' _ExtendedGDBusSignalInfo *info;\n' - ' GVariantIter iter;\n' - ' GVariant *child;\n' - ' GValue *paramv;\n' - ' gsize num_params;\n' - ' gsize n;\n' - ' guint signal_id;\n'); + self.outfile.write( + "static void\n" + "%s_proxy_g_signal (GDBusProxy *proxy,\n" + " const gchar *sender_name G_GNUC_UNUSED,\n" + " const gchar *signal_name,\n" + " GVariant *parameters)\n" + "{\n" % (i.name_lower) + ) + self.outfile.write( + " _ExtendedGDBusSignalInfo *info;\n" + " GVariantIter iter;\n" + " GVariant *child;\n" + " GValue *paramv;\n" + " gsize num_params;\n" + " gsize n;\n" + " guint signal_id;\n" + ) # Note: info could be NULL if we are talking to a newer version of the interface - self.outfile.write(' info = (_ExtendedGDBusSignalInfo *) g_dbus_interface_info_lookup_signal ((GDBusInterfaceInfo *) &_%s_interface_info.parent_struct, signal_name);\n' - ' if (info == NULL)\n' - ' return;\n' - %(i.name_lower)) - self.outfile.write(' num_params = g_variant_n_children (parameters);\n' - ' paramv = g_new0 (GValue, num_params + 1);\n' - ' g_value_init (¶mv[0], %sTYPE_%s);\n' - ' g_value_set_object (¶mv[0], proxy);\n' - %(i.ns_upper, i.name_upper)) - self.outfile.write(' g_variant_iter_init (&iter, parameters);\n' - ' n = 1;\n' - ' while ((child = g_variant_iter_next_value (&iter)) != NULL)\n' - ' {\n' - ' _ExtendedGDBusArgInfo *arg_info = (_ExtendedGDBusArgInfo *) info->parent_struct.args[n - 1];\n' - ' if (arg_info->use_gvariant)\n' - ' {\n' - ' g_value_init (¶mv[n], G_TYPE_VARIANT);\n' - ' g_value_set_variant (¶mv[n], child);\n' - ' n++;\n' - ' }\n' - ' else\n' - ' g_dbus_gvariant_to_gvalue (child, ¶mv[n++]);\n' - ' g_variant_unref (child);\n' - ' }\n' - ) - self.outfile.write(' signal_id = g_signal_lookup (info->signal_name, %sTYPE_%s);\n' - %(i.ns_upper, i.name_upper)) - self.outfile.write(' g_signal_emitv (paramv, signal_id, 0, NULL);\n') - self.outfile.write(' for (n = 0; n < num_params + 1; n++)\n' - ' g_value_unset (¶mv[n]);\n' - ' g_free (paramv);\n') - self.outfile.write('}\n' - '\n') + self.outfile.write( + " info = (_ExtendedGDBusSignalInfo *) g_dbus_interface_info_lookup_signal ((GDBusInterfaceInfo *) &_%s_interface_info.parent_struct, signal_name);\n" + " if (info == NULL)\n" + " return;\n" % (i.name_lower) + ) + self.outfile.write( + " num_params = g_variant_n_children (parameters);\n" + " paramv = g_new0 (GValue, num_params + 1);\n" + " g_value_init (¶mv[0], %sTYPE_%s);\n" + " g_value_set_object (¶mv[0], proxy);\n" % (i.ns_upper, i.name_upper) + ) + self.outfile.write( + " g_variant_iter_init (&iter, parameters);\n" + " n = 1;\n" + " while ((child = g_variant_iter_next_value (&iter)) != NULL)\n" + " {\n" + " _ExtendedGDBusArgInfo *arg_info = (_ExtendedGDBusArgInfo *) info->parent_struct.args[n - 1];\n" + " if (arg_info->use_gvariant)\n" + " {\n" + " g_value_init (¶mv[n], G_TYPE_VARIANT);\n" + " g_value_set_variant (¶mv[n], child);\n" + " n++;\n" + " }\n" + " else\n" + " g_dbus_gvariant_to_gvalue (child, ¶mv[n++]);\n" + " g_variant_unref (child);\n" + " }\n" + ) + self.outfile.write( + " signal_id = g_signal_lookup (info->signal_name, %sTYPE_%s);\n" + % (i.ns_upper, i.name_upper) + ) + self.outfile.write(" g_signal_emitv (paramv, signal_id, 0, NULL);\n") + self.outfile.write( + " for (n = 0; n < num_params + 1; n++)\n" + " g_value_unset (¶mv[n]);\n" + " g_free (paramv);\n" + ) + self.outfile.write("}\n" "\n") # property changed - self.outfile.write('static void\n' - '%s_proxy_g_properties_changed (GDBusProxy *_proxy,\n' - ' GVariant *changed_properties,\n' - ' const gchar *const *invalidated_properties)\n' - '{\n'%(i.name_lower)) + self.outfile.write( + "static void\n" + "%s_proxy_g_properties_changed (GDBusProxy *_proxy,\n" + " GVariant *changed_properties,\n" + " const gchar *const *invalidated_properties)\n" + "{\n" % (i.name_lower) + ) # Note: info could be NULL if we are talking to a newer version of the interface - self.outfile.write(' %sProxy *proxy = %s%s_PROXY (_proxy);\n' - ' guint n;\n' - ' const gchar *key;\n' - ' GVariantIter *iter;\n' - ' _ExtendedGDBusPropertyInfo *info;\n' - ' g_variant_get (changed_properties, "a{sv}", &iter);\n' - ' while (g_variant_iter_next (iter, "{&sv}", &key, NULL))\n' - ' {\n' - ' info = (_ExtendedGDBusPropertyInfo *) g_dbus_interface_info_lookup_property ((GDBusInterfaceInfo *) &_%s_interface_info.parent_struct, key);\n' - ' g_datalist_remove_data (&proxy->priv->qdata, key);\n' - ' if (info != NULL)\n' - ' g_object_notify (G_OBJECT (proxy), info->hyphen_name);\n' - ' }\n' - ' g_variant_iter_free (iter);\n' - ' for (n = 0; invalidated_properties[n] != NULL; n++)\n' - ' {\n' - ' info = (_ExtendedGDBusPropertyInfo *) g_dbus_interface_info_lookup_property ((GDBusInterfaceInfo *) &_%s_interface_info.parent_struct, invalidated_properties[n]);\n' - ' g_datalist_remove_data (&proxy->priv->qdata, invalidated_properties[n]);\n' - ' if (info != NULL)\n' - ' g_object_notify (G_OBJECT (proxy), info->hyphen_name);\n' - ' }\n' - '}\n' - '\n' - %(i.camel_name, i.ns_upper, i.name_upper, - i.name_lower, i.name_lower)) + self.outfile.write( + " %sProxy *proxy = %s%s_PROXY (_proxy);\n" + " guint n;\n" + " const gchar *key;\n" + " GVariantIter *iter;\n" + " _ExtendedGDBusPropertyInfo *info;\n" + ' g_variant_get (changed_properties, "a{sv}", &iter);\n' + ' while (g_variant_iter_next (iter, "{&sv}", &key, NULL))\n' + " {\n" + " info = (_ExtendedGDBusPropertyInfo *) g_dbus_interface_info_lookup_property ((GDBusInterfaceInfo *) &_%s_interface_info.parent_struct, key);\n" + " g_datalist_remove_data (&proxy->priv->qdata, key);\n" + " if (info != NULL)\n" + " g_object_notify (G_OBJECT (proxy), info->hyphen_name);\n" + " }\n" + " g_variant_iter_free (iter);\n" + " for (n = 0; invalidated_properties[n] != NULL; n++)\n" + " {\n" + " info = (_ExtendedGDBusPropertyInfo *) g_dbus_interface_info_lookup_property ((GDBusInterfaceInfo *) &_%s_interface_info.parent_struct, invalidated_properties[n]);\n" + " g_datalist_remove_data (&proxy->priv->qdata, invalidated_properties[n]);\n" + " if (info != NULL)\n" + " g_object_notify (G_OBJECT (proxy), info->hyphen_name);\n" + " }\n" + "}\n" + "\n" % (i.camel_name, i.ns_upper, i.name_upper, i.name_lower, i.name_lower) + ) # property vfuncs for p in i.properties: - nul_value = '0' + nul_value = "0" if p.arg.free_func != None: - nul_value = 'NULL' - self.outfile.write('static %s\n' - '%s_proxy_get_%s (%s *object)\n' - '{\n' - ' %sProxy *proxy = %s%s_PROXY (object);\n' - ' GVariant *variant;\n' - ' %svalue = %s;\n'%(p.arg.ctype_in, i.name_lower, p.name_lower, i.camel_name, - i.camel_name, i.ns_upper, i.name_upper, - p.arg.ctype_in, nul_value)) + nul_value = "NULL" + self.outfile.write( + "static %s\n" + "%s_proxy_get_%s (%s *object)\n" + "{\n" + " %sProxy *proxy = %s%s_PROXY (object);\n" + " GVariant *variant;\n" + " %svalue = %s;\n" + % ( + p.arg.ctype_in, + i.name_lower, + p.name_lower, + i.camel_name, + i.camel_name, + i.ns_upper, + i.name_upper, + p.arg.ctype_in, + nul_value, + ) + ) # For some property types, we have to free the returned # value (or part of it, e.g. the container) because of how # GVariant works.. see https://bugzilla.gnome.org/show_bug.cgi?id=657100 # for details # - free_container = False; - if p.arg.gvariant_get == 'g_variant_get_strv' or p.arg.gvariant_get == 'g_variant_get_objv' or p.arg.gvariant_get == 'g_variant_get_bytestring_array': - free_container = True; + free_container = False + if ( + p.arg.gvariant_get == "g_variant_get_strv" + or p.arg.gvariant_get == "g_variant_get_objv" + or p.arg.gvariant_get == "g_variant_get_bytestring_array" + ): + free_container = True # If already using an old value for strv, objv, bytestring_array (see below), # then just return that... that way the result from multiple consecutive calls # to the getter are valid as long as they're freed # if free_container: - self.outfile.write(' value = g_datalist_get_data (&proxy->priv->qdata, \"%s\");\n' - ' if (value != NULL)\n' - ' return value;\n' - %(p.name)) - self.outfile.write(' variant = g_dbus_proxy_get_cached_property (G_DBUS_PROXY (proxy), \"%s\");\n'%(p.name)) - if p.arg.gtype == 'G_TYPE_VARIANT': - self.outfile.write(' value = variant;\n') - self.outfile.write(' if (variant != NULL)\n') - self.outfile.write(' g_variant_unref (variant);\n') + self.outfile.write( + ' value = g_datalist_get_data (&proxy->priv->qdata, "%s");\n' + " if (value != NULL)\n" + " return value;\n" % (p.name) + ) + self.outfile.write( + ' variant = g_dbus_proxy_get_cached_property (G_DBUS_PROXY (proxy), "%s");\n' + % (p.name) + ) + if p.arg.gtype == "G_TYPE_VARIANT": + self.outfile.write(" value = variant;\n") + self.outfile.write(" if (variant != NULL)\n") + self.outfile.write(" g_variant_unref (variant);\n") else: - self.outfile.write(' if (variant != NULL)\n' - ' {\n') - extra_len = '' - if p.arg.gvariant_get == 'g_variant_get_string' or p.arg.gvariant_get == 'g_variant_get_strv' or p.arg.gvariant_get == 'g_variant_get_objv' or p.arg.gvariant_get == 'g_variant_get_bytestring_array': - extra_len = ', NULL' - self.outfile.write(' value = %s (variant%s);\n'%(p.arg.gvariant_get, extra_len)) + self.outfile.write(" if (variant != NULL)\n" " {\n") + extra_len = "" + if ( + p.arg.gvariant_get == "g_variant_get_string" + or p.arg.gvariant_get == "g_variant_get_strv" + or p.arg.gvariant_get == "g_variant_get_objv" + or p.arg.gvariant_get == "g_variant_get_bytestring_array" + ): + extra_len = ", NULL" + self.outfile.write( + " value = %s (variant%s);\n" % (p.arg.gvariant_get, extra_len) + ) if free_container: - self.outfile.write(' g_datalist_set_data_full (&proxy->priv->qdata, \"%s\", (gpointer) value, g_free);\n' - %(p.name)) - self.outfile.write(' g_variant_unref (variant);\n') - self.outfile.write(' }\n') - self.outfile.write(' return value;\n') - self.outfile.write('}\n') - self.outfile.write('\n') + self.outfile.write( + ' g_datalist_set_data_full (&proxy->priv->qdata, "%s", (gpointer) value, g_free);\n' + % (p.name) + ) + self.outfile.write(" g_variant_unref (variant);\n") + self.outfile.write(" }\n") + self.outfile.write(" return value;\n") + self.outfile.write("}\n") + self.outfile.write("\n") # class boilerplate - self.outfile.write('static void\n' - '%s_proxy_init (%sProxy *proxy)\n' - '{\n' - '#if GLIB_VERSION_MAX_ALLOWED >= GLIB_VERSION_2_38\n' - ' proxy->priv = %s_proxy_get_instance_private (proxy);\n' - '#else\n' - ' proxy->priv = G_TYPE_INSTANCE_GET_PRIVATE (proxy, %sTYPE_%s_PROXY, %sProxyPrivate);\n' - '#endif\n\n' - ' g_dbus_proxy_set_interface_info (G_DBUS_PROXY (proxy), %s_interface_info ());\n' - '}\n' - '\n' - %(i.name_lower, i.camel_name, - i.name_lower, - i.ns_upper, i.name_upper, i.camel_name, - i.name_lower)) - self.outfile.write('static void\n' - '%s_proxy_class_init (%sProxyClass *klass)\n' - '{\n' - ' GObjectClass *gobject_class;\n' - ' GDBusProxyClass *proxy_class;\n' - '\n' - ' gobject_class = G_OBJECT_CLASS (klass);\n' - ' gobject_class->finalize = %s_proxy_finalize;\n' - ' gobject_class->get_property = %s_proxy_get_property;\n' - ' gobject_class->set_property = %s_proxy_set_property;\n' - '\n' - ' proxy_class = G_DBUS_PROXY_CLASS (klass);\n' - ' proxy_class->g_signal = %s_proxy_g_signal;\n' - ' proxy_class->g_properties_changed = %s_proxy_g_properties_changed;\n' - '\n'%(i.name_lower, i.camel_name, - i.name_lower, i.name_lower, i.name_lower, i.name_lower, i.name_lower)) + self.outfile.write( + "static void\n" + "%s_proxy_init (%sProxy *proxy)\n" + "{\n" + "#if GLIB_VERSION_MAX_ALLOWED >= GLIB_VERSION_2_38\n" + " proxy->priv = %s_proxy_get_instance_private (proxy);\n" + "#else\n" + " proxy->priv = G_TYPE_INSTANCE_GET_PRIVATE (proxy, %sTYPE_%s_PROXY, %sProxyPrivate);\n" + "#endif\n\n" + " g_dbus_proxy_set_interface_info (G_DBUS_PROXY (proxy), %s_interface_info ());\n" + "}\n" + "\n" + % ( + i.name_lower, + i.camel_name, + i.name_lower, + i.ns_upper, + i.name_upper, + i.camel_name, + i.name_lower, + ) + ) + self.outfile.write( + "static void\n" + "%s_proxy_class_init (%sProxyClass *klass)\n" + "{\n" + " GObjectClass *gobject_class;\n" + " GDBusProxyClass *proxy_class;\n" + "\n" + " gobject_class = G_OBJECT_CLASS (klass);\n" + " gobject_class->finalize = %s_proxy_finalize;\n" + " gobject_class->get_property = %s_proxy_get_property;\n" + " gobject_class->set_property = %s_proxy_set_property;\n" + "\n" + " proxy_class = G_DBUS_PROXY_CLASS (klass);\n" + " proxy_class->g_signal = %s_proxy_g_signal;\n" + " proxy_class->g_properties_changed = %s_proxy_g_properties_changed;\n" + "\n" + % ( + i.name_lower, + i.camel_name, + i.name_lower, + i.name_lower, + i.name_lower, + i.name_lower, + i.name_lower, + ) + ) if len(i.properties) > 0: - self.outfile.write(' %s_override_properties (gobject_class, 1);\n\n'%(i.name_lower)) - self.outfile.write('#if GLIB_VERSION_MAX_ALLOWED < GLIB_VERSION_2_38\n' - ' g_type_class_add_private (klass, sizeof (%sProxyPrivate));\n' - '#endif\n'%(i.camel_name)) - self.outfile.write('}\n' - '\n') - - self.outfile.write('static void\n' - '%s_proxy_iface_init (%sIface *iface)\n' - '{\n'%(i.name_lower, i.camel_name)) + self.outfile.write( + " %s_override_properties (gobject_class, 1);\n\n" % (i.name_lower) + ) + self.outfile.write( + "#if GLIB_VERSION_MAX_ALLOWED < GLIB_VERSION_2_38\n" + " g_type_class_add_private (klass, sizeof (%sProxyPrivate));\n" + "#endif\n" % (i.camel_name) + ) + self.outfile.write("}\n" "\n") + + self.outfile.write( + "static void\n" + "%s_proxy_iface_init (%sIface *iface)\n" + "{\n" % (i.name_lower, i.camel_name) + ) for p in i.properties: - self.outfile.write(' iface->get_%s = %s_proxy_get_%s;\n'%(p.name_lower, i.name_lower, p.name_lower)) - self.outfile.write('}\n' - '\n') + self.outfile.write( + " iface->get_%s = %s_proxy_get_%s;\n" + % (p.name_lower, i.name_lower, p.name_lower) + ) + self.outfile.write("}\n" "\n") # constructors - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %s_proxy_new:\n' - ' * @connection: A #GDBusConnection.\n' - ' * @flags: Flags from the #GDBusProxyFlags enumeration.\n' - ' * @name: (nullable): A bus name (well-known or unique) or %%NULL if @connection is not a message bus connection.\n' - ' * @object_path: An object path.\n' - ' * @cancellable: (nullable): A #GCancellable or %%NULL.\n' - ' * @callback: A #GAsyncReadyCallback to call when the request is satisfied.\n' - ' * @user_data: User data to pass to @callback.\n' - ' *\n' - ' * Asynchronously creates a proxy for the D-Bus interface #%s. See g_dbus_proxy_new() for more details.\n' - ' *\n' - ' * When the operation is finished, @callback will be invoked in the thread-default main loop of the thread you are calling this method from (see g_main_context_push_thread_default()).\n' - ' * You can then call %s_proxy_new_finish() to get the result of the operation.\n' - ' *\n' - ' * See %s_proxy_new_sync() for the synchronous, blocking version of this constructor.\n' - %(i.name_lower, i.name, i.name_lower, i.name_lower), False)) + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %s_proxy_new:\n" + " * @connection: A #GDBusConnection.\n" + " * @flags: Flags from the #GDBusProxyFlags enumeration.\n" + " * @name: (nullable): A bus name (well-known or unique) or %%NULL if @connection is not a message bus connection.\n" + " * @object_path: An object path.\n" + " * @cancellable: (nullable): A #GCancellable or %%NULL.\n" + " * @callback: A #GAsyncReadyCallback to call when the request is satisfied.\n" + " * @user_data: User data to pass to @callback.\n" + " *\n" + " * Asynchronously creates a proxy for the D-Bus interface #%s. See g_dbus_proxy_new() for more details.\n" + " *\n" + " * When the operation is finished, @callback will be invoked in the thread-default main loop of the thread you are calling this method from (see g_main_context_push_thread_default()).\n" + " * You can then call %s_proxy_new_finish() to get the result of the operation.\n" + " *\n" + " * See %s_proxy_new_sync() for the synchronous, blocking version of this constructor.\n" + % (i.name_lower, i.name, i.name_lower, i.name_lower), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('void\n' - '%s_proxy_new (\n' - ' GDBusConnection *connection,\n' - ' GDBusProxyFlags flags,\n' - ' const gchar *name,\n' - ' const gchar *object_path,\n' - ' GCancellable *cancellable,\n' - ' GAsyncReadyCallback callback,\n' - ' gpointer user_data)\n' - '{\n' - ' g_async_initable_new_async (%sTYPE_%s_PROXY, G_PRIORITY_DEFAULT, cancellable, callback, user_data, "g-flags", flags, "g-name", name, "g-connection", connection, "g-object-path", object_path, "g-interface-name", "%s", NULL);\n' - '}\n' - '\n' - %(i.name_lower, i.ns_upper, i.name_upper, i.name)) - self.outfile.write('/**\n' - ' * %s_proxy_new_finish:\n' - ' * @res: The #GAsyncResult obtained from the #GAsyncReadyCallback passed to %s_proxy_new().\n' - ' * @error: Return location for error or %%NULL\n' - ' *\n' - ' * Finishes an operation started with %s_proxy_new().\n' - ' *\n' - ' * Returns: (transfer full) (type %sProxy): The constructed proxy object or %%NULL if @error is set.\n' - %(i.name_lower, i.name_lower, i.name_lower, i.camel_name)) + self.outfile.write( + "void\n" + "%s_proxy_new (\n" + " GDBusConnection *connection,\n" + " GDBusProxyFlags flags,\n" + " const gchar *name,\n" + " const gchar *object_path,\n" + " GCancellable *cancellable,\n" + " GAsyncReadyCallback callback,\n" + " gpointer user_data)\n" + "{\n" + ' g_async_initable_new_async (%sTYPE_%s_PROXY, G_PRIORITY_DEFAULT, cancellable, callback, user_data, "g-flags", flags, "g-name", name, "g-connection", connection, "g-object-path", object_path, "g-interface-name", "%s", NULL);\n' + "}\n" + "\n" % (i.name_lower, i.ns_upper, i.name_upper, i.name) + ) + self.outfile.write( + "/**\n" + " * %s_proxy_new_finish:\n" + " * @res: The #GAsyncResult obtained from the #GAsyncReadyCallback passed to %s_proxy_new().\n" + " * @error: Return location for error or %%NULL\n" + " *\n" + " * Finishes an operation started with %s_proxy_new().\n" + " *\n" + " * Returns: (transfer full) (type %sProxy): The constructed proxy object or %%NULL if @error is set.\n" + % (i.name_lower, i.name_lower, i.name_lower, i.camel_name) + ) self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('%s *\n' - '%s_proxy_new_finish (\n' - ' GAsyncResult *res,\n' - ' GError **error)\n' - '{\n' - ' GObject *ret;\n' - ' GObject *source_object;\n' - ' source_object = g_async_result_get_source_object (res);\n' - ' ret = g_async_initable_new_finish (G_ASYNC_INITABLE (source_object), res, error);\n' - ' g_object_unref (source_object);\n' - ' if (ret != NULL)\n' - ' return %s%s (ret);\n' - ' else\n' - ' return NULL;\n' - '}\n' - '\n' - %(i.camel_name, i.name_lower, i.ns_upper, i.name_upper)) - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %s_proxy_new_sync:\n' - ' * @connection: A #GDBusConnection.\n' - ' * @flags: Flags from the #GDBusProxyFlags enumeration.\n' - ' * @name: (nullable): A bus name (well-known or unique) or %%NULL if @connection is not a message bus connection.\n' - ' * @object_path: An object path.\n' - ' * @cancellable: (nullable): A #GCancellable or %%NULL.\n' - ' * @error: Return location for error or %%NULL\n' - ' *\n' - ' * Synchronously creates a proxy for the D-Bus interface #%s. See g_dbus_proxy_new_sync() for more details.\n' - ' *\n' - ' * The calling thread is blocked until a reply is received.\n' - ' *\n' - ' * See %s_proxy_new() for the asynchronous version of this constructor.\n' - ' *\n' - ' * Returns: (transfer full) (type %sProxy): The constructed proxy object or %%NULL if @error is set.\n' - %(i.name_lower, i.name, i.name_lower, i.camel_name), False)) + self.outfile.write( + "%s *\n" + "%s_proxy_new_finish (\n" + " GAsyncResult *res,\n" + " GError **error)\n" + "{\n" + " GObject *ret;\n" + " GObject *source_object;\n" + " source_object = g_async_result_get_source_object (res);\n" + " ret = g_async_initable_new_finish (G_ASYNC_INITABLE (source_object), res, error);\n" + " g_object_unref (source_object);\n" + " if (ret != NULL)\n" + " return %s%s (ret);\n" + " else\n" + " return NULL;\n" + "}\n" + "\n" % (i.camel_name, i.name_lower, i.ns_upper, i.name_upper) + ) + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %s_proxy_new_sync:\n" + " * @connection: A #GDBusConnection.\n" + " * @flags: Flags from the #GDBusProxyFlags enumeration.\n" + " * @name: (nullable): A bus name (well-known or unique) or %%NULL if @connection is not a message bus connection.\n" + " * @object_path: An object path.\n" + " * @cancellable: (nullable): A #GCancellable or %%NULL.\n" + " * @error: Return location for error or %%NULL\n" + " *\n" + " * Synchronously creates a proxy for the D-Bus interface #%s. See g_dbus_proxy_new_sync() for more details.\n" + " *\n" + " * The calling thread is blocked until a reply is received.\n" + " *\n" + " * See %s_proxy_new() for the asynchronous version of this constructor.\n" + " *\n" + " * Returns: (transfer full) (type %sProxy): The constructed proxy object or %%NULL if @error is set.\n" + % (i.name_lower, i.name, i.name_lower, i.camel_name), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('%s *\n' - '%s_proxy_new_sync (\n' - ' GDBusConnection *connection,\n' - ' GDBusProxyFlags flags,\n' - ' const gchar *name,\n' - ' const gchar *object_path,\n' - ' GCancellable *cancellable,\n' - ' GError **error)\n' - '{\n' - ' GInitable *ret;\n' - ' ret = g_initable_new (%sTYPE_%s_PROXY, cancellable, error, "g-flags", flags, "g-name", name, "g-connection", connection, "g-object-path", object_path, "g-interface-name", "%s", NULL);\n' - ' if (ret != NULL)\n' - ' return %s%s (ret);\n' - ' else\n' - ' return NULL;\n' - '}\n' - '\n' - %(i.camel_name, i.name_lower, i.ns_upper, i.name_upper, i.name, i.ns_upper, i.name_upper)) - self.outfile.write('\n') - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %s_proxy_new_for_bus:\n' - ' * @bus_type: A #GBusType.\n' - ' * @flags: Flags from the #GDBusProxyFlags enumeration.\n' - ' * @name: A bus name (well-known or unique).\n' - ' * @object_path: An object path.\n' - ' * @cancellable: (nullable): A #GCancellable or %%NULL.\n' - ' * @callback: A #GAsyncReadyCallback to call when the request is satisfied.\n' - ' * @user_data: User data to pass to @callback.\n' - ' *\n' - ' * Like %s_proxy_new() but takes a #GBusType instead of a #GDBusConnection.\n' - ' *\n' - ' * When the operation is finished, @callback will be invoked in the thread-default main loop of the thread you are calling this method from (see g_main_context_push_thread_default()).\n' - ' * You can then call %s_proxy_new_for_bus_finish() to get the result of the operation.\n' - ' *\n' - ' * See %s_proxy_new_for_bus_sync() for the synchronous, blocking version of this constructor.\n' - %(i.name_lower, i.name_lower, i.name_lower, i.name_lower), False)) + self.outfile.write( + "%s *\n" + "%s_proxy_new_sync (\n" + " GDBusConnection *connection,\n" + " GDBusProxyFlags flags,\n" + " const gchar *name,\n" + " const gchar *object_path,\n" + " GCancellable *cancellable,\n" + " GError **error)\n" + "{\n" + " GInitable *ret;\n" + ' ret = g_initable_new (%sTYPE_%s_PROXY, cancellable, error, "g-flags", flags, "g-name", name, "g-connection", connection, "g-object-path", object_path, "g-interface-name", "%s", NULL);\n' + " if (ret != NULL)\n" + " return %s%s (ret);\n" + " else\n" + " return NULL;\n" + "}\n" + "\n" + % ( + i.camel_name, + i.name_lower, + i.ns_upper, + i.name_upper, + i.name, + i.ns_upper, + i.name_upper, + ) + ) + self.outfile.write("\n") + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %s_proxy_new_for_bus:\n" + " * @bus_type: A #GBusType.\n" + " * @flags: Flags from the #GDBusProxyFlags enumeration.\n" + " * @name: A bus name (well-known or unique).\n" + " * @object_path: An object path.\n" + " * @cancellable: (nullable): A #GCancellable or %%NULL.\n" + " * @callback: A #GAsyncReadyCallback to call when the request is satisfied.\n" + " * @user_data: User data to pass to @callback.\n" + " *\n" + " * Like %s_proxy_new() but takes a #GBusType instead of a #GDBusConnection.\n" + " *\n" + " * When the operation is finished, @callback will be invoked in the thread-default main loop of the thread you are calling this method from (see g_main_context_push_thread_default()).\n" + " * You can then call %s_proxy_new_for_bus_finish() to get the result of the operation.\n" + " *\n" + " * See %s_proxy_new_for_bus_sync() for the synchronous, blocking version of this constructor.\n" + % (i.name_lower, i.name_lower, i.name_lower, i.name_lower), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('void\n' - '%s_proxy_new_for_bus (\n' - ' GBusType bus_type,\n' - ' GDBusProxyFlags flags,\n' - ' const gchar *name,\n' - ' const gchar *object_path,\n' - ' GCancellable *cancellable,\n' - ' GAsyncReadyCallback callback,\n' - ' gpointer user_data)\n' - '{\n' - ' g_async_initable_new_async (%sTYPE_%s_PROXY, G_PRIORITY_DEFAULT, cancellable, callback, user_data, "g-flags", flags, "g-name", name, "g-bus-type", bus_type, "g-object-path", object_path, "g-interface-name", "%s", NULL);\n' - '}\n' - '\n' - %(i.name_lower, i.ns_upper, i.name_upper, i.name)) - self.outfile.write('/**\n' - ' * %s_proxy_new_for_bus_finish:\n' - ' * @res: The #GAsyncResult obtained from the #GAsyncReadyCallback passed to %s_proxy_new_for_bus().\n' - ' * @error: Return location for error or %%NULL\n' - ' *\n' - ' * Finishes an operation started with %s_proxy_new_for_bus().\n' - ' *\n' - ' * Returns: (transfer full) (type %sProxy): The constructed proxy object or %%NULL if @error is set.\n' - %(i.name_lower, i.name_lower, i.name_lower, i.camel_name)) + self.outfile.write( + "void\n" + "%s_proxy_new_for_bus (\n" + " GBusType bus_type,\n" + " GDBusProxyFlags flags,\n" + " const gchar *name,\n" + " const gchar *object_path,\n" + " GCancellable *cancellable,\n" + " GAsyncReadyCallback callback,\n" + " gpointer user_data)\n" + "{\n" + ' g_async_initable_new_async (%sTYPE_%s_PROXY, G_PRIORITY_DEFAULT, cancellable, callback, user_data, "g-flags", flags, "g-name", name, "g-bus-type", bus_type, "g-object-path", object_path, "g-interface-name", "%s", NULL);\n' + "}\n" + "\n" % (i.name_lower, i.ns_upper, i.name_upper, i.name) + ) + self.outfile.write( + "/**\n" + " * %s_proxy_new_for_bus_finish:\n" + " * @res: The #GAsyncResult obtained from the #GAsyncReadyCallback passed to %s_proxy_new_for_bus().\n" + " * @error: Return location for error or %%NULL\n" + " *\n" + " * Finishes an operation started with %s_proxy_new_for_bus().\n" + " *\n" + " * Returns: (transfer full) (type %sProxy): The constructed proxy object or %%NULL if @error is set.\n" + % (i.name_lower, i.name_lower, i.name_lower, i.camel_name) + ) self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('%s *\n' - '%s_proxy_new_for_bus_finish (\n' - ' GAsyncResult *res,\n' - ' GError **error)\n' - '{\n' - ' GObject *ret;\n' - ' GObject *source_object;\n' - ' source_object = g_async_result_get_source_object (res);\n' - ' ret = g_async_initable_new_finish (G_ASYNC_INITABLE (source_object), res, error);\n' - ' g_object_unref (source_object);\n' - ' if (ret != NULL)\n' - ' return %s%s (ret);\n' - ' else\n' - ' return NULL;\n' - '}\n' - '\n' - %(i.camel_name, i.name_lower, i.ns_upper, i.name_upper)) - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %s_proxy_new_for_bus_sync:\n' - ' * @bus_type: A #GBusType.\n' - ' * @flags: Flags from the #GDBusProxyFlags enumeration.\n' - ' * @name: A bus name (well-known or unique).\n' - ' * @object_path: An object path.\n' - ' * @cancellable: (nullable): A #GCancellable or %%NULL.\n' - ' * @error: Return location for error or %%NULL\n' - ' *\n' - ' * Like %s_proxy_new_sync() but takes a #GBusType instead of a #GDBusConnection.\n' - ' *\n' - ' * The calling thread is blocked until a reply is received.\n' - ' *\n' - ' * See %s_proxy_new_for_bus() for the asynchronous version of this constructor.\n' - ' *\n' - ' * Returns: (transfer full) (type %sProxy): The constructed proxy object or %%NULL if @error is set.\n' - %(i.name_lower, i.name_lower, i.name_lower, i.camel_name), False)) + self.outfile.write( + "%s *\n" + "%s_proxy_new_for_bus_finish (\n" + " GAsyncResult *res,\n" + " GError **error)\n" + "{\n" + " GObject *ret;\n" + " GObject *source_object;\n" + " source_object = g_async_result_get_source_object (res);\n" + " ret = g_async_initable_new_finish (G_ASYNC_INITABLE (source_object), res, error);\n" + " g_object_unref (source_object);\n" + " if (ret != NULL)\n" + " return %s%s (ret);\n" + " else\n" + " return NULL;\n" + "}\n" + "\n" % (i.camel_name, i.name_lower, i.ns_upper, i.name_upper) + ) + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %s_proxy_new_for_bus_sync:\n" + " * @bus_type: A #GBusType.\n" + " * @flags: Flags from the #GDBusProxyFlags enumeration.\n" + " * @name: A bus name (well-known or unique).\n" + " * @object_path: An object path.\n" + " * @cancellable: (nullable): A #GCancellable or %%NULL.\n" + " * @error: Return location for error or %%NULL\n" + " *\n" + " * Like %s_proxy_new_sync() but takes a #GBusType instead of a #GDBusConnection.\n" + " *\n" + " * The calling thread is blocked until a reply is received.\n" + " *\n" + " * See %s_proxy_new_for_bus() for the asynchronous version of this constructor.\n" + " *\n" + " * Returns: (transfer full) (type %sProxy): The constructed proxy object or %%NULL if @error is set.\n" + % (i.name_lower, i.name_lower, i.name_lower, i.camel_name), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('%s *\n' - '%s_proxy_new_for_bus_sync (\n' - ' GBusType bus_type,\n' - ' GDBusProxyFlags flags,\n' - ' const gchar *name,\n' - ' const gchar *object_path,\n' - ' GCancellable *cancellable,\n' - ' GError **error)\n' - '{\n' - ' GInitable *ret;\n' - ' ret = g_initable_new (%sTYPE_%s_PROXY, cancellable, error, "g-flags", flags, "g-name", name, "g-bus-type", bus_type, "g-object-path", object_path, "g-interface-name", "%s", NULL);\n' - ' if (ret != NULL)\n' - ' return %s%s (ret);\n' - ' else\n' - ' return NULL;\n' - '}\n' - '\n' - %(i.camel_name, i.name_lower, i.ns_upper, i.name_upper, i.name, i.ns_upper, i.name_upper)) - self.outfile.write('\n') + self.outfile.write( + "%s *\n" + "%s_proxy_new_for_bus_sync (\n" + " GBusType bus_type,\n" + " GDBusProxyFlags flags,\n" + " const gchar *name,\n" + " const gchar *object_path,\n" + " GCancellable *cancellable,\n" + " GError **error)\n" + "{\n" + " GInitable *ret;\n" + ' ret = g_initable_new (%sTYPE_%s_PROXY, cancellable, error, "g-flags", flags, "g-name", name, "g-bus-type", bus_type, "g-object-path", object_path, "g-interface-name", "%s", NULL);\n' + " if (ret != NULL)\n" + " return %s%s (ret);\n" + " else\n" + " return NULL;\n" + "}\n" + "\n" + % ( + i.camel_name, + i.name_lower, + i.ns_upper, + i.name_upper, + i.name, + i.ns_upper, + i.name_upper, + ) + ) + self.outfile.write("\n") # --------------------------------------------------------------------------------------------------- def generate_skeleton(self, i): # class boilerplate - self.outfile.write('/* ------------------------------------------------------------------------ */\n' - '\n') - - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sSkeleton:\n' - ' *\n' - ' * The #%sSkeleton structure contains only private data and should only be accessed using the provided API.\n' - %(i.camel_name, i.camel_name), False)) + self.outfile.write( + "/* ------------------------------------------------------------------------ */\n" + "\n" + ) + + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sSkeleton:\n" + " *\n" + " * The #%sSkeleton structure contains only private data and should only be accessed using the provided API.\n" + % (i.camel_name, i.camel_name), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('\n') - - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sSkeletonClass:\n' - ' * @parent_class: The parent class.\n' - ' *\n' - ' * Class structure for #%sSkeleton.\n' - %(i.camel_name, i.camel_name), False)) + self.outfile.write("\n") + + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sSkeletonClass:\n" + " * @parent_class: The parent class.\n" + " *\n" + " * Class structure for #%sSkeleton.\n" % (i.camel_name, i.camel_name), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('\n') - - self.outfile.write('struct _%sSkeletonPrivate\n' - '{\n' - ' GValue *properties;\n' - ' GList *changed_properties;\n' - ' GSource *changed_properties_idle_source;\n' - ' GMainContext *context;\n' - ' GMutex lock;\n' - '};\n' - '\n'%i.camel_name) - - self.outfile.write('static void\n' - '_%s_skeleton_handle_method_call (\n' - ' GDBusConnection *connection G_GNUC_UNUSED,\n' - ' const gchar *sender G_GNUC_UNUSED,\n' - ' const gchar *object_path G_GNUC_UNUSED,\n' - ' const gchar *interface_name,\n' - ' const gchar *method_name,\n' - ' GVariant *parameters,\n' - ' GDBusMethodInvocation *invocation,\n' - ' gpointer user_data)\n' - '{\n' - ' %sSkeleton *skeleton = %s%s_SKELETON (user_data);\n' - ' _ExtendedGDBusMethodInfo *info;\n' - ' GVariantIter iter;\n' - ' GVariant *child;\n' - ' GValue *paramv;\n' - ' gsize num_params;\n' - ' guint num_extra;\n' - ' gsize n;\n' - ' guint signal_id;\n' - ' GValue return_value = G_VALUE_INIT;\n' - %(i.name_lower, i.camel_name, i.ns_upper, i.name_upper)) - self.outfile.write(' info = (_ExtendedGDBusMethodInfo *) g_dbus_method_invocation_get_method_info (invocation);\n' - ' g_assert (info != NULL);\n' - %()) - self.outfile.write(' num_params = g_variant_n_children (parameters);\n' - ' num_extra = info->pass_fdlist ? 3 : 2;' - ' paramv = g_new0 (GValue, num_params + num_extra);\n' - ' n = 0;\n' - ' g_value_init (¶mv[n], %sTYPE_%s);\n' - ' g_value_set_object (¶mv[n++], skeleton);\n' - ' g_value_init (¶mv[n], G_TYPE_DBUS_METHOD_INVOCATION);\n' - ' g_value_set_object (¶mv[n++], invocation);\n' - ' if (info->pass_fdlist)\n' - ' {\n' - '#ifdef G_OS_UNIX\n' - ' g_value_init (¶mv[n], G_TYPE_UNIX_FD_LIST);\n' - ' g_value_set_object (¶mv[n++], g_dbus_message_get_unix_fd_list (g_dbus_method_invocation_get_message (invocation)));\n' - '#else\n' - ' g_assert_not_reached ();\n' - '#endif\n' - ' }\n' - %(i.ns_upper, i.name_upper)) - self.outfile.write(' g_variant_iter_init (&iter, parameters);\n' - ' while ((child = g_variant_iter_next_value (&iter)) != NULL)\n' - ' {\n' - ' _ExtendedGDBusArgInfo *arg_info = (_ExtendedGDBusArgInfo *) info->parent_struct.in_args[n - num_extra];\n' - ' if (arg_info->use_gvariant)\n' - ' {\n' - ' g_value_init (¶mv[n], G_TYPE_VARIANT);\n' - ' g_value_set_variant (¶mv[n], child);\n' - ' n++;\n' - ' }\n' - ' else\n' - ' g_dbus_gvariant_to_gvalue (child, ¶mv[n++]);\n' - ' g_variant_unref (child);\n' - ' }\n') - self.outfile.write(' signal_id = g_signal_lookup (info->signal_name, %sTYPE_%s);\n' - %(i.ns_upper, i.name_upper)) - self.outfile.write(' g_value_init (&return_value, G_TYPE_BOOLEAN);\n' - ' g_signal_emitv (paramv, signal_id, 0, &return_value);\n' - ' if (!g_value_get_boolean (&return_value))\n' - ' g_dbus_method_invocation_return_error (invocation, G_DBUS_ERROR, G_DBUS_ERROR_UNKNOWN_METHOD, "Method %s is not implemented on interface %s", method_name, interface_name);\n' - ' g_value_unset (&return_value);\n') - self.outfile.write(' for (n = 0; n < num_params + num_extra; n++)\n' - ' g_value_unset (¶mv[n]);\n' - ' g_free (paramv);\n') - self.outfile.write('}\n' - '\n') - - self.outfile.write('static GVariant *\n' - '_%s_skeleton_handle_get_property (\n' - ' GDBusConnection *connection G_GNUC_UNUSED,\n' - ' const gchar *sender G_GNUC_UNUSED,\n' - ' const gchar *object_path G_GNUC_UNUSED,\n' - ' const gchar *interface_name G_GNUC_UNUSED,\n' - ' const gchar *property_name,\n' - ' GError **error,\n' - ' gpointer user_data)\n' - '{\n' - ' %sSkeleton *skeleton = %s%s_SKELETON (user_data);\n' - ' GValue value = G_VALUE_INIT;\n' - ' GParamSpec *pspec;\n' - ' _ExtendedGDBusPropertyInfo *info;\n' - ' GVariant *ret;\n' - %(i.name_lower, i.camel_name, i.ns_upper, i.name_upper)) - self.outfile.write(' ret = NULL;\n' - ' info = (_ExtendedGDBusPropertyInfo *) g_dbus_interface_info_lookup_property ((GDBusInterfaceInfo *) &_%s_interface_info.parent_struct, property_name);\n' - ' g_assert (info != NULL);\n' - ' pspec = g_object_class_find_property (G_OBJECT_GET_CLASS (skeleton), info->hyphen_name);\n' - ' if (pspec == NULL)\n' - ' {\n' - ' g_set_error (error, G_DBUS_ERROR, G_DBUS_ERROR_INVALID_ARGS, "No property with name %%s", property_name);\n' - ' }\n' - ' else\n' - ' {\n' - ' g_value_init (&value, pspec->value_type);\n' - ' g_object_get_property (G_OBJECT (skeleton), info->hyphen_name, &value);\n' - ' ret = g_dbus_gvalue_to_gvariant (&value, G_VARIANT_TYPE (info->parent_struct.signature));\n' - ' g_value_unset (&value);\n' - ' }\n' - ' return ret;\n' - '}\n' - '\n' - %(i.name_lower)) - - self.outfile.write('static gboolean\n' - '_%s_skeleton_handle_set_property (\n' - ' GDBusConnection *connection G_GNUC_UNUSED,\n' - ' const gchar *sender G_GNUC_UNUSED,\n' - ' const gchar *object_path G_GNUC_UNUSED,\n' - ' const gchar *interface_name G_GNUC_UNUSED,\n' - ' const gchar *property_name,\n' - ' GVariant *variant,\n' - ' GError **error,\n' - ' gpointer user_data)\n' - '{\n' - ' %sSkeleton *skeleton = %s%s_SKELETON (user_data);\n' - ' GValue value = G_VALUE_INIT;\n' - ' GParamSpec *pspec;\n' - ' _ExtendedGDBusPropertyInfo *info;\n' - ' gboolean ret;\n' - %(i.name_lower, i.camel_name, i.ns_upper, i.name_upper)) - self.outfile.write(' ret = FALSE;\n' - ' info = (_ExtendedGDBusPropertyInfo *) g_dbus_interface_info_lookup_property ((GDBusInterfaceInfo *) &_%s_interface_info.parent_struct, property_name);\n' - ' g_assert (info != NULL);\n' - ' pspec = g_object_class_find_property (G_OBJECT_GET_CLASS (skeleton), info->hyphen_name);\n' - ' if (pspec == NULL)\n' - ' {\n' - ' g_set_error (error, G_DBUS_ERROR, G_DBUS_ERROR_INVALID_ARGS, "No property with name %%s", property_name);\n' - ' }\n' - ' else\n' - ' {\n' - ' if (info->use_gvariant)\n' - ' g_value_set_variant (&value, variant);\n' - ' else\n' - ' g_dbus_gvariant_to_gvalue (variant, &value);\n' - ' g_object_set_property (G_OBJECT (skeleton), info->hyphen_name, &value);\n' - ' g_value_unset (&value);\n' - ' ret = TRUE;\n' - ' }\n' - ' return ret;\n' - '}\n' - '\n' - %(i.name_lower)) - - - self.outfile.write('static const GDBusInterfaceVTable _%s_skeleton_vtable =\n' - '{\n' - ' _%s_skeleton_handle_method_call,\n' - ' _%s_skeleton_handle_get_property,\n' - ' _%s_skeleton_handle_set_property,\n' - ' {NULL}\n' - '};\n' - '\n'%(i.name_lower, i.name_lower, i.name_lower, i.name_lower)) - - self.outfile.write('static GDBusInterfaceInfo *\n' - '%s_skeleton_dbus_interface_get_info (GDBusInterfaceSkeleton *skeleton G_GNUC_UNUSED)\n' - '{\n' - ' return %s_interface_info ();\n' - %(i.name_lower, i.name_lower)) - self.outfile.write('}\n' - '\n') - - self.outfile.write('static GDBusInterfaceVTable *\n' - '%s_skeleton_dbus_interface_get_vtable (GDBusInterfaceSkeleton *skeleton G_GNUC_UNUSED)\n' - '{\n' - ' return (GDBusInterfaceVTable *) &_%s_skeleton_vtable;\n' - %(i.name_lower, i.name_lower)) - self.outfile.write('}\n' - '\n') - - self.outfile.write('static GVariant *\n' - '%s_skeleton_dbus_interface_get_properties (GDBusInterfaceSkeleton *_skeleton)\n' - '{\n' - ' %sSkeleton *skeleton = %s%s_SKELETON (_skeleton);\n' - %(i.name_lower, i.camel_name, i.ns_upper, i.name_upper)) - self.outfile.write('\n' - ' GVariantBuilder builder;\n' - ' guint n;\n' - ' g_variant_builder_init (&builder, G_VARIANT_TYPE ("a{sv}"));\n' - ' if (_%s_interface_info.parent_struct.properties == NULL)\n' - ' goto out;\n' - ' for (n = 0; _%s_interface_info.parent_struct.properties[n] != NULL; n++)\n' - ' {\n' - ' GDBusPropertyInfo *info = _%s_interface_info.parent_struct.properties[n];\n' - ' if (info->flags & G_DBUS_PROPERTY_INFO_FLAGS_READABLE)\n' - ' {\n' - ' GVariant *value;\n' - ' value = _%s_skeleton_handle_get_property (g_dbus_interface_skeleton_get_connection (G_DBUS_INTERFACE_SKELETON (skeleton)), NULL, g_dbus_interface_skeleton_get_object_path (G_DBUS_INTERFACE_SKELETON (skeleton)), "%s", info->name, NULL, skeleton);\n' - ' if (value != NULL)\n' - ' {\n' - ' g_variant_take_ref (value);\n' - ' g_variant_builder_add (&builder, "{sv}", info->name, value);\n' - ' g_variant_unref (value);\n' - ' }\n' - ' }\n' - ' }\n' - 'out:\n' - ' return g_variant_builder_end (&builder);\n' - '}\n' - '\n' - %(i.name_lower, i.name_lower, i.name_lower, i.name_lower, i.name)) + self.outfile.write("\n") + + self.outfile.write( + "struct _%sSkeletonPrivate\n" + "{\n" + " GValue *properties;\n" + " GList *changed_properties;\n" + " GSource *changed_properties_idle_source;\n" + " GMainContext *context;\n" + " GMutex lock;\n" + "};\n" + "\n" % i.camel_name + ) + + self.outfile.write( + "static void\n" + "_%s_skeleton_handle_method_call (\n" + " GDBusConnection *connection G_GNUC_UNUSED,\n" + " const gchar *sender G_GNUC_UNUSED,\n" + " const gchar *object_path G_GNUC_UNUSED,\n" + " const gchar *interface_name,\n" + " const gchar *method_name,\n" + " GVariant *parameters,\n" + " GDBusMethodInvocation *invocation,\n" + " gpointer user_data)\n" + "{\n" + " %sSkeleton *skeleton = %s%s_SKELETON (user_data);\n" + " _ExtendedGDBusMethodInfo *info;\n" + " GVariantIter iter;\n" + " GVariant *child;\n" + " GValue *paramv;\n" + " gsize num_params;\n" + " guint num_extra;\n" + " gsize n;\n" + " guint signal_id;\n" + " GValue return_value = G_VALUE_INIT;\n" + % (i.name_lower, i.camel_name, i.ns_upper, i.name_upper) + ) + self.outfile.write( + " info = (_ExtendedGDBusMethodInfo *) g_dbus_method_invocation_get_method_info (invocation);\n" + " g_assert (info != NULL);\n" % () + ) + self.outfile.write( + " num_params = g_variant_n_children (parameters);\n" + " num_extra = info->pass_fdlist ? 3 : 2;" + " paramv = g_new0 (GValue, num_params + num_extra);\n" + " n = 0;\n" + " g_value_init (¶mv[n], %sTYPE_%s);\n" + " g_value_set_object (¶mv[n++], skeleton);\n" + " g_value_init (¶mv[n], G_TYPE_DBUS_METHOD_INVOCATION);\n" + " g_value_set_object (¶mv[n++], invocation);\n" + " if (info->pass_fdlist)\n" + " {\n" + "#ifdef G_OS_UNIX\n" + " g_value_init (¶mv[n], G_TYPE_UNIX_FD_LIST);\n" + " g_value_set_object (¶mv[n++], g_dbus_message_get_unix_fd_list (g_dbus_method_invocation_get_message (invocation)));\n" + "#else\n" + " g_assert_not_reached ();\n" + "#endif\n" + " }\n" % (i.ns_upper, i.name_upper) + ) + self.outfile.write( + " g_variant_iter_init (&iter, parameters);\n" + " while ((child = g_variant_iter_next_value (&iter)) != NULL)\n" + " {\n" + " _ExtendedGDBusArgInfo *arg_info = (_ExtendedGDBusArgInfo *) info->parent_struct.in_args[n - num_extra];\n" + " if (arg_info->use_gvariant)\n" + " {\n" + " g_value_init (¶mv[n], G_TYPE_VARIANT);\n" + " g_value_set_variant (¶mv[n], child);\n" + " n++;\n" + " }\n" + " else\n" + " g_dbus_gvariant_to_gvalue (child, ¶mv[n++]);\n" + " g_variant_unref (child);\n" + " }\n" + ) + self.outfile.write( + " signal_id = g_signal_lookup (info->signal_name, %sTYPE_%s);\n" + % (i.ns_upper, i.name_upper) + ) + self.outfile.write( + " g_value_init (&return_value, G_TYPE_BOOLEAN);\n" + " g_signal_emitv (paramv, signal_id, 0, &return_value);\n" + " if (!g_value_get_boolean (&return_value))\n" + ' g_dbus_method_invocation_return_error (invocation, G_DBUS_ERROR, G_DBUS_ERROR_UNKNOWN_METHOD, "Method %s is not implemented on interface %s", method_name, interface_name);\n' + " g_value_unset (&return_value);\n" + ) + self.outfile.write( + " for (n = 0; n < num_params + num_extra; n++)\n" + " g_value_unset (¶mv[n]);\n" + " g_free (paramv);\n" + ) + self.outfile.write("}\n" "\n") + + self.outfile.write( + "static GVariant *\n" + "_%s_skeleton_handle_get_property (\n" + " GDBusConnection *connection G_GNUC_UNUSED,\n" + " const gchar *sender G_GNUC_UNUSED,\n" + " const gchar *object_path G_GNUC_UNUSED,\n" + " const gchar *interface_name G_GNUC_UNUSED,\n" + " const gchar *property_name,\n" + " GError **error,\n" + " gpointer user_data)\n" + "{\n" + " %sSkeleton *skeleton = %s%s_SKELETON (user_data);\n" + " GValue value = G_VALUE_INIT;\n" + " GParamSpec *pspec;\n" + " _ExtendedGDBusPropertyInfo *info;\n" + " GVariant *ret;\n" + % (i.name_lower, i.camel_name, i.ns_upper, i.name_upper) + ) + self.outfile.write( + " ret = NULL;\n" + " info = (_ExtendedGDBusPropertyInfo *) g_dbus_interface_info_lookup_property ((GDBusInterfaceInfo *) &_%s_interface_info.parent_struct, property_name);\n" + " g_assert (info != NULL);\n" + " pspec = g_object_class_find_property (G_OBJECT_GET_CLASS (skeleton), info->hyphen_name);\n" + " if (pspec == NULL)\n" + " {\n" + ' g_set_error (error, G_DBUS_ERROR, G_DBUS_ERROR_INVALID_ARGS, "No property with name %%s", property_name);\n' + " }\n" + " else\n" + " {\n" + " g_value_init (&value, pspec->value_type);\n" + " g_object_get_property (G_OBJECT (skeleton), info->hyphen_name, &value);\n" + " ret = g_dbus_gvalue_to_gvariant (&value, G_VARIANT_TYPE (info->parent_struct.signature));\n" + " g_value_unset (&value);\n" + " }\n" + " return ret;\n" + "}\n" + "\n" % (i.name_lower) + ) + + self.outfile.write( + "static gboolean\n" + "_%s_skeleton_handle_set_property (\n" + " GDBusConnection *connection G_GNUC_UNUSED,\n" + " const gchar *sender G_GNUC_UNUSED,\n" + " const gchar *object_path G_GNUC_UNUSED,\n" + " const gchar *interface_name G_GNUC_UNUSED,\n" + " const gchar *property_name,\n" + " GVariant *variant,\n" + " GError **error,\n" + " gpointer user_data)\n" + "{\n" + " %sSkeleton *skeleton = %s%s_SKELETON (user_data);\n" + " GValue value = G_VALUE_INIT;\n" + " GParamSpec *pspec;\n" + " _ExtendedGDBusPropertyInfo *info;\n" + " gboolean ret;\n" % (i.name_lower, i.camel_name, i.ns_upper, i.name_upper) + ) + self.outfile.write( + " ret = FALSE;\n" + " info = (_ExtendedGDBusPropertyInfo *) g_dbus_interface_info_lookup_property ((GDBusInterfaceInfo *) &_%s_interface_info.parent_struct, property_name);\n" + " g_assert (info != NULL);\n" + " pspec = g_object_class_find_property (G_OBJECT_GET_CLASS (skeleton), info->hyphen_name);\n" + " if (pspec == NULL)\n" + " {\n" + ' g_set_error (error, G_DBUS_ERROR, G_DBUS_ERROR_INVALID_ARGS, "No property with name %%s", property_name);\n' + " }\n" + " else\n" + " {\n" + " if (info->use_gvariant)\n" + " g_value_set_variant (&value, variant);\n" + " else\n" + " g_dbus_gvariant_to_gvalue (variant, &value);\n" + " g_object_set_property (G_OBJECT (skeleton), info->hyphen_name, &value);\n" + " g_value_unset (&value);\n" + " ret = TRUE;\n" + " }\n" + " return ret;\n" + "}\n" + "\n" % (i.name_lower) + ) + + self.outfile.write( + "static const GDBusInterfaceVTable _%s_skeleton_vtable =\n" + "{\n" + " _%s_skeleton_handle_method_call,\n" + " _%s_skeleton_handle_get_property,\n" + " _%s_skeleton_handle_set_property,\n" + " {NULL}\n" + "};\n" + "\n" % (i.name_lower, i.name_lower, i.name_lower, i.name_lower) + ) + + self.outfile.write( + "static GDBusInterfaceInfo *\n" + "%s_skeleton_dbus_interface_get_info (GDBusInterfaceSkeleton *skeleton G_GNUC_UNUSED)\n" + "{\n" + " return %s_interface_info ();\n" % (i.name_lower, i.name_lower) + ) + self.outfile.write("}\n" "\n") + + self.outfile.write( + "static GDBusInterfaceVTable *\n" + "%s_skeleton_dbus_interface_get_vtable (GDBusInterfaceSkeleton *skeleton G_GNUC_UNUSED)\n" + "{\n" + " return (GDBusInterfaceVTable *) &_%s_skeleton_vtable;\n" + % (i.name_lower, i.name_lower) + ) + self.outfile.write("}\n" "\n") + + self.outfile.write( + "static GVariant *\n" + "%s_skeleton_dbus_interface_get_properties (GDBusInterfaceSkeleton *_skeleton)\n" + "{\n" + " %sSkeleton *skeleton = %s%s_SKELETON (_skeleton);\n" + % (i.name_lower, i.camel_name, i.ns_upper, i.name_upper) + ) + self.outfile.write( + "\n" + " GVariantBuilder builder;\n" + " guint n;\n" + ' g_variant_builder_init (&builder, G_VARIANT_TYPE ("a{sv}"));\n' + " if (_%s_interface_info.parent_struct.properties == NULL)\n" + " goto out;\n" + " for (n = 0; _%s_interface_info.parent_struct.properties[n] != NULL; n++)\n" + " {\n" + " GDBusPropertyInfo *info = _%s_interface_info.parent_struct.properties[n];\n" + " if (info->flags & G_DBUS_PROPERTY_INFO_FLAGS_READABLE)\n" + " {\n" + " GVariant *value;\n" + ' value = _%s_skeleton_handle_get_property (g_dbus_interface_skeleton_get_connection (G_DBUS_INTERFACE_SKELETON (skeleton)), NULL, g_dbus_interface_skeleton_get_object_path (G_DBUS_INTERFACE_SKELETON (skeleton)), "%s", info->name, NULL, skeleton);\n' + " if (value != NULL)\n" + " {\n" + " g_variant_take_ref (value);\n" + ' g_variant_builder_add (&builder, "{sv}", info->name, value);\n' + " g_variant_unref (value);\n" + " }\n" + " }\n" + " }\n" + "out:\n" + " return g_variant_builder_end (&builder);\n" + "}\n" + "\n" % (i.name_lower, i.name_lower, i.name_lower, i.name_lower, i.name) + ) if len(i.properties) > 0: - self.outfile.write('static gboolean _%s_emit_changed (gpointer user_data);\n' - '\n' - %(i.name_lower)) - - self.outfile.write('static void\n' - '%s_skeleton_dbus_interface_flush (GDBusInterfaceSkeleton *_skeleton)\n' - '{\n' - %(i.name_lower)) + self.outfile.write( + "static gboolean _%s_emit_changed (gpointer user_data);\n" + "\n" % (i.name_lower) + ) + + self.outfile.write( + "static void\n" + "%s_skeleton_dbus_interface_flush (GDBusInterfaceSkeleton *_skeleton)\n" + "{\n" % (i.name_lower) + ) if len(i.properties) > 0: - self.outfile.write(' %sSkeleton *skeleton = %s%s_SKELETON (_skeleton);\n' - ' gboolean emit_changed = FALSE;\n' - '\n' - ' g_mutex_lock (&skeleton->priv->lock);\n' - ' if (skeleton->priv->changed_properties_idle_source != NULL)\n' - ' {\n' - ' g_source_destroy (skeleton->priv->changed_properties_idle_source);\n' - ' skeleton->priv->changed_properties_idle_source = NULL;\n' - ' emit_changed = TRUE;\n' - ' }\n' - ' g_mutex_unlock (&skeleton->priv->lock);\n' - '\n' - ' if (emit_changed)\n' - ' _%s_emit_changed (skeleton);\n' - %(i.camel_name, i.ns_upper, i.name_upper, i.name_lower)) - self.outfile.write('}\n' - '\n') + self.outfile.write( + " %sSkeleton *skeleton = %s%s_SKELETON (_skeleton);\n" + " gboolean emit_changed = FALSE;\n" + "\n" + " g_mutex_lock (&skeleton->priv->lock);\n" + " if (skeleton->priv->changed_properties_idle_source != NULL)\n" + " {\n" + " g_source_destroy (skeleton->priv->changed_properties_idle_source);\n" + " skeleton->priv->changed_properties_idle_source = NULL;\n" + " emit_changed = TRUE;\n" + " }\n" + " g_mutex_unlock (&skeleton->priv->lock);\n" + "\n" + " if (emit_changed)\n" + " _%s_emit_changed (skeleton);\n" + % (i.camel_name, i.ns_upper, i.name_upper, i.name_lower) + ) + self.outfile.write("}\n" "\n") for s in i.signals: - self.outfile.write('static void\n' - '_%s_on_signal_%s (\n' - ' %s *object'%(i.name_lower, s.name_lower, i.camel_name)) + self.outfile.write( + "static void\n" + "_%s_on_signal_%s (\n" + " %s *object" % (i.name_lower, s.name_lower, i.camel_name) + ) for a in s.args: - self.outfile.write(',\n %sarg_%s'%(a.ctype_in, a.name)) - self.outfile.write(')\n' - '{\n' - ' %sSkeleton *skeleton = %s%s_SKELETON (object);\n\n' - ' GList *connections, *l;\n' - ' GVariant *signal_variant;\n' - ' connections = g_dbus_interface_skeleton_get_connections (G_DBUS_INTERFACE_SKELETON (skeleton));\n' - %(i.camel_name, i.ns_upper, i.name_upper)) - self.outfile.write('\n' - ' signal_variant = g_variant_ref_sink (g_variant_new ("(') + self.outfile.write(",\n %sarg_%s" % (a.ctype_in, a.name)) + self.outfile.write( + ")\n" + "{\n" + " %sSkeleton *skeleton = %s%s_SKELETON (object);\n\n" + " GList *connections, *l;\n" + " GVariant *signal_variant;\n" + " connections = g_dbus_interface_skeleton_get_connections (G_DBUS_INTERFACE_SKELETON (skeleton));\n" + % (i.camel_name, i.ns_upper, i.name_upper) + ) + self.outfile.write( + "\n" ' signal_variant = g_variant_ref_sink (g_variant_new ("(' + ) for a in s.args: - self.outfile.write('%s'%(a.format_in)) + self.outfile.write("%s" % (a.format_in)) self.outfile.write(')"') for a in s.args: - self.outfile.write(',\n arg_%s'%(a.name)) - self.outfile.write('));\n') - - self.outfile.write(' for (l = connections; l != NULL; l = l->next)\n' - ' {\n' - ' GDBusConnection *connection = l->data;\n' - ' g_dbus_connection_emit_signal (connection,\n' - ' NULL, g_dbus_interface_skeleton_get_object_path (G_DBUS_INTERFACE_SKELETON (skeleton)), "%s", "%s",\n' - ' signal_variant, NULL);\n' - ' }\n' - %(i.name, s.name)) - self.outfile.write(' g_variant_unref (signal_variant);\n') - self.outfile.write(' g_list_free_full (connections, g_object_unref);\n') - self.outfile.write('}\n' - '\n') - - self.outfile.write('static void %s_skeleton_iface_init (%sIface *iface);\n' - %(i.name_lower, i.camel_name)) - - self.outfile.write('#if GLIB_VERSION_MAX_ALLOWED >= GLIB_VERSION_2_38\n') - self.outfile.write('G_DEFINE_TYPE_WITH_CODE (%sSkeleton, %s_skeleton, G_TYPE_DBUS_INTERFACE_SKELETON,\n'%(i.camel_name, i.name_lower)) - self.outfile.write(' G_ADD_PRIVATE (%sSkeleton)\n'%(i.camel_name)) - self.outfile.write(' G_IMPLEMENT_INTERFACE (%sTYPE_%s, %s_skeleton_iface_init))\n\n'%(i.ns_upper, i.name_upper, i.name_lower)) - self.outfile.write('#else\n') - self.outfile.write('G_DEFINE_TYPE_WITH_CODE (%sSkeleton, %s_skeleton, G_TYPE_DBUS_INTERFACE_SKELETON,\n'%(i.camel_name, i.name_lower)) - self.outfile.write(' G_IMPLEMENT_INTERFACE (%sTYPE_%s, %s_skeleton_iface_init))\n\n'%(i.ns_upper, i.name_upper, i.name_lower)) - self.outfile.write('#endif\n') + self.outfile.write(",\n arg_%s" % (a.name)) + self.outfile.write("));\n") + + self.outfile.write( + " for (l = connections; l != NULL; l = l->next)\n" + " {\n" + " GDBusConnection *connection = l->data;\n" + " g_dbus_connection_emit_signal (connection,\n" + ' NULL, g_dbus_interface_skeleton_get_object_path (G_DBUS_INTERFACE_SKELETON (skeleton)), "%s", "%s",\n' + " signal_variant, NULL);\n" + " }\n" % (i.name, s.name) + ) + self.outfile.write(" g_variant_unref (signal_variant);\n") + self.outfile.write(" g_list_free_full (connections, g_object_unref);\n") + self.outfile.write("}\n" "\n") + + self.outfile.write( + "static void %s_skeleton_iface_init (%sIface *iface);\n" + % (i.name_lower, i.camel_name) + ) + + self.outfile.write("#if GLIB_VERSION_MAX_ALLOWED >= GLIB_VERSION_2_38\n") + self.outfile.write( + "G_DEFINE_TYPE_WITH_CODE (%sSkeleton, %s_skeleton, G_TYPE_DBUS_INTERFACE_SKELETON,\n" + % (i.camel_name, i.name_lower) + ) + self.outfile.write( + " G_ADD_PRIVATE (%sSkeleton)\n" % (i.camel_name) + ) + self.outfile.write( + " G_IMPLEMENT_INTERFACE (%sTYPE_%s, %s_skeleton_iface_init))\n\n" + % (i.ns_upper, i.name_upper, i.name_lower) + ) + self.outfile.write("#else\n") + self.outfile.write( + "G_DEFINE_TYPE_WITH_CODE (%sSkeleton, %s_skeleton, G_TYPE_DBUS_INTERFACE_SKELETON,\n" + % (i.camel_name, i.name_lower) + ) + self.outfile.write( + " G_IMPLEMENT_INTERFACE (%sTYPE_%s, %s_skeleton_iface_init))\n\n" + % (i.ns_upper, i.name_upper, i.name_lower) + ) + self.outfile.write("#endif\n") # finalize - self.outfile.write('static void\n' - '%s_skeleton_finalize (GObject *object)\n' - '{\n'%(i.name_lower)) - self.outfile.write(' %sSkeleton *skeleton = %s%s_SKELETON (object);\n'%(i.camel_name, i.ns_upper, i.name_upper)) + self.outfile.write( + "static void\n" + "%s_skeleton_finalize (GObject *object)\n" + "{\n" % (i.name_lower) + ) + self.outfile.write( + " %sSkeleton *skeleton = %s%s_SKELETON (object);\n" + % (i.camel_name, i.ns_upper, i.name_upper) + ) if len(i.properties) > 0: - self.outfile.write(' guint n;\n' - ' for (n = 0; n < %d; n++)\n' - ' g_value_unset (&skeleton->priv->properties[n]);\n'%(len(i.properties))) - self.outfile.write(' g_free (skeleton->priv->properties);\n') - self.outfile.write(' g_list_free_full (skeleton->priv->changed_properties, (GDestroyNotify) _changed_property_free);\n') - self.outfile.write(' if (skeleton->priv->changed_properties_idle_source != NULL)\n') - self.outfile.write(' g_source_destroy (skeleton->priv->changed_properties_idle_source);\n') - self.outfile.write(' g_main_context_unref (skeleton->priv->context);\n') - self.outfile.write(' g_mutex_clear (&skeleton->priv->lock);\n') - self.outfile.write(' G_OBJECT_CLASS (%s_skeleton_parent_class)->finalize (object);\n' - '}\n' - '\n'%(i.name_lower)) + self.outfile.write( + " guint n;\n" + " for (n = 0; n < %d; n++)\n" + " g_value_unset (&skeleton->priv->properties[n]);\n" + % (len(i.properties)) + ) + self.outfile.write(" g_free (skeleton->priv->properties);\n") + self.outfile.write( + " g_list_free_full (skeleton->priv->changed_properties, (GDestroyNotify) _changed_property_free);\n" + ) + self.outfile.write( + " if (skeleton->priv->changed_properties_idle_source != NULL)\n" + ) + self.outfile.write( + " g_source_destroy (skeleton->priv->changed_properties_idle_source);\n" + ) + self.outfile.write(" g_main_context_unref (skeleton->priv->context);\n") + self.outfile.write(" g_mutex_clear (&skeleton->priv->lock);\n") + self.outfile.write( + " G_OBJECT_CLASS (%s_skeleton_parent_class)->finalize (object);\n" + "}\n" + "\n" % (i.name_lower) + ) # property accessors (TODO: generate PropertiesChanged signals in setter) if len(i.properties) > 0: - self.outfile.write('static void\n' - '%s_skeleton_get_property (GObject *object,\n' - ' guint prop_id,\n' - ' GValue *value,\n' - ' GParamSpec *pspec G_GNUC_UNUSED)\n' - '{\n'%(i.name_lower)) - self.outfile.write(' %sSkeleton *skeleton = %s%s_SKELETON (object);\n' - ' g_assert (prop_id != 0 && prop_id - 1 < %d);\n' - ' g_mutex_lock (&skeleton->priv->lock);\n' - ' g_value_copy (&skeleton->priv->properties[prop_id - 1], value);\n' - ' g_mutex_unlock (&skeleton->priv->lock);\n' - %(i.camel_name, i.ns_upper, i.name_upper, len(i.properties))) - self.outfile.write('}\n' - '\n') + self.outfile.write( + "static void\n" + "%s_skeleton_get_property (GObject *object,\n" + " guint prop_id,\n" + " GValue *value,\n" + " GParamSpec *pspec G_GNUC_UNUSED)\n" + "{\n" % (i.name_lower) + ) + self.outfile.write( + " %sSkeleton *skeleton = %s%s_SKELETON (object);\n" + " g_assert (prop_id != 0 && prop_id - 1 < %d);\n" + " g_mutex_lock (&skeleton->priv->lock);\n" + " g_value_copy (&skeleton->priv->properties[prop_id - 1], value);\n" + " g_mutex_unlock (&skeleton->priv->lock);\n" + % (i.camel_name, i.ns_upper, i.name_upper, len(i.properties)) + ) + self.outfile.write("}\n" "\n") # if property is already scheduled then re-use entry.. though it could be # that the user did @@ -2895,992 +3909,1281 @@ class CodeGenerator: # change event. If the latest value is not different from the original # one, we can simply ignore the ChangedProperty # - self.outfile.write('static gboolean\n' - '_%s_emit_changed (gpointer user_data)\n' - '{\n' - ' %sSkeleton *skeleton = %s%s_SKELETON (user_data);\n' - %(i.name_lower, i.camel_name, i.ns_upper, i.name_upper)) - self.outfile.write(' GList *l;\n' - ' GVariantBuilder builder;\n' - ' GVariantBuilder invalidated_builder;\n' - ' guint num_changes;\n' - '\n' - ' g_mutex_lock (&skeleton->priv->lock);\n' - ' g_variant_builder_init (&builder, G_VARIANT_TYPE ("a{sv}"));\n' - ' g_variant_builder_init (&invalidated_builder, G_VARIANT_TYPE ("as"));\n' - ' for (l = skeleton->priv->changed_properties, num_changes = 0; l != NULL; l = l->next)\n' - ' {\n' - ' ChangedProperty *cp = l->data;\n' - ' GVariant *variant;\n' - ' const GValue *cur_value;\n' - '\n' - ' cur_value = &skeleton->priv->properties[cp->prop_id - 1];\n' - ' if (!_g_value_equal (cur_value, &cp->orig_value))\n' - ' {\n' - ' variant = g_dbus_gvalue_to_gvariant (cur_value, G_VARIANT_TYPE (cp->info->parent_struct.signature));\n' - ' g_variant_builder_add (&builder, "{sv}", cp->info->parent_struct.name, variant);\n' - ' g_variant_unref (variant);\n' - ' num_changes++;\n' - ' }\n' - ' }\n' - ' if (num_changes > 0)\n' - ' {\n' - ' GList *connections, *ll;\n' - ' GVariant *signal_variant;' - '\n' - ' signal_variant = g_variant_ref_sink (g_variant_new ("(sa{sv}as)", "%s",\n' - ' &builder, &invalidated_builder));\n' - ' connections = g_dbus_interface_skeleton_get_connections (G_DBUS_INTERFACE_SKELETON (skeleton));\n' - ' for (ll = connections; ll != NULL; ll = ll->next)\n' - ' {\n' - ' GDBusConnection *connection = ll->data;\n' - '\n' - ' g_dbus_connection_emit_signal (connection,\n' - ' NULL, g_dbus_interface_skeleton_get_object_path (G_DBUS_INTERFACE_SKELETON (skeleton)),\n' - ' "org.freedesktop.DBus.Properties",\n' - ' "PropertiesChanged",\n' - ' signal_variant,\n' - ' NULL);\n' - ' }\n' - ' g_variant_unref (signal_variant);\n' - ' g_list_free_full (connections, g_object_unref);\n' - ' }\n' - ' else\n' - ' {\n' - ' g_variant_builder_clear (&builder);\n' - ' g_variant_builder_clear (&invalidated_builder);\n' - ' }\n' - %(i.name)) - self.outfile.write(' g_list_free_full (skeleton->priv->changed_properties, (GDestroyNotify) _changed_property_free);\n') - self.outfile.write(' skeleton->priv->changed_properties = NULL;\n') - self.outfile.write(' skeleton->priv->changed_properties_idle_source = NULL;\n') - self.outfile.write(' g_mutex_unlock (&skeleton->priv->lock);\n') - self.outfile.write(' return FALSE;\n' - '}\n' - '\n') + self.outfile.write( + "static gboolean\n" + "_%s_emit_changed (gpointer user_data)\n" + "{\n" + " %sSkeleton *skeleton = %s%s_SKELETON (user_data);\n" + % (i.name_lower, i.camel_name, i.ns_upper, i.name_upper) + ) + self.outfile.write( + " GList *l;\n" + " GVariantBuilder builder;\n" + " GVariantBuilder invalidated_builder;\n" + " guint num_changes;\n" + "\n" + " g_mutex_lock (&skeleton->priv->lock);\n" + ' g_variant_builder_init (&builder, G_VARIANT_TYPE ("a{sv}"));\n' + ' g_variant_builder_init (&invalidated_builder, G_VARIANT_TYPE ("as"));\n' + " for (l = skeleton->priv->changed_properties, num_changes = 0; l != NULL; l = l->next)\n" + " {\n" + " ChangedProperty *cp = l->data;\n" + " GVariant *variant;\n" + " const GValue *cur_value;\n" + "\n" + " cur_value = &skeleton->priv->properties[cp->prop_id - 1];\n" + " if (!_g_value_equal (cur_value, &cp->orig_value))\n" + " {\n" + " variant = g_dbus_gvalue_to_gvariant (cur_value, G_VARIANT_TYPE (cp->info->parent_struct.signature));\n" + ' g_variant_builder_add (&builder, "{sv}", cp->info->parent_struct.name, variant);\n' + " g_variant_unref (variant);\n" + " num_changes++;\n" + " }\n" + " }\n" + " if (num_changes > 0)\n" + " {\n" + " GList *connections, *ll;\n" + " GVariant *signal_variant;" + "\n" + ' signal_variant = g_variant_ref_sink (g_variant_new ("(sa{sv}as)", "%s",\n' + " &builder, &invalidated_builder));\n" + " connections = g_dbus_interface_skeleton_get_connections (G_DBUS_INTERFACE_SKELETON (skeleton));\n" + " for (ll = connections; ll != NULL; ll = ll->next)\n" + " {\n" + " GDBusConnection *connection = ll->data;\n" + "\n" + " g_dbus_connection_emit_signal (connection,\n" + " NULL, g_dbus_interface_skeleton_get_object_path (G_DBUS_INTERFACE_SKELETON (skeleton)),\n" + ' "org.freedesktop.DBus.Properties",\n' + ' "PropertiesChanged",\n' + " signal_variant,\n" + " NULL);\n" + " }\n" + " g_variant_unref (signal_variant);\n" + " g_list_free_full (connections, g_object_unref);\n" + " }\n" + " else\n" + " {\n" + " g_variant_builder_clear (&builder);\n" + " g_variant_builder_clear (&invalidated_builder);\n" + " }\n" % (i.name) + ) + self.outfile.write( + " g_list_free_full (skeleton->priv->changed_properties, (GDestroyNotify) _changed_property_free);\n" + ) + self.outfile.write(" skeleton->priv->changed_properties = NULL;\n") + self.outfile.write( + " skeleton->priv->changed_properties_idle_source = NULL;\n" + ) + self.outfile.write(" g_mutex_unlock (&skeleton->priv->lock);\n") + self.outfile.write(" return FALSE;\n" "}\n" "\n") # holding lock while being called - self.outfile.write('static void\n' - '_%s_schedule_emit_changed (%sSkeleton *skeleton, const _ExtendedGDBusPropertyInfo *info, guint prop_id, const GValue *orig_value)\n' - '{\n' - ' ChangedProperty *cp;\n' - ' GList *l;\n' - ' cp = NULL;\n' - ' for (l = skeleton->priv->changed_properties; l != NULL; l = l->next)\n' - ' {\n' - ' ChangedProperty *i_cp = l->data;\n' - ' if (i_cp->info == info)\n' - ' {\n' - ' cp = i_cp;\n' - ' break;\n' - ' }\n' - ' }\n' - %(i.name_lower, i.camel_name)) - self.outfile.write(' if (cp == NULL)\n' - ' {\n' - ' cp = g_new0 (ChangedProperty, 1);\n' - ' cp->prop_id = prop_id;\n' - ' cp->info = info;\n' - ' skeleton->priv->changed_properties = g_list_prepend (skeleton->priv->changed_properties, cp);\n' - ' g_value_init (&cp->orig_value, G_VALUE_TYPE (orig_value));\n' - ' g_value_copy (orig_value, &cp->orig_value);\n' - ' }\n' - '}\n' - '\n' - %()) + self.outfile.write( + "static void\n" + "_%s_schedule_emit_changed (%sSkeleton *skeleton, const _ExtendedGDBusPropertyInfo *info, guint prop_id, const GValue *orig_value)\n" + "{\n" + " ChangedProperty *cp;\n" + " GList *l;\n" + " cp = NULL;\n" + " for (l = skeleton->priv->changed_properties; l != NULL; l = l->next)\n" + " {\n" + " ChangedProperty *i_cp = l->data;\n" + " if (i_cp->info == info)\n" + " {\n" + " cp = i_cp;\n" + " break;\n" + " }\n" + " }\n" % (i.name_lower, i.camel_name) + ) + self.outfile.write( + " if (cp == NULL)\n" + " {\n" + " cp = g_new0 (ChangedProperty, 1);\n" + " cp->prop_id = prop_id;\n" + " cp->info = info;\n" + " skeleton->priv->changed_properties = g_list_prepend (skeleton->priv->changed_properties, cp);\n" + " g_value_init (&cp->orig_value, G_VALUE_TYPE (orig_value));\n" + " g_value_copy (orig_value, &cp->orig_value);\n" + " }\n" + "}\n" + "\n" % () + ) # Postpone setting up the refresh source until the ::notify signal is emitted as # this allows use of g_object_freeze_notify()/g_object_thaw_notify() ... # This is useful when updating several properties from another thread than # where the idle will be emitted from - self.outfile.write('static void\n' - '%s_skeleton_notify (GObject *object,\n' - ' GParamSpec *pspec G_GNUC_UNUSED)\n' - '{\n' - ' %sSkeleton *skeleton = %s%s_SKELETON (object);\n' - ' g_mutex_lock (&skeleton->priv->lock);\n' - ' if (skeleton->priv->changed_properties != NULL &&\n' - ' skeleton->priv->changed_properties_idle_source == NULL)\n' - ' {\n' - ' skeleton->priv->changed_properties_idle_source = g_idle_source_new ();\n' - ' g_source_set_priority (skeleton->priv->changed_properties_idle_source, G_PRIORITY_DEFAULT);\n' - ' g_source_set_callback (skeleton->priv->changed_properties_idle_source, _%s_emit_changed, g_object_ref (skeleton), (GDestroyNotify) g_object_unref);\n' - ' g_source_set_name (skeleton->priv->changed_properties_idle_source, "[generated] _%s_emit_changed");\n' - ' g_source_attach (skeleton->priv->changed_properties_idle_source, skeleton->priv->context);\n' - ' g_source_unref (skeleton->priv->changed_properties_idle_source);\n' - ' }\n' - ' g_mutex_unlock (&skeleton->priv->lock);\n' - '}\n' - '\n' - %(i.name_lower, i.camel_name, i.ns_upper, i.name_upper, i.name_lower, i.name_lower)) - - self.outfile.write('static void\n' - '%s_skeleton_set_property (GObject *object,\n' - ' guint prop_id,\n' - ' const GValue *value,\n' - ' GParamSpec *pspec)\n' - '{\n'%(i.name_lower)) - self.outfile.write(' const _ExtendedGDBusPropertyInfo *info;\n' - ' %sSkeleton *skeleton = %s%s_SKELETON (object);\n' - ' g_assert (prop_id != 0 && prop_id - 1 < %d);\n' - ' info = (const _ExtendedGDBusPropertyInfo *) _%s_property_info_pointers[prop_id - 1];\n' - ' g_mutex_lock (&skeleton->priv->lock);\n' - ' g_object_freeze_notify (object);\n' - ' if (!_g_value_equal (value, &skeleton->priv->properties[prop_id - 1]))\n' - ' {\n' - ' if (g_dbus_interface_skeleton_get_connection (G_DBUS_INTERFACE_SKELETON (skeleton)) != NULL &&\n' - ' info->emits_changed_signal)\n' - ' _%s_schedule_emit_changed (skeleton, info, prop_id, &skeleton->priv->properties[prop_id - 1]);\n' - ' g_value_copy (value, &skeleton->priv->properties[prop_id - 1]);\n' - ' g_object_notify_by_pspec (object, pspec);\n' - ' }\n' - ' g_mutex_unlock (&skeleton->priv->lock);\n' - ' g_object_thaw_notify (object);\n' - %(i.camel_name, i.ns_upper, i.name_upper, len(i.properties), i.name_lower, i.name_lower)) - self.outfile.write('}\n' - '\n') - - self.outfile.write('static void\n' - '%s_skeleton_init (%sSkeleton *skeleton)\n' - '{\n' - '#if GLIB_VERSION_MAX_ALLOWED >= GLIB_VERSION_2_38\n' - ' skeleton->priv = %s_skeleton_get_instance_private (skeleton);\n' - '#else\n' - ' skeleton->priv = G_TYPE_INSTANCE_GET_PRIVATE (skeleton, %sTYPE_%s_SKELETON, %sSkeletonPrivate);\n' - '#endif\n\n' - %(i.name_lower, i.camel_name, - i.name_lower, - i.ns_upper, i.name_upper, i.camel_name)) - self.outfile.write(' g_mutex_init (&skeleton->priv->lock);\n') - self.outfile.write(' skeleton->priv->context = g_main_context_ref_thread_default ();\n') + self.outfile.write( + "static void\n" + "%s_skeleton_notify (GObject *object,\n" + " GParamSpec *pspec G_GNUC_UNUSED)\n" + "{\n" + " %sSkeleton *skeleton = %s%s_SKELETON (object);\n" + " g_mutex_lock (&skeleton->priv->lock);\n" + " if (skeleton->priv->changed_properties != NULL &&\n" + " skeleton->priv->changed_properties_idle_source == NULL)\n" + " {\n" + " skeleton->priv->changed_properties_idle_source = g_idle_source_new ();\n" + " g_source_set_priority (skeleton->priv->changed_properties_idle_source, G_PRIORITY_DEFAULT);\n" + " g_source_set_callback (skeleton->priv->changed_properties_idle_source, _%s_emit_changed, g_object_ref (skeleton), (GDestroyNotify) g_object_unref);\n" + ' g_source_set_name (skeleton->priv->changed_properties_idle_source, "[generated] _%s_emit_changed");\n' + " g_source_attach (skeleton->priv->changed_properties_idle_source, skeleton->priv->context);\n" + " g_source_unref (skeleton->priv->changed_properties_idle_source);\n" + " }\n" + " g_mutex_unlock (&skeleton->priv->lock);\n" + "}\n" + "\n" + % ( + i.name_lower, + i.camel_name, + i.ns_upper, + i.name_upper, + i.name_lower, + i.name_lower, + ) + ) + + self.outfile.write( + "static void\n" + "%s_skeleton_set_property (GObject *object,\n" + " guint prop_id,\n" + " const GValue *value,\n" + " GParamSpec *pspec)\n" + "{\n" % (i.name_lower) + ) + self.outfile.write( + " const _ExtendedGDBusPropertyInfo *info;\n" + " %sSkeleton *skeleton = %s%s_SKELETON (object);\n" + " g_assert (prop_id != 0 && prop_id - 1 < %d);\n" + " info = (const _ExtendedGDBusPropertyInfo *) _%s_property_info_pointers[prop_id - 1];\n" + " g_mutex_lock (&skeleton->priv->lock);\n" + " g_object_freeze_notify (object);\n" + " if (!_g_value_equal (value, &skeleton->priv->properties[prop_id - 1]))\n" + " {\n" + " if (g_dbus_interface_skeleton_get_connection (G_DBUS_INTERFACE_SKELETON (skeleton)) != NULL &&\n" + " info->emits_changed_signal)\n" + " _%s_schedule_emit_changed (skeleton, info, prop_id, &skeleton->priv->properties[prop_id - 1]);\n" + " g_value_copy (value, &skeleton->priv->properties[prop_id - 1]);\n" + " g_object_notify_by_pspec (object, pspec);\n" + " }\n" + " g_mutex_unlock (&skeleton->priv->lock);\n" + " g_object_thaw_notify (object);\n" + % ( + i.camel_name, + i.ns_upper, + i.name_upper, + len(i.properties), + i.name_lower, + i.name_lower, + ) + ) + self.outfile.write("}\n" "\n") + + self.outfile.write( + "static void\n" + "%s_skeleton_init (%sSkeleton *skeleton)\n" + "{\n" + "#if GLIB_VERSION_MAX_ALLOWED >= GLIB_VERSION_2_38\n" + " skeleton->priv = %s_skeleton_get_instance_private (skeleton);\n" + "#else\n" + " skeleton->priv = G_TYPE_INSTANCE_GET_PRIVATE (skeleton, %sTYPE_%s_SKELETON, %sSkeletonPrivate);\n" + "#endif\n\n" + % ( + i.name_lower, + i.camel_name, + i.name_lower, + i.ns_upper, + i.name_upper, + i.camel_name, + ) + ) + self.outfile.write(" g_mutex_init (&skeleton->priv->lock);\n") + self.outfile.write( + " skeleton->priv->context = g_main_context_ref_thread_default ();\n" + ) if len(i.properties) > 0: - self.outfile.write(' skeleton->priv->properties = g_new0 (GValue, %d);\n'%(len(i.properties))) + self.outfile.write( + " skeleton->priv->properties = g_new0 (GValue, %d);\n" + % (len(i.properties)) + ) n = 0 for p in i.properties: - self.outfile.write(' g_value_init (&skeleton->priv->properties[%d], %s);\n'%(n, p.arg.gtype)) + self.outfile.write( + " g_value_init (&skeleton->priv->properties[%d], %s);\n" + % (n, p.arg.gtype) + ) n += 1 - self.outfile.write('}\n' - '\n') + self.outfile.write("}\n" "\n") # property vfuncs n = 0 for p in i.properties: - self.outfile.write('static %s\n' - '%s_skeleton_get_%s (%s *object)\n' - '{\n' - %(p.arg.ctype_in, i.name_lower, p.name_lower, i.camel_name)) - self.outfile.write(' %sSkeleton *skeleton = %s%s_SKELETON (object);\n'%(i.camel_name, i.ns_upper, i.name_upper)) - self.outfile.write(' %svalue;\n' - ' g_mutex_lock (&skeleton->priv->lock);\n' - ' value = %s (&(skeleton->priv->properties[%d]));\n' - ' g_mutex_unlock (&skeleton->priv->lock);\n' - %(p.arg.ctype_in_g, p.arg.gvalue_get, n)) - self.outfile.write(' return value;\n') - self.outfile.write('}\n') - self.outfile.write('\n') + self.outfile.write( + "static %s\n" + "%s_skeleton_get_%s (%s *object)\n" + "{\n" % (p.arg.ctype_in, i.name_lower, p.name_lower, i.camel_name) + ) + self.outfile.write( + " %sSkeleton *skeleton = %s%s_SKELETON (object);\n" + % (i.camel_name, i.ns_upper, i.name_upper) + ) + self.outfile.write( + " %svalue;\n" + " g_mutex_lock (&skeleton->priv->lock);\n" + " value = %s (&(skeleton->priv->properties[%d]));\n" + " g_mutex_unlock (&skeleton->priv->lock);\n" + % (p.arg.ctype_in_g, p.arg.gvalue_get, n) + ) + self.outfile.write(" return value;\n") + self.outfile.write("}\n") + self.outfile.write("\n") n += 1 - self.outfile.write('static void\n' - '%s_skeleton_class_init (%sSkeletonClass *klass)\n' - '{\n' - ' GObjectClass *gobject_class;\n' - ' GDBusInterfaceSkeletonClass *skeleton_class;\n' - '\n' - ' gobject_class = G_OBJECT_CLASS (klass);\n' - ' gobject_class->finalize = %s_skeleton_finalize;\n' - %(i.name_lower, i.camel_name, i.name_lower)) + self.outfile.write( + "static void\n" + "%s_skeleton_class_init (%sSkeletonClass *klass)\n" + "{\n" + " GObjectClass *gobject_class;\n" + " GDBusInterfaceSkeletonClass *skeleton_class;\n" + "\n" + " gobject_class = G_OBJECT_CLASS (klass);\n" + " gobject_class->finalize = %s_skeleton_finalize;\n" + % (i.name_lower, i.camel_name, i.name_lower) + ) if len(i.properties) > 0: - self.outfile.write(' gobject_class->get_property = %s_skeleton_get_property;\n' - ' gobject_class->set_property = %s_skeleton_set_property;\n' - ' gobject_class->notify = %s_skeleton_notify;\n' - '\n'%(i.name_lower, i.name_lower, i.name_lower)) - self.outfile.write('\n' - ' %s_override_properties (gobject_class, 1);\n'%(i.name_lower)) - self.outfile.write('\n' - ' skeleton_class = G_DBUS_INTERFACE_SKELETON_CLASS (klass);\n'); - self.outfile.write(' skeleton_class->get_info = %s_skeleton_dbus_interface_get_info;\n'%(i.name_lower)) - self.outfile.write(' skeleton_class->get_properties = %s_skeleton_dbus_interface_get_properties;\n'%(i.name_lower)) - self.outfile.write(' skeleton_class->flush = %s_skeleton_dbus_interface_flush;\n'%(i.name_lower)) - self.outfile.write(' skeleton_class->get_vtable = %s_skeleton_dbus_interface_get_vtable;\n'%(i.name_lower)) - - self.outfile.write('\n' - '#if GLIB_VERSION_MAX_ALLOWED < GLIB_VERSION_2_38\n' - ' g_type_class_add_private (klass, sizeof (%sSkeletonPrivate));\n' - '#endif\n'%(i.camel_name)) - - self.outfile.write('}\n' - '\n') - - self.outfile.write('static void\n' - '%s_skeleton_iface_init (%sIface *iface)\n' - '{\n' - %(i.name_lower, i.camel_name)) + self.outfile.write( + " gobject_class->get_property = %s_skeleton_get_property;\n" + " gobject_class->set_property = %s_skeleton_set_property;\n" + " gobject_class->notify = %s_skeleton_notify;\n" + "\n" % (i.name_lower, i.name_lower, i.name_lower) + ) + self.outfile.write( + "\n" " %s_override_properties (gobject_class, 1);\n" % (i.name_lower) + ) + self.outfile.write( + "\n" " skeleton_class = G_DBUS_INTERFACE_SKELETON_CLASS (klass);\n" + ) + self.outfile.write( + " skeleton_class->get_info = %s_skeleton_dbus_interface_get_info;\n" + % (i.name_lower) + ) + self.outfile.write( + " skeleton_class->get_properties = %s_skeleton_dbus_interface_get_properties;\n" + % (i.name_lower) + ) + self.outfile.write( + " skeleton_class->flush = %s_skeleton_dbus_interface_flush;\n" + % (i.name_lower) + ) + self.outfile.write( + " skeleton_class->get_vtable = %s_skeleton_dbus_interface_get_vtable;\n" + % (i.name_lower) + ) + + self.outfile.write( + "\n" + "#if GLIB_VERSION_MAX_ALLOWED < GLIB_VERSION_2_38\n" + " g_type_class_add_private (klass, sizeof (%sSkeletonPrivate));\n" + "#endif\n" % (i.camel_name) + ) + + self.outfile.write("}\n" "\n") + + self.outfile.write( + "static void\n" + "%s_skeleton_iface_init (%sIface *iface)\n" + "{\n" % (i.name_lower, i.camel_name) + ) for s in i.signals: - self.outfile.write(' iface->%s = _%s_on_signal_%s;\n' - %(s.name_lower, i.name_lower, s.name_lower)) + self.outfile.write( + " iface->%s = _%s_on_signal_%s;\n" + % (s.name_lower, i.name_lower, s.name_lower) + ) for p in i.properties: - self.outfile.write(' iface->get_%s = %s_skeleton_get_%s;\n'%(p.name_lower, i.name_lower, p.name_lower)) - self.outfile.write('}\n' - '\n') + self.outfile.write( + " iface->get_%s = %s_skeleton_get_%s;\n" + % (p.name_lower, i.name_lower, p.name_lower) + ) + self.outfile.write("}\n" "\n") # constructors - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %s_skeleton_new:\n' - ' *\n' - ' * Creates a skeleton object for the D-Bus interface #%s.\n' - ' *\n' - ' * Returns: (transfer full) (type %sSkeleton): The skeleton object.\n' - %(i.name_lower, i.name, i.camel_name), False)) + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %s_skeleton_new:\n" + " *\n" + " * Creates a skeleton object for the D-Bus interface #%s.\n" + " *\n" + " * Returns: (transfer full) (type %sSkeleton): The skeleton object.\n" + % (i.name_lower, i.name, i.camel_name), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('%s *\n' - '%s_skeleton_new (void)\n' - '{\n' - ' return %s%s (g_object_new (%sTYPE_%s_SKELETON, NULL));\n' - '}\n' - '\n'%(i.camel_name, i.name_lower, i.ns_upper, i.name_upper, i.ns_upper, i.name_upper)) + self.outfile.write( + "%s *\n" + "%s_skeleton_new (void)\n" + "{\n" + " return %s%s (g_object_new (%sTYPE_%s_SKELETON, NULL));\n" + "}\n" + "\n" + % ( + i.camel_name, + i.name_lower, + i.ns_upper, + i.name_upper, + i.ns_upper, + i.name_upper, + ) + ) # --------------------------------------------------------------------------------------------------- def generate_object(self): - self.outfile.write('/* ------------------------------------------------------------------------\n' - ' * Code for Object, ObjectProxy and ObjectSkeleton\n' - ' * ------------------------------------------------------------------------\n' - ' */\n' - '\n') - - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * SECTION:%sObject\n' - ' * @title: %sObject\n' - ' * @short_description: Specialized GDBusObject types\n' - ' *\n' - ' * This section contains the #%sObject, #%sObjectProxy, and #%sObjectSkeleton types which make it easier to work with objects implementing generated types for D-Bus interfaces.\n' - ' */\n' - %(self.namespace, self.namespace, self.namespace, self.namespace, self.namespace), False)) - self.outfile.write('\n') - - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sObject:\n' - ' *\n' - ' * The #%sObject type is a specialized container of interfaces.\n' - ' */\n' - %(self.namespace, self.namespace), False)) - self.outfile.write('\n') - - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sObjectIface:\n' - ' * @parent_iface: The parent interface.\n' - ' *\n' - ' * Virtual table for the #%sObject interface.\n' - ' */\n' - %(self.namespace, self.namespace), False)) - self.outfile.write('\n') - - self.outfile.write('typedef %sObjectIface %sObjectInterface;\n'%(self.namespace, self.namespace)) - self.outfile.write('G_DEFINE_INTERFACE_WITH_CODE (%sObject, %sobject, G_TYPE_OBJECT, g_type_interface_add_prerequisite (g_define_type_id, G_TYPE_DBUS_OBJECT);)\n'%(self.namespace, self.ns_lower)) - self.outfile.write('\n') - self.outfile.write('static void\n' - '%sobject_default_init (%sObjectIface *iface)\n' - '{\n' - %(self.ns_lower, self.namespace)); + self.outfile.write( + "/* ------------------------------------------------------------------------\n" + " * Code for Object, ObjectProxy and ObjectSkeleton\n" + " * ------------------------------------------------------------------------\n" + " */\n" + "\n" + ) + + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * SECTION:%sObject\n" + " * @title: %sObject\n" + " * @short_description: Specialized GDBusObject types\n" + " *\n" + " * This section contains the #%sObject, #%sObjectProxy, and #%sObjectSkeleton types which make it easier to work with objects implementing generated types for D-Bus interfaces.\n" + " */\n" + % ( + self.namespace, + self.namespace, + self.namespace, + self.namespace, + self.namespace, + ), + False, + ) + ) + self.outfile.write("\n") + + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sObject:\n" + " *\n" + " * The #%sObject type is a specialized container of interfaces.\n" + " */\n" % (self.namespace, self.namespace), + False, + ) + ) + self.outfile.write("\n") + + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sObjectIface:\n" + " * @parent_iface: The parent interface.\n" + " *\n" + " * Virtual table for the #%sObject interface.\n" + " */\n" % (self.namespace, self.namespace), + False, + ) + ) + self.outfile.write("\n") + + self.outfile.write( + "typedef %sObjectIface %sObjectInterface;\n" + % (self.namespace, self.namespace) + ) + self.outfile.write( + "G_DEFINE_INTERFACE_WITH_CODE (%sObject, %sobject, G_TYPE_OBJECT, g_type_interface_add_prerequisite (g_define_type_id, G_TYPE_DBUS_OBJECT);)\n" + % (self.namespace, self.ns_lower) + ) + self.outfile.write("\n") + self.outfile.write( + "static void\n" + "%sobject_default_init (%sObjectIface *iface)\n" + "{\n" % (self.ns_lower, self.namespace) + ) for i in self.ifaces: - self.outfile.write(self.docbook_gen.expand( - ' /**\n' - ' * %sObject:%s:\n' - ' *\n' - ' * The #%s instance corresponding to the D-Bus interface #%s, if any.\n' - ' *\n' - ' * Connect to the #GObject::notify signal to get informed of property changes.\n' - %(self.namespace, i.name_hyphen, i.camel_name, i.name), False)) + self.outfile.write( + self.docbook_gen.expand( + " /**\n" + " * %sObject:%s:\n" + " *\n" + " * The #%s instance corresponding to the D-Bus interface #%s, if any.\n" + " *\n" + " * Connect to the #GObject::notify signal to get informed of property changes.\n" + % (self.namespace, i.name_hyphen, i.camel_name, i.name), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 2) - flags = 'G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS' + flags = "G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS" if i.deprecated: - flags = 'G_PARAM_DEPRECATED | ' + flags - self.outfile.write(' g_object_interface_install_property (iface, g_param_spec_object ("%s", "%s", "%s", %sTYPE_%s, %s));\n' - '\n' - %(i.name_hyphen, i.name_hyphen, i.name_hyphen, self.ns_upper, i.name_upper, flags)) - self.outfile.write('}\n' - '\n') + flags = "G_PARAM_DEPRECATED | " + flags + self.outfile.write( + ' g_object_interface_install_property (iface, g_param_spec_object ("%s", "%s", "%s", %sTYPE_%s, %s));\n' + "\n" + % ( + i.name_hyphen, + i.name_hyphen, + i.name_hyphen, + self.ns_upper, + i.name_upper, + flags, + ) + ) + self.outfile.write("}\n" "\n") for i in self.ifaces: - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sobject_get_%s:\n' - ' * @object: A #%sObject.\n' - ' *\n' - ' * Gets the #%s instance for the D-Bus interface #%s on @object, if any.\n' - ' *\n' - ' * Returns: (transfer full) (nullable): A #%s that must be freed with g_object_unref() or %%NULL if @object does not implement the interface.\n' - %(self.ns_lower, i.name_upper.lower(), self.namespace, i.camel_name, i.name, i.camel_name), False)) + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sobject_get_%s:\n" + " * @object: A #%sObject.\n" + " *\n" + " * Gets the #%s instance for the D-Bus interface #%s on @object, if any.\n" + " *\n" + " * Returns: (transfer full) (nullable): A #%s that must be freed with g_object_unref() or %%NULL if @object does not implement the interface.\n" + % ( + self.ns_lower, + i.name_upper.lower(), + self.namespace, + i.camel_name, + i.name, + i.camel_name, + ), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('%s *%sobject_get_%s (%sObject *object)\n' - %(i.camel_name, self.ns_lower, i.name_upper.lower(), self.namespace)) - self.outfile.write('{\n' - ' GDBusInterface *ret;\n' - ' ret = g_dbus_object_get_interface (G_DBUS_OBJECT (object), "%s");\n' - ' if (ret == NULL)\n' - ' return NULL;\n' - ' return %s%s (ret);\n' - '}\n' - '\n' - %(i.name, self.ns_upper, i.name_upper)) - self.outfile.write('\n') + self.outfile.write( + "%s *%sobject_get_%s (%sObject *object)\n" + % (i.camel_name, self.ns_lower, i.name_upper.lower(), self.namespace) + ) + self.outfile.write( + "{\n" + " GDBusInterface *ret;\n" + ' ret = g_dbus_object_get_interface (G_DBUS_OBJECT (object), "%s");\n' + " if (ret == NULL)\n" + " return NULL;\n" + " return %s%s (ret);\n" + "}\n" + "\n" % (i.name, self.ns_upper, i.name_upper) + ) + self.outfile.write("\n") for i in self.ifaces: - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sobject_peek_%s: (skip)\n' - ' * @object: A #%sObject.\n' - ' *\n' - ' * Like %sobject_get_%s() but doesn\'t increase the reference count on the returned object.\n' - ' *\n' - ' * It is not safe to use the returned object if you are on another thread than the one where the #GDBusObjectManagerClient or #GDBusObjectManagerServer for @object is running.\n' - ' *\n' - ' * Returns: (transfer none) (nullable): A #%s or %%NULL if @object does not implement the interface. Do not free the returned object, it is owned by @object.\n' - %(self.ns_lower, i.name_upper.lower(), self.namespace, self.ns_lower, i.name_upper.lower(), i.camel_name), False)) + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sobject_peek_%s: (skip)\n" + " * @object: A #%sObject.\n" + " *\n" + " * Like %sobject_get_%s() but doesn't increase the reference count on the returned object.\n" + " *\n" + " * It is not safe to use the returned object if you are on another thread than the one where the #GDBusObjectManagerClient or #GDBusObjectManagerServer for @object is running.\n" + " *\n" + " * Returns: (transfer none) (nullable): A #%s or %%NULL if @object does not implement the interface. Do not free the returned object, it is owned by @object.\n" + % ( + self.ns_lower, + i.name_upper.lower(), + self.namespace, + self.ns_lower, + i.name_upper.lower(), + i.camel_name, + ), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('%s *%sobject_peek_%s (%sObject *object)\n' - %(i.camel_name, self.ns_lower, i.name_upper.lower(), self.namespace)) - self.outfile.write('{\n' - ' GDBusInterface *ret;\n' - ' ret = g_dbus_object_get_interface (G_DBUS_OBJECT (object), "%s");\n' - ' if (ret == NULL)\n' - ' return NULL;\n' - ' g_object_unref (ret);\n' - ' return %s%s (ret);\n' - '}\n' - '\n' - %(i.name, self.ns_upper, i.name_upper)) - self.outfile.write('\n') + self.outfile.write( + "%s *%sobject_peek_%s (%sObject *object)\n" + % (i.camel_name, self.ns_lower, i.name_upper.lower(), self.namespace) + ) + self.outfile.write( + "{\n" + " GDBusInterface *ret;\n" + ' ret = g_dbus_object_get_interface (G_DBUS_OBJECT (object), "%s");\n' + " if (ret == NULL)\n" + " return NULL;\n" + " g_object_unref (ret);\n" + " return %s%s (ret);\n" + "}\n" + "\n" % (i.name, self.ns_upper, i.name_upper) + ) + self.outfile.write("\n") # shared by ObjectProxy and ObjectSkeleton classes - self.outfile.write('static void\n' - '%sobject_notify (GDBusObject *object, GDBusInterface *interface)\n' - '{\n' - ' _ExtendedGDBusInterfaceInfo *info = (_ExtendedGDBusInterfaceInfo *) g_dbus_interface_get_info (interface);\n' - ' /* info can be NULL if the other end is using a D-Bus interface we don\'t know\n' - ' * anything about, for example old generated code in this process talking to\n' - ' * newer generated code in the other process. */\n' - ' if (info != NULL)\n' - ' g_object_notify (G_OBJECT (object), info->hyphen_name);\n' - '}\n' - '\n' - %(self.ns_lower)) - - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sObjectProxy:\n' - ' *\n' - ' * The #%sObjectProxy structure contains only private data and should only be accessed using the provided API.\n' - %(self.namespace, self.namespace), False)) - self.outfile.write(' */\n') - self.outfile.write('\n') - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sObjectProxyClass:\n' - ' * @parent_class: The parent class.\n' - ' *\n' - ' * Class structure for #%sObjectProxy.\n' - %(self.namespace, self.namespace), False)) - self.outfile.write(' */\n') - self.outfile.write('\n') + self.outfile.write( + "static void\n" + "%sobject_notify (GDBusObject *object, GDBusInterface *interface)\n" + "{\n" + " _ExtendedGDBusInterfaceInfo *info = (_ExtendedGDBusInterfaceInfo *) g_dbus_interface_get_info (interface);\n" + " /* info can be NULL if the other end is using a D-Bus interface we don't know\n" + " * anything about, for example old generated code in this process talking to\n" + " * newer generated code in the other process. */\n" + " if (info != NULL)\n" + " g_object_notify (G_OBJECT (object), info->hyphen_name);\n" + "}\n" + "\n" % (self.ns_lower) + ) + + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sObjectProxy:\n" + " *\n" + " * The #%sObjectProxy structure contains only private data and should only be accessed using the provided API.\n" + % (self.namespace, self.namespace), + False, + ) + ) + self.outfile.write(" */\n") + self.outfile.write("\n") + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sObjectProxyClass:\n" + " * @parent_class: The parent class.\n" + " *\n" + " * Class structure for #%sObjectProxy.\n" + % (self.namespace, self.namespace), + False, + ) + ) + self.outfile.write(" */\n") + self.outfile.write("\n") # class boilerplate - self.outfile.write('static void\n' - '%sobject_proxy__%sobject_iface_init (%sObjectIface *iface G_GNUC_UNUSED)\n' - '{\n' - '}\n' - '\n' - %(self.ns_lower, self.ns_lower, self.namespace)) - self.outfile.write('static void\n' - '%sobject_proxy__g_dbus_object_iface_init (GDBusObjectIface *iface)\n' - '{\n' - ' iface->interface_added = %sobject_notify;\n' - ' iface->interface_removed = %sobject_notify;\n' - '}\n' - '\n' - %(self.ns_lower, self.ns_lower, self.ns_lower)) - self.outfile.write('\n') - self.outfile.write('G_DEFINE_TYPE_WITH_CODE (%sObjectProxy, %sobject_proxy, G_TYPE_DBUS_OBJECT_PROXY,\n' - ' G_IMPLEMENT_INTERFACE (%sTYPE_OBJECT, %sobject_proxy__%sobject_iface_init)\n' - ' G_IMPLEMENT_INTERFACE (G_TYPE_DBUS_OBJECT, %sobject_proxy__g_dbus_object_iface_init))\n' - '\n' - %(self.namespace, self.ns_lower, self.ns_upper, self.ns_lower, self.ns_lower, self.ns_lower)) + self.outfile.write( + "static void\n" + "%sobject_proxy__%sobject_iface_init (%sObjectIface *iface G_GNUC_UNUSED)\n" + "{\n" + "}\n" + "\n" % (self.ns_lower, self.ns_lower, self.namespace) + ) + self.outfile.write( + "static void\n" + "%sobject_proxy__g_dbus_object_iface_init (GDBusObjectIface *iface)\n" + "{\n" + " iface->interface_added = %sobject_notify;\n" + " iface->interface_removed = %sobject_notify;\n" + "}\n" + "\n" % (self.ns_lower, self.ns_lower, self.ns_lower) + ) + self.outfile.write("\n") + self.outfile.write( + "G_DEFINE_TYPE_WITH_CODE (%sObjectProxy, %sobject_proxy, G_TYPE_DBUS_OBJECT_PROXY,\n" + " G_IMPLEMENT_INTERFACE (%sTYPE_OBJECT, %sobject_proxy__%sobject_iface_init)\n" + " G_IMPLEMENT_INTERFACE (G_TYPE_DBUS_OBJECT, %sobject_proxy__g_dbus_object_iface_init))\n" + "\n" + % ( + self.namespace, + self.ns_lower, + self.ns_upper, + self.ns_lower, + self.ns_lower, + self.ns_lower, + ) + ) # class boilerplate - self.outfile.write('static void\n' - '%sobject_proxy_init (%sObjectProxy *object G_GNUC_UNUSED)\n' - '{\n' - '}\n' - '\n'%(self.ns_lower, self.namespace)) - self.outfile.write('static void\n' - '%sobject_proxy_set_property (GObject *gobject,\n' - ' guint prop_id,\n' - ' const GValue *value G_GNUC_UNUSED,\n' - ' GParamSpec *pspec)\n' - '{\n' - ' G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, prop_id, pspec);\n' - %(self.ns_lower)) - self.outfile.write('}\n' - '\n'%()) - self.outfile.write('static void\n' - '%sobject_proxy_get_property (GObject *gobject,\n' - ' guint prop_id,\n' - ' GValue *value,\n' - ' GParamSpec *pspec)\n' - '{\n' - ' %sObjectProxy *object = %sOBJECT_PROXY (gobject);\n' - ' GDBusInterface *interface;\n' - '\n' - ' switch (prop_id)\n' - ' {\n' - %(self.ns_lower, self.namespace, self.ns_upper)) + self.outfile.write( + "static void\n" + "%sobject_proxy_init (%sObjectProxy *object G_GNUC_UNUSED)\n" + "{\n" + "}\n" + "\n" % (self.ns_lower, self.namespace) + ) + self.outfile.write( + "static void\n" + "%sobject_proxy_set_property (GObject *gobject,\n" + " guint prop_id,\n" + " const GValue *value G_GNUC_UNUSED,\n" + " GParamSpec *pspec)\n" + "{\n" + " G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, prop_id, pspec);\n" + % (self.ns_lower) + ) + self.outfile.write("}\n" "\n" % ()) + self.outfile.write( + "static void\n" + "%sobject_proxy_get_property (GObject *gobject,\n" + " guint prop_id,\n" + " GValue *value,\n" + " GParamSpec *pspec)\n" + "{\n" + " %sObjectProxy *object = %sOBJECT_PROXY (gobject);\n" + " GDBusInterface *interface;\n" + "\n" + " switch (prop_id)\n" + " {\n" % (self.ns_lower, self.namespace, self.ns_upper) + ) n = 1 for i in self.ifaces: - self.outfile.write(' case %d:\n' - ' interface = g_dbus_object_get_interface (G_DBUS_OBJECT (object), "%s");\n' - ' g_value_take_object (value, interface);\n' - ' break;\n' - '\n' - %(n, i.name)) + self.outfile.write( + " case %d:\n" + ' interface = g_dbus_object_get_interface (G_DBUS_OBJECT (object), "%s");\n' + " g_value_take_object (value, interface);\n" + " break;\n" + "\n" % (n, i.name) + ) n += 1 - self.outfile.write(' default:\n' - ' G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, prop_id, pspec);\n' - ' break;\n' - ' }\n' - '}\n' - '\n'%()) - self.outfile.write('static void\n' - '%sobject_proxy_class_init (%sObjectProxyClass *klass)\n' - '{\n' - ' GObjectClass *gobject_class = G_OBJECT_CLASS (klass);\n' - '\n' - ' gobject_class->set_property = %sobject_proxy_set_property;\n' - ' gobject_class->get_property = %sobject_proxy_get_property;\n' - '\n' - %(self.ns_lower, self.namespace, self.ns_lower, self.ns_lower)) + self.outfile.write( + " default:\n" + " G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, prop_id, pspec);\n" + " break;\n" + " }\n" + "}\n" + "\n" % () + ) + self.outfile.write( + "static void\n" + "%sobject_proxy_class_init (%sObjectProxyClass *klass)\n" + "{\n" + " GObjectClass *gobject_class = G_OBJECT_CLASS (klass);\n" + "\n" + " gobject_class->set_property = %sobject_proxy_set_property;\n" + " gobject_class->get_property = %sobject_proxy_get_property;\n" + "\n" % (self.ns_lower, self.namespace, self.ns_lower, self.ns_lower) + ) n = 1 for i in self.ifaces: - self.outfile.write(' g_object_class_override_property (gobject_class, %d, "%s");' - '\n' - %(n, i.name_hyphen)) + self.outfile.write( + ' g_object_class_override_property (gobject_class, %d, "%s");' + "\n" % (n, i.name_hyphen) + ) n += 1 - self.outfile.write('}\n' - '\n') - - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sobject_proxy_new:\n' - ' * @connection: A #GDBusConnection.\n' - ' * @object_path: An object path.\n' - ' *\n' - ' * Creates a new proxy object.\n' - ' *\n' - ' * Returns: (transfer full): The proxy object.\n' - ' */\n' - %(self.ns_lower), False)) - self.outfile.write('%sObjectProxy *\n' - '%sobject_proxy_new (GDBusConnection *connection,\n' - ' const gchar *object_path)\n' - '{\n' - ' g_return_val_if_fail (G_IS_DBUS_CONNECTION (connection), NULL);\n' - ' g_return_val_if_fail (g_variant_is_object_path (object_path), NULL);\n' - ' return %sOBJECT_PROXY (g_object_new (%sTYPE_OBJECT_PROXY, "g-connection", connection, "g-object-path", object_path, NULL));\n' - '}\n' - '\n'%(self.namespace, self.ns_lower, self.ns_upper, self.ns_upper)) - - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sObjectSkeleton:\n' - ' *\n' - ' * The #%sObjectSkeleton structure contains only private data and should only be accessed using the provided API.\n' - %(self.namespace, self.namespace), False)) - self.outfile.write(' */\n') - self.outfile.write('\n') - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sObjectSkeletonClass:\n' - ' * @parent_class: The parent class.\n' - ' *\n' - ' * Class structure for #%sObjectSkeleton.\n' - %(self.namespace, self.namespace), False)) - self.outfile.write(' */\n') - self.outfile.write('\n') + self.outfile.write("}\n" "\n") + + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sobject_proxy_new:\n" + " * @connection: A #GDBusConnection.\n" + " * @object_path: An object path.\n" + " *\n" + " * Creates a new proxy object.\n" + " *\n" + " * Returns: (transfer full): The proxy object.\n" + " */\n" % (self.ns_lower), + False, + ) + ) + self.outfile.write( + "%sObjectProxy *\n" + "%sobject_proxy_new (GDBusConnection *connection,\n" + " const gchar *object_path)\n" + "{\n" + " g_return_val_if_fail (G_IS_DBUS_CONNECTION (connection), NULL);\n" + " g_return_val_if_fail (g_variant_is_object_path (object_path), NULL);\n" + ' return %sOBJECT_PROXY (g_object_new (%sTYPE_OBJECT_PROXY, "g-connection", connection, "g-object-path", object_path, NULL));\n' + "}\n" + "\n" % (self.namespace, self.ns_lower, self.ns_upper, self.ns_upper) + ) + + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sObjectSkeleton:\n" + " *\n" + " * The #%sObjectSkeleton structure contains only private data and should only be accessed using the provided API.\n" + % (self.namespace, self.namespace), + False, + ) + ) + self.outfile.write(" */\n") + self.outfile.write("\n") + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sObjectSkeletonClass:\n" + " * @parent_class: The parent class.\n" + " *\n" + " * Class structure for #%sObjectSkeleton.\n" + % (self.namespace, self.namespace), + False, + ) + ) + self.outfile.write(" */\n") + self.outfile.write("\n") # class boilerplate - self.outfile.write('static void\n' - '%sobject_skeleton__%sobject_iface_init (%sObjectIface *iface G_GNUC_UNUSED)\n' - '{\n' - '}\n' - '\n' - %(self.ns_lower, self.ns_lower, self.namespace)) - self.outfile.write('\n') - self.outfile.write('static void\n' - '%sobject_skeleton__g_dbus_object_iface_init (GDBusObjectIface *iface)\n' - '{\n' - ' iface->interface_added = %sobject_notify;\n' - ' iface->interface_removed = %sobject_notify;\n' - '}\n' - '\n' - %(self.ns_lower, self.ns_lower, self.ns_lower)) - self.outfile.write('G_DEFINE_TYPE_WITH_CODE (%sObjectSkeleton, %sobject_skeleton, G_TYPE_DBUS_OBJECT_SKELETON,\n' - ' G_IMPLEMENT_INTERFACE (%sTYPE_OBJECT, %sobject_skeleton__%sobject_iface_init)\n' - ' G_IMPLEMENT_INTERFACE (G_TYPE_DBUS_OBJECT, %sobject_skeleton__g_dbus_object_iface_init))\n' - '\n' - %(self.namespace, self.ns_lower, self.ns_upper, self.ns_lower, self.ns_lower, self.ns_lower)) + self.outfile.write( + "static void\n" + "%sobject_skeleton__%sobject_iface_init (%sObjectIface *iface G_GNUC_UNUSED)\n" + "{\n" + "}\n" + "\n" % (self.ns_lower, self.ns_lower, self.namespace) + ) + self.outfile.write("\n") + self.outfile.write( + "static void\n" + "%sobject_skeleton__g_dbus_object_iface_init (GDBusObjectIface *iface)\n" + "{\n" + " iface->interface_added = %sobject_notify;\n" + " iface->interface_removed = %sobject_notify;\n" + "}\n" + "\n" % (self.ns_lower, self.ns_lower, self.ns_lower) + ) + self.outfile.write( + "G_DEFINE_TYPE_WITH_CODE (%sObjectSkeleton, %sobject_skeleton, G_TYPE_DBUS_OBJECT_SKELETON,\n" + " G_IMPLEMENT_INTERFACE (%sTYPE_OBJECT, %sobject_skeleton__%sobject_iface_init)\n" + " G_IMPLEMENT_INTERFACE (G_TYPE_DBUS_OBJECT, %sobject_skeleton__g_dbus_object_iface_init))\n" + "\n" + % ( + self.namespace, + self.ns_lower, + self.ns_upper, + self.ns_lower, + self.ns_lower, + self.ns_lower, + ) + ) # class boilerplate - self.outfile.write('static void\n' - '%sobject_skeleton_init (%sObjectSkeleton *object G_GNUC_UNUSED)\n' - '{\n' - '}\n' - '\n'%(self.ns_lower, self.namespace)) - self.outfile.write('static void\n' - '%sobject_skeleton_set_property (GObject *gobject,\n' - ' guint prop_id,\n' - ' const GValue *value,\n' - ' GParamSpec *pspec)\n' - '{\n' - ' %sObjectSkeleton *object = %sOBJECT_SKELETON (gobject);\n' - ' GDBusInterfaceSkeleton *interface;\n' - '\n' - ' switch (prop_id)\n' - ' {\n' - %(self.ns_lower, self.namespace, self.ns_upper)) + self.outfile.write( + "static void\n" + "%sobject_skeleton_init (%sObjectSkeleton *object G_GNUC_UNUSED)\n" + "{\n" + "}\n" + "\n" % (self.ns_lower, self.namespace) + ) + self.outfile.write( + "static void\n" + "%sobject_skeleton_set_property (GObject *gobject,\n" + " guint prop_id,\n" + " const GValue *value,\n" + " GParamSpec *pspec)\n" + "{\n" + " %sObjectSkeleton *object = %sOBJECT_SKELETON (gobject);\n" + " GDBusInterfaceSkeleton *interface;\n" + "\n" + " switch (prop_id)\n" + " {\n" % (self.ns_lower, self.namespace, self.ns_upper) + ) n = 1 for i in self.ifaces: - self.outfile.write(' case %d:\n' - ' interface = g_value_get_object (value);\n' - ' if (interface != NULL)\n' - ' {\n' - ' g_warn_if_fail (%sIS_%s (interface));\n' - ' g_dbus_object_skeleton_add_interface (G_DBUS_OBJECT_SKELETON (object), interface);\n' - ' }\n' - ' else\n' - ' {\n' - ' g_dbus_object_skeleton_remove_interface_by_name (G_DBUS_OBJECT_SKELETON (object), "%s");\n' - ' }\n' - ' break;\n' - '\n' - %(n, self.ns_upper, i.name_upper, i.name)) + self.outfile.write( + " case %d:\n" + " interface = g_value_get_object (value);\n" + " if (interface != NULL)\n" + " {\n" + " g_warn_if_fail (%sIS_%s (interface));\n" + " g_dbus_object_skeleton_add_interface (G_DBUS_OBJECT_SKELETON (object), interface);\n" + " }\n" + " else\n" + " {\n" + ' g_dbus_object_skeleton_remove_interface_by_name (G_DBUS_OBJECT_SKELETON (object), "%s");\n' + " }\n" + " break;\n" + "\n" % (n, self.ns_upper, i.name_upper, i.name) + ) n += 1 - self.outfile.write(' default:\n' - ' G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, prop_id, pspec);\n' - ' break;\n' - ' }\n' - '}\n' - '\n'%()) - self.outfile.write('static void\n' - '%sobject_skeleton_get_property (GObject *gobject,\n' - ' guint prop_id,\n' - ' GValue *value,\n' - ' GParamSpec *pspec)\n' - '{\n' - ' %sObjectSkeleton *object = %sOBJECT_SKELETON (gobject);\n' - ' GDBusInterface *interface;\n' - '\n' - ' switch (prop_id)\n' - ' {\n' - %(self.ns_lower, self.namespace, self.ns_upper)) + self.outfile.write( + " default:\n" + " G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, prop_id, pspec);\n" + " break;\n" + " }\n" + "}\n" + "\n" % () + ) + self.outfile.write( + "static void\n" + "%sobject_skeleton_get_property (GObject *gobject,\n" + " guint prop_id,\n" + " GValue *value,\n" + " GParamSpec *pspec)\n" + "{\n" + " %sObjectSkeleton *object = %sOBJECT_SKELETON (gobject);\n" + " GDBusInterface *interface;\n" + "\n" + " switch (prop_id)\n" + " {\n" % (self.ns_lower, self.namespace, self.ns_upper) + ) n = 1 for i in self.ifaces: - self.outfile.write(' case %d:\n' - ' interface = g_dbus_object_get_interface (G_DBUS_OBJECT (object), "%s");\n' - ' g_value_take_object (value, interface);\n' - ' break;\n' - '\n' - %(n, i.name)) + self.outfile.write( + " case %d:\n" + ' interface = g_dbus_object_get_interface (G_DBUS_OBJECT (object), "%s");\n' + " g_value_take_object (value, interface);\n" + " break;\n" + "\n" % (n, i.name) + ) n += 1 - self.outfile.write(' default:\n' - ' G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, prop_id, pspec);\n' - ' break;\n' - ' }\n' - '}\n' - '\n'%()) - self.outfile.write('static void\n' - '%sobject_skeleton_class_init (%sObjectSkeletonClass *klass)\n' - '{\n' - ' GObjectClass *gobject_class = G_OBJECT_CLASS (klass);\n' - '\n' - ' gobject_class->set_property = %sobject_skeleton_set_property;\n' - ' gobject_class->get_property = %sobject_skeleton_get_property;\n' - '\n' - %(self.ns_lower, self.namespace, self.ns_lower, self.ns_lower)) + self.outfile.write( + " default:\n" + " G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, prop_id, pspec);\n" + " break;\n" + " }\n" + "}\n" + "\n" % () + ) + self.outfile.write( + "static void\n" + "%sobject_skeleton_class_init (%sObjectSkeletonClass *klass)\n" + "{\n" + " GObjectClass *gobject_class = G_OBJECT_CLASS (klass);\n" + "\n" + " gobject_class->set_property = %sobject_skeleton_set_property;\n" + " gobject_class->get_property = %sobject_skeleton_get_property;\n" + "\n" % (self.ns_lower, self.namespace, self.ns_lower, self.ns_lower) + ) n = 1 for i in self.ifaces: - self.outfile.write(' g_object_class_override_property (gobject_class, %d, "%s");' - '\n' - %(n, i.name_hyphen)) + self.outfile.write( + ' g_object_class_override_property (gobject_class, %d, "%s");' + "\n" % (n, i.name_hyphen) + ) n += 1 - self.outfile.write('}\n' - '\n') - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sobject_skeleton_new:\n' - ' * @object_path: An object path.\n' - ' *\n' - ' * Creates a new skeleton object.\n' - ' *\n' - ' * Returns: (transfer full): The skeleton object.\n' - ' */\n' - %(self.ns_lower), False)) - self.outfile.write('%sObjectSkeleton *\n' - '%sobject_skeleton_new (const gchar *object_path)\n' - '{\n' - ' g_return_val_if_fail (g_variant_is_object_path (object_path), NULL);\n' - ' return %sOBJECT_SKELETON (g_object_new (%sTYPE_OBJECT_SKELETON, "g-object-path", object_path, NULL));\n' - '}\n' - '\n'%(self.namespace, self.ns_lower, self.ns_upper, self.ns_upper)) + self.outfile.write("}\n" "\n") + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sobject_skeleton_new:\n" + " * @object_path: An object path.\n" + " *\n" + " * Creates a new skeleton object.\n" + " *\n" + " * Returns: (transfer full): The skeleton object.\n" + " */\n" % (self.ns_lower), + False, + ) + ) + self.outfile.write( + "%sObjectSkeleton *\n" + "%sobject_skeleton_new (const gchar *object_path)\n" + "{\n" + " g_return_val_if_fail (g_variant_is_object_path (object_path), NULL);\n" + ' return %sOBJECT_SKELETON (g_object_new (%sTYPE_OBJECT_SKELETON, "g-object-path", object_path, NULL));\n' + "}\n" + "\n" % (self.namespace, self.ns_lower, self.ns_upper, self.ns_upper) + ) for i in self.ifaces: - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sobject_skeleton_set_%s:\n' - ' * @object: A #%sObjectSkeleton.\n' - ' * @interface_: (nullable): A #%s or %%NULL to clear the interface.\n' - ' *\n' - ' * Sets the #%s instance for the D-Bus interface #%s on @object.\n' - %(self.ns_lower, i.name_upper.lower(), self.namespace, i.camel_name, i.camel_name, i.name), False)) + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sobject_skeleton_set_%s:\n" + " * @object: A #%sObjectSkeleton.\n" + " * @interface_: (nullable): A #%s or %%NULL to clear the interface.\n" + " *\n" + " * Sets the #%s instance for the D-Bus interface #%s on @object.\n" + % ( + self.ns_lower, + i.name_upper.lower(), + self.namespace, + i.camel_name, + i.camel_name, + i.name, + ), + False, + ) + ) self.write_gtkdoc_deprecated_and_since_and_close(i, self.outfile, 0) - self.outfile.write('void %sobject_skeleton_set_%s (%sObjectSkeleton *object, %s *interface_)\n' - %(self.ns_lower, i.name_upper.lower(), self.namespace, i.camel_name)) - self.outfile.write('{\n' - ' g_object_set (G_OBJECT (object), "%s", interface_, NULL);\n' - '}\n' - '\n' - %(i.name_hyphen)) - self.outfile.write('\n') - + self.outfile.write( + "void %sobject_skeleton_set_%s (%sObjectSkeleton *object, %s *interface_)\n" + % (self.ns_lower, i.name_upper.lower(), self.namespace, i.camel_name) + ) + self.outfile.write( + "{\n" + ' g_object_set (G_OBJECT (object), "%s", interface_, NULL);\n' + "}\n" + "\n" % (i.name_hyphen) + ) + self.outfile.write("\n") def generate_object_manager_client(self): - self.outfile.write('/* ------------------------------------------------------------------------\n' - ' * Code for ObjectManager client\n' - ' * ------------------------------------------------------------------------\n' - ' */\n' - '\n') - - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * SECTION:%sObjectManagerClient\n' - ' * @title: %sObjectManagerClient\n' - ' * @short_description: Generated GDBusObjectManagerClient type\n' - ' *\n' - ' * This section contains a #GDBusObjectManagerClient that uses %sobject_manager_client_get_proxy_type() as the #GDBusProxyTypeFunc.\n' - ' */\n' - %(self.namespace, self.namespace, self.ns_lower), False)) - self.outfile.write('\n') - - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sObjectManagerClient:\n' - ' *\n' - ' * The #%sObjectManagerClient structure contains only private data and should only be accessed using the provided API.\n' - %(self.namespace, self.namespace), False)) - self.outfile.write(' */\n') - self.outfile.write('\n') - - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sObjectManagerClientClass:\n' - ' * @parent_class: The parent class.\n' - ' *\n' - ' * Class structure for #%sObjectManagerClient.\n' - %(self.namespace, self.namespace), False)) - self.outfile.write(' */\n') - self.outfile.write('\n') + self.outfile.write( + "/* ------------------------------------------------------------------------\n" + " * Code for ObjectManager client\n" + " * ------------------------------------------------------------------------\n" + " */\n" + "\n" + ) + + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * SECTION:%sObjectManagerClient\n" + " * @title: %sObjectManagerClient\n" + " * @short_description: Generated GDBusObjectManagerClient type\n" + " *\n" + " * This section contains a #GDBusObjectManagerClient that uses %sobject_manager_client_get_proxy_type() as the #GDBusProxyTypeFunc.\n" + " */\n" % (self.namespace, self.namespace, self.ns_lower), + False, + ) + ) + self.outfile.write("\n") + + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sObjectManagerClient:\n" + " *\n" + " * The #%sObjectManagerClient structure contains only private data and should only be accessed using the provided API.\n" + % (self.namespace, self.namespace), + False, + ) + ) + self.outfile.write(" */\n") + self.outfile.write("\n") + + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sObjectManagerClientClass:\n" + " * @parent_class: The parent class.\n" + " *\n" + " * Class structure for #%sObjectManagerClient.\n" + % (self.namespace, self.namespace), + False, + ) + ) + self.outfile.write(" */\n") + self.outfile.write("\n") # class boilerplate - self.outfile.write('G_DEFINE_TYPE (%sObjectManagerClient, %sobject_manager_client, G_TYPE_DBUS_OBJECT_MANAGER_CLIENT)\n' - '\n' - %(self.namespace, self.ns_lower)) + self.outfile.write( + "G_DEFINE_TYPE (%sObjectManagerClient, %sobject_manager_client, G_TYPE_DBUS_OBJECT_MANAGER_CLIENT)\n" + "\n" % (self.namespace, self.ns_lower) + ) # class boilerplate - self.outfile.write('static void\n' - '%sobject_manager_client_init (%sObjectManagerClient *manager G_GNUC_UNUSED)\n' - '{\n' - '}\n' - '\n'%(self.ns_lower, self.namespace)) - self.outfile.write('static void\n' - '%sobject_manager_client_class_init (%sObjectManagerClientClass *klass G_GNUC_UNUSED)\n' - '{\n' - '}\n' - '\n'%(self.ns_lower, self.namespace)) - - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sobject_manager_client_get_proxy_type:\n' - ' * @manager: A #GDBusObjectManagerClient.\n' - ' * @object_path: The object path of the remote object (unused).\n' - ' * @interface_name: (nullable): Interface name of the remote object or %%NULL to get the object proxy #GType.\n' - ' * @user_data: User data (unused).\n' - ' *\n' - ' * A #GDBusProxyTypeFunc that maps @interface_name to the generated #GDBusObjectProxy derived and #GDBusProxy derived types.\n' - ' *\n' - ' * Returns: A #GDBusProxy derived #GType if @interface_name is not %%NULL, otherwise the #GType for #%sObjectProxy.\n' - %(self.ns_lower, self.namespace), False)) - self.outfile.write(' */\n') - self.outfile.write('GType\n' - '%sobject_manager_client_get_proxy_type (GDBusObjectManagerClient *manager G_GNUC_UNUSED, const gchar *object_path G_GNUC_UNUSED, const gchar *interface_name, gpointer user_data G_GNUC_UNUSED)\n' - '{\n' - %(self.ns_lower)) - self.outfile.write(' static gsize once_init_value = 0;\n' - ' static GHashTable *lookup_hash;\n' - ' GType ret;\n' - '\n' - ' if (interface_name == NULL)\n' - ' return %sTYPE_OBJECT_PROXY;\n' - ' if (g_once_init_enter (&once_init_value))\n' - ' {\n' - ' lookup_hash = g_hash_table_new (g_str_hash, g_str_equal);\n' - %(self.ns_upper)) + self.outfile.write( + "static void\n" + "%sobject_manager_client_init (%sObjectManagerClient *manager G_GNUC_UNUSED)\n" + "{\n" + "}\n" + "\n" % (self.ns_lower, self.namespace) + ) + self.outfile.write( + "static void\n" + "%sobject_manager_client_class_init (%sObjectManagerClientClass *klass G_GNUC_UNUSED)\n" + "{\n" + "}\n" + "\n" % (self.ns_lower, self.namespace) + ) + + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sobject_manager_client_get_proxy_type:\n" + " * @manager: A #GDBusObjectManagerClient.\n" + " * @object_path: The object path of the remote object (unused).\n" + " * @interface_name: (nullable): Interface name of the remote object or %%NULL to get the object proxy #GType.\n" + " * @user_data: User data (unused).\n" + " *\n" + " * A #GDBusProxyTypeFunc that maps @interface_name to the generated #GDBusObjectProxy derived and #GDBusProxy derived types.\n" + " *\n" + " * Returns: A #GDBusProxy derived #GType if @interface_name is not %%NULL, otherwise the #GType for #%sObjectProxy.\n" + % (self.ns_lower, self.namespace), + False, + ) + ) + self.outfile.write(" */\n") + self.outfile.write( + "GType\n" + "%sobject_manager_client_get_proxy_type (GDBusObjectManagerClient *manager G_GNUC_UNUSED, const gchar *object_path G_GNUC_UNUSED, const gchar *interface_name, gpointer user_data G_GNUC_UNUSED)\n" + "{\n" % (self.ns_lower) + ) + self.outfile.write( + " static gsize once_init_value = 0;\n" + " static GHashTable *lookup_hash;\n" + " GType ret;\n" + "\n" + " if (interface_name == NULL)\n" + " return %sTYPE_OBJECT_PROXY;\n" + " if (g_once_init_enter (&once_init_value))\n" + " {\n" + " lookup_hash = g_hash_table_new (g_str_hash, g_str_equal);\n" + % (self.ns_upper) + ) for i in self.ifaces: - self.outfile.write(' g_hash_table_insert (lookup_hash, (gpointer) "%s", GSIZE_TO_POINTER (%sTYPE_%s_PROXY));\n' - %(i.name, i.ns_upper, i.name_upper)) - self.outfile.write(' g_once_init_leave (&once_init_value, 1);\n' - ' }\n') - self.outfile.write(' ret = (GType) GPOINTER_TO_SIZE (g_hash_table_lookup (lookup_hash, interface_name));\n' - ' if (ret == (GType) 0)\n' - ' ret = G_TYPE_DBUS_PROXY;\n') - self.outfile.write(' return ret;\n' - '}\n' - '\n') + self.outfile.write( + ' g_hash_table_insert (lookup_hash, (gpointer) "%s", GSIZE_TO_POINTER (%sTYPE_%s_PROXY));\n' + % (i.name, i.ns_upper, i.name_upper) + ) + self.outfile.write(" g_once_init_leave (&once_init_value, 1);\n" " }\n") + self.outfile.write( + " ret = (GType) GPOINTER_TO_SIZE (g_hash_table_lookup (lookup_hash, interface_name));\n" + " if (ret == (GType) 0)\n" + " ret = G_TYPE_DBUS_PROXY;\n" + ) + self.outfile.write(" return ret;\n" "}\n" "\n") # constructors - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sobject_manager_client_new:\n' - ' * @connection: A #GDBusConnection.\n' - ' * @flags: Flags from the #GDBusObjectManagerClientFlags enumeration.\n' - ' * @name: (nullable): A bus name (well-known or unique) or %%NULL if @connection is not a message bus connection.\n' - ' * @object_path: An object path.\n' - ' * @cancellable: (nullable): A #GCancellable or %%NULL.\n' - ' * @callback: A #GAsyncReadyCallback to call when the request is satisfied.\n' - ' * @user_data: User data to pass to @callback.\n' - ' *\n' - ' * Asynchronously creates #GDBusObjectManagerClient using %sobject_manager_client_get_proxy_type() as the #GDBusProxyTypeFunc. See g_dbus_object_manager_client_new() for more details.\n' - ' *\n' - ' * When the operation is finished, @callback will be invoked in the thread-default main loop of the thread you are calling this method from (see g_main_context_push_thread_default()).\n' - ' * You can then call %sobject_manager_client_new_finish() to get the result of the operation.\n' - ' *\n' - ' * See %sobject_manager_client_new_sync() for the synchronous, blocking version of this constructor.\n' - %(self.ns_lower, self.ns_lower, self.ns_lower, self.ns_lower), False)) - self.outfile.write(' */\n') - self.outfile.write('void\n' - '%sobject_manager_client_new (\n' - ' GDBusConnection *connection,\n' - ' GDBusObjectManagerClientFlags flags,\n' - ' const gchar *name,\n' - ' const gchar *object_path,\n' - ' GCancellable *cancellable,\n' - ' GAsyncReadyCallback callback,\n' - ' gpointer user_data)\n' - '{\n' - ' g_async_initable_new_async (%sTYPE_OBJECT_MANAGER_CLIENT, G_PRIORITY_DEFAULT, cancellable, callback, user_data, "flags", flags, "name", name, "connection", connection, "object-path", object_path, "get-proxy-type-func", %sobject_manager_client_get_proxy_type, NULL);\n' - '}\n' - '\n' - %(self.ns_lower, self.ns_upper, self.ns_lower)) - self.outfile.write('/**\n' - ' * %sobject_manager_client_new_finish:\n' - ' * @res: The #GAsyncResult obtained from the #GAsyncReadyCallback passed to %sobject_manager_client_new().\n' - ' * @error: Return location for error or %%NULL\n' - ' *\n' - ' * Finishes an operation started with %sobject_manager_client_new().\n' - ' *\n' - ' * Returns: (transfer full) (type %sObjectManagerClient): The constructed object manager client or %%NULL if @error is set.\n' - %(self.ns_lower, self.ns_lower, self.ns_lower, self.namespace)) - self.outfile.write(' */\n') - self.outfile.write('GDBusObjectManager *\n' - '%sobject_manager_client_new_finish (\n' - ' GAsyncResult *res,\n' - ' GError **error)\n' - '{\n' - ' GObject *ret;\n' - ' GObject *source_object;\n' - ' source_object = g_async_result_get_source_object (res);\n' - ' ret = g_async_initable_new_finish (G_ASYNC_INITABLE (source_object), res, error);\n' - ' g_object_unref (source_object);\n' - ' if (ret != NULL)\n' - ' return G_DBUS_OBJECT_MANAGER (ret);\n' - ' else\n' - ' return NULL;\n' - '}\n' - '\n' - %(self.ns_lower)) - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sobject_manager_client_new_sync:\n' - ' * @connection: A #GDBusConnection.\n' - ' * @flags: Flags from the #GDBusObjectManagerClientFlags enumeration.\n' - ' * @name: (nullable): A bus name (well-known or unique) or %%NULL if @connection is not a message bus connection.\n' - ' * @object_path: An object path.\n' - ' * @cancellable: (nullable): A #GCancellable or %%NULL.\n' - ' * @error: Return location for error or %%NULL\n' - ' *\n' - ' * Synchronously creates #GDBusObjectManagerClient using %sobject_manager_client_get_proxy_type() as the #GDBusProxyTypeFunc. See g_dbus_object_manager_client_new_sync() for more details.\n' - ' *\n' - ' * The calling thread is blocked until a reply is received.\n' - ' *\n' - ' * See %sobject_manager_client_new() for the asynchronous version of this constructor.\n' - ' *\n' - ' * Returns: (transfer full) (type %sObjectManagerClient): The constructed object manager client or %%NULL if @error is set.\n' - %(self.ns_lower, self.ns_lower, self.ns_lower, self.namespace), False)) - self.outfile.write(' */\n') - self.outfile.write('GDBusObjectManager *\n' - '%sobject_manager_client_new_sync (\n' - ' GDBusConnection *connection,\n' - ' GDBusObjectManagerClientFlags flags,\n' - ' const gchar *name,\n' - ' const gchar *object_path,\n' - ' GCancellable *cancellable,\n' - ' GError **error)\n' - '{\n' - ' GInitable *ret;\n' - ' ret = g_initable_new (%sTYPE_OBJECT_MANAGER_CLIENT, cancellable, error, "flags", flags, "name", name, "connection", connection, "object-path", object_path, "get-proxy-type-func", %sobject_manager_client_get_proxy_type, NULL);\n' - ' if (ret != NULL)\n' - ' return G_DBUS_OBJECT_MANAGER (ret);\n' - ' else\n' - ' return NULL;\n' - '}\n' - '\n' - %(self.ns_lower, self.ns_upper, self.ns_lower)) - self.outfile.write('\n') - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sobject_manager_client_new_for_bus:\n' - ' * @bus_type: A #GBusType.\n' - ' * @flags: Flags from the #GDBusObjectManagerClientFlags enumeration.\n' - ' * @name: A bus name (well-known or unique).\n' - ' * @object_path: An object path.\n' - ' * @cancellable: (nullable): A #GCancellable or %%NULL.\n' - ' * @callback: A #GAsyncReadyCallback to call when the request is satisfied.\n' - ' * @user_data: User data to pass to @callback.\n' - ' *\n' - ' * Like %sobject_manager_client_new() but takes a #GBusType instead of a #GDBusConnection.\n' - ' *\n' - ' * When the operation is finished, @callback will be invoked in the thread-default main loop of the thread you are calling this method from (see g_main_context_push_thread_default()).\n' - ' * You can then call %sobject_manager_client_new_for_bus_finish() to get the result of the operation.\n' - ' *\n' - ' * See %sobject_manager_client_new_for_bus_sync() for the synchronous, blocking version of this constructor.\n' - %(self.ns_lower, self.ns_lower, self.ns_lower, self.ns_lower), False)) - self.outfile.write(' */\n') - self.outfile.write('void\n' - '%sobject_manager_client_new_for_bus (\n' - ' GBusType bus_type,\n' - ' GDBusObjectManagerClientFlags flags,\n' - ' const gchar *name,\n' - ' const gchar *object_path,\n' - ' GCancellable *cancellable,\n' - ' GAsyncReadyCallback callback,\n' - ' gpointer user_data)\n' - '{\n' - ' g_async_initable_new_async (%sTYPE_OBJECT_MANAGER_CLIENT, G_PRIORITY_DEFAULT, cancellable, callback, user_data, "flags", flags, "name", name, "bus-type", bus_type, "object-path", object_path, "get-proxy-type-func", %sobject_manager_client_get_proxy_type, NULL);\n' - '}\n' - '\n' - %(self.ns_lower, self.ns_upper, self.ns_lower)) - self.outfile.write('/**\n' - ' * %sobject_manager_client_new_for_bus_finish:\n' - ' * @res: The #GAsyncResult obtained from the #GAsyncReadyCallback passed to %sobject_manager_client_new_for_bus().\n' - ' * @error: Return location for error or %%NULL\n' - ' *\n' - ' * Finishes an operation started with %sobject_manager_client_new_for_bus().\n' - ' *\n' - ' * Returns: (transfer full) (type %sObjectManagerClient): The constructed object manager client or %%NULL if @error is set.\n' - %(self.ns_lower, self.ns_lower, self.ns_lower, self.namespace)) - self.outfile.write(' */\n') - self.outfile.write('GDBusObjectManager *\n' - '%sobject_manager_client_new_for_bus_finish (\n' - ' GAsyncResult *res,\n' - ' GError **error)\n' - '{\n' - ' GObject *ret;\n' - ' GObject *source_object;\n' - ' source_object = g_async_result_get_source_object (res);\n' - ' ret = g_async_initable_new_finish (G_ASYNC_INITABLE (source_object), res, error);\n' - ' g_object_unref (source_object);\n' - ' if (ret != NULL)\n' - ' return G_DBUS_OBJECT_MANAGER (ret);\n' - ' else\n' - ' return NULL;\n' - '}\n' - '\n' - %(self.ns_lower)) - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * %sobject_manager_client_new_for_bus_sync:\n' - ' * @bus_type: A #GBusType.\n' - ' * @flags: Flags from the #GDBusObjectManagerClientFlags enumeration.\n' - ' * @name: A bus name (well-known or unique).\n' - ' * @object_path: An object path.\n' - ' * @cancellable: (nullable): A #GCancellable or %%NULL.\n' - ' * @error: Return location for error or %%NULL\n' - ' *\n' - ' * Like %sobject_manager_client_new_sync() but takes a #GBusType instead of a #GDBusConnection.\n' - ' *\n' - ' * The calling thread is blocked until a reply is received.\n' - ' *\n' - ' * See %sobject_manager_client_new_for_bus() for the asynchronous version of this constructor.\n' - ' *\n' - ' * Returns: (transfer full) (type %sObjectManagerClient): The constructed object manager client or %%NULL if @error is set.\n' - %(self.ns_lower, self.ns_lower, self.ns_lower, self.namespace), False)) - self.outfile.write(' */\n') - self.outfile.write('GDBusObjectManager *\n' - '%sobject_manager_client_new_for_bus_sync (\n' - ' GBusType bus_type,\n' - ' GDBusObjectManagerClientFlags flags,\n' - ' const gchar *name,\n' - ' const gchar *object_path,\n' - ' GCancellable *cancellable,\n' - ' GError **error)\n' - '{\n' - ' GInitable *ret;\n' - ' ret = g_initable_new (%sTYPE_OBJECT_MANAGER_CLIENT, cancellable, error, "flags", flags, "name", name, "bus-type", bus_type, "object-path", object_path, "get-proxy-type-func", %sobject_manager_client_get_proxy_type, NULL);\n' - ' if (ret != NULL)\n' - ' return G_DBUS_OBJECT_MANAGER (ret);\n' - ' else\n' - ' return NULL;\n' - '}\n' - '\n' - %(self.ns_lower, self.ns_upper, self.ns_lower)) - self.outfile.write('\n') + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sobject_manager_client_new:\n" + " * @connection: A #GDBusConnection.\n" + " * @flags: Flags from the #GDBusObjectManagerClientFlags enumeration.\n" + " * @name: (nullable): A bus name (well-known or unique) or %%NULL if @connection is not a message bus connection.\n" + " * @object_path: An object path.\n" + " * @cancellable: (nullable): A #GCancellable or %%NULL.\n" + " * @callback: A #GAsyncReadyCallback to call when the request is satisfied.\n" + " * @user_data: User data to pass to @callback.\n" + " *\n" + " * Asynchronously creates #GDBusObjectManagerClient using %sobject_manager_client_get_proxy_type() as the #GDBusProxyTypeFunc. See g_dbus_object_manager_client_new() for more details.\n" + " *\n" + " * When the operation is finished, @callback will be invoked in the thread-default main loop of the thread you are calling this method from (see g_main_context_push_thread_default()).\n" + " * You can then call %sobject_manager_client_new_finish() to get the result of the operation.\n" + " *\n" + " * See %sobject_manager_client_new_sync() for the synchronous, blocking version of this constructor.\n" + % (self.ns_lower, self.ns_lower, self.ns_lower, self.ns_lower), + False, + ) + ) + self.outfile.write(" */\n") + self.outfile.write( + "void\n" + "%sobject_manager_client_new (\n" + " GDBusConnection *connection,\n" + " GDBusObjectManagerClientFlags flags,\n" + " const gchar *name,\n" + " const gchar *object_path,\n" + " GCancellable *cancellable,\n" + " GAsyncReadyCallback callback,\n" + " gpointer user_data)\n" + "{\n" + ' g_async_initable_new_async (%sTYPE_OBJECT_MANAGER_CLIENT, G_PRIORITY_DEFAULT, cancellable, callback, user_data, "flags", flags, "name", name, "connection", connection, "object-path", object_path, "get-proxy-type-func", %sobject_manager_client_get_proxy_type, NULL);\n' + "}\n" + "\n" % (self.ns_lower, self.ns_upper, self.ns_lower) + ) + self.outfile.write( + "/**\n" + " * %sobject_manager_client_new_finish:\n" + " * @res: The #GAsyncResult obtained from the #GAsyncReadyCallback passed to %sobject_manager_client_new().\n" + " * @error: Return location for error or %%NULL\n" + " *\n" + " * Finishes an operation started with %sobject_manager_client_new().\n" + " *\n" + " * Returns: (transfer full) (type %sObjectManagerClient): The constructed object manager client or %%NULL if @error is set.\n" + % (self.ns_lower, self.ns_lower, self.ns_lower, self.namespace) + ) + self.outfile.write(" */\n") + self.outfile.write( + "GDBusObjectManager *\n" + "%sobject_manager_client_new_finish (\n" + " GAsyncResult *res,\n" + " GError **error)\n" + "{\n" + " GObject *ret;\n" + " GObject *source_object;\n" + " source_object = g_async_result_get_source_object (res);\n" + " ret = g_async_initable_new_finish (G_ASYNC_INITABLE (source_object), res, error);\n" + " g_object_unref (source_object);\n" + " if (ret != NULL)\n" + " return G_DBUS_OBJECT_MANAGER (ret);\n" + " else\n" + " return NULL;\n" + "}\n" + "\n" % (self.ns_lower) + ) + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sobject_manager_client_new_sync:\n" + " * @connection: A #GDBusConnection.\n" + " * @flags: Flags from the #GDBusObjectManagerClientFlags enumeration.\n" + " * @name: (nullable): A bus name (well-known or unique) or %%NULL if @connection is not a message bus connection.\n" + " * @object_path: An object path.\n" + " * @cancellable: (nullable): A #GCancellable or %%NULL.\n" + " * @error: Return location for error or %%NULL\n" + " *\n" + " * Synchronously creates #GDBusObjectManagerClient using %sobject_manager_client_get_proxy_type() as the #GDBusProxyTypeFunc. See g_dbus_object_manager_client_new_sync() for more details.\n" + " *\n" + " * The calling thread is blocked until a reply is received.\n" + " *\n" + " * See %sobject_manager_client_new() for the asynchronous version of this constructor.\n" + " *\n" + " * Returns: (transfer full) (type %sObjectManagerClient): The constructed object manager client or %%NULL if @error is set.\n" + % (self.ns_lower, self.ns_lower, self.ns_lower, self.namespace), + False, + ) + ) + self.outfile.write(" */\n") + self.outfile.write( + "GDBusObjectManager *\n" + "%sobject_manager_client_new_sync (\n" + " GDBusConnection *connection,\n" + " GDBusObjectManagerClientFlags flags,\n" + " const gchar *name,\n" + " const gchar *object_path,\n" + " GCancellable *cancellable,\n" + " GError **error)\n" + "{\n" + " GInitable *ret;\n" + ' ret = g_initable_new (%sTYPE_OBJECT_MANAGER_CLIENT, cancellable, error, "flags", flags, "name", name, "connection", connection, "object-path", object_path, "get-proxy-type-func", %sobject_manager_client_get_proxy_type, NULL);\n' + " if (ret != NULL)\n" + " return G_DBUS_OBJECT_MANAGER (ret);\n" + " else\n" + " return NULL;\n" + "}\n" + "\n" % (self.ns_lower, self.ns_upper, self.ns_lower) + ) + self.outfile.write("\n") + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sobject_manager_client_new_for_bus:\n" + " * @bus_type: A #GBusType.\n" + " * @flags: Flags from the #GDBusObjectManagerClientFlags enumeration.\n" + " * @name: A bus name (well-known or unique).\n" + " * @object_path: An object path.\n" + " * @cancellable: (nullable): A #GCancellable or %%NULL.\n" + " * @callback: A #GAsyncReadyCallback to call when the request is satisfied.\n" + " * @user_data: User data to pass to @callback.\n" + " *\n" + " * Like %sobject_manager_client_new() but takes a #GBusType instead of a #GDBusConnection.\n" + " *\n" + " * When the operation is finished, @callback will be invoked in the thread-default main loop of the thread you are calling this method from (see g_main_context_push_thread_default()).\n" + " * You can then call %sobject_manager_client_new_for_bus_finish() to get the result of the operation.\n" + " *\n" + " * See %sobject_manager_client_new_for_bus_sync() for the synchronous, blocking version of this constructor.\n" + % (self.ns_lower, self.ns_lower, self.ns_lower, self.ns_lower), + False, + ) + ) + self.outfile.write(" */\n") + self.outfile.write( + "void\n" + "%sobject_manager_client_new_for_bus (\n" + " GBusType bus_type,\n" + " GDBusObjectManagerClientFlags flags,\n" + " const gchar *name,\n" + " const gchar *object_path,\n" + " GCancellable *cancellable,\n" + " GAsyncReadyCallback callback,\n" + " gpointer user_data)\n" + "{\n" + ' g_async_initable_new_async (%sTYPE_OBJECT_MANAGER_CLIENT, G_PRIORITY_DEFAULT, cancellable, callback, user_data, "flags", flags, "name", name, "bus-type", bus_type, "object-path", object_path, "get-proxy-type-func", %sobject_manager_client_get_proxy_type, NULL);\n' + "}\n" + "\n" % (self.ns_lower, self.ns_upper, self.ns_lower) + ) + self.outfile.write( + "/**\n" + " * %sobject_manager_client_new_for_bus_finish:\n" + " * @res: The #GAsyncResult obtained from the #GAsyncReadyCallback passed to %sobject_manager_client_new_for_bus().\n" + " * @error: Return location for error or %%NULL\n" + " *\n" + " * Finishes an operation started with %sobject_manager_client_new_for_bus().\n" + " *\n" + " * Returns: (transfer full) (type %sObjectManagerClient): The constructed object manager client or %%NULL if @error is set.\n" + % (self.ns_lower, self.ns_lower, self.ns_lower, self.namespace) + ) + self.outfile.write(" */\n") + self.outfile.write( + "GDBusObjectManager *\n" + "%sobject_manager_client_new_for_bus_finish (\n" + " GAsyncResult *res,\n" + " GError **error)\n" + "{\n" + " GObject *ret;\n" + " GObject *source_object;\n" + " source_object = g_async_result_get_source_object (res);\n" + " ret = g_async_initable_new_finish (G_ASYNC_INITABLE (source_object), res, error);\n" + " g_object_unref (source_object);\n" + " if (ret != NULL)\n" + " return G_DBUS_OBJECT_MANAGER (ret);\n" + " else\n" + " return NULL;\n" + "}\n" + "\n" % (self.ns_lower) + ) + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * %sobject_manager_client_new_for_bus_sync:\n" + " * @bus_type: A #GBusType.\n" + " * @flags: Flags from the #GDBusObjectManagerClientFlags enumeration.\n" + " * @name: A bus name (well-known or unique).\n" + " * @object_path: An object path.\n" + " * @cancellable: (nullable): A #GCancellable or %%NULL.\n" + " * @error: Return location for error or %%NULL\n" + " *\n" + " * Like %sobject_manager_client_new_sync() but takes a #GBusType instead of a #GDBusConnection.\n" + " *\n" + " * The calling thread is blocked until a reply is received.\n" + " *\n" + " * See %sobject_manager_client_new_for_bus() for the asynchronous version of this constructor.\n" + " *\n" + " * Returns: (transfer full) (type %sObjectManagerClient): The constructed object manager client or %%NULL if @error is set.\n" + % (self.ns_lower, self.ns_lower, self.ns_lower, self.namespace), + False, + ) + ) + self.outfile.write(" */\n") + self.outfile.write( + "GDBusObjectManager *\n" + "%sobject_manager_client_new_for_bus_sync (\n" + " GBusType bus_type,\n" + " GDBusObjectManagerClientFlags flags,\n" + " const gchar *name,\n" + " const gchar *object_path,\n" + " GCancellable *cancellable,\n" + " GError **error)\n" + "{\n" + " GInitable *ret;\n" + ' ret = g_initable_new (%sTYPE_OBJECT_MANAGER_CLIENT, cancellable, error, "flags", flags, "name", name, "bus-type", bus_type, "object-path", object_path, "get-proxy-type-func", %sobject_manager_client_get_proxy_type, NULL);\n' + " if (ret != NULL)\n" + " return G_DBUS_OBJECT_MANAGER (ret);\n" + " else\n" + " return NULL;\n" + "}\n" + "\n" % (self.ns_lower, self.ns_upper, self.ns_lower) + ) + self.outfile.write("\n") # --------------------------------------------------------------------------------------------------- def write_gtkdoc_deprecated_and_since_and_close(self, obj, f, indent): if len(obj.since) > 0: - f.write('%*s *\n' - '%*s * Since: %s\n' - %(indent, '', indent, '', obj.since)) + f.write("%*s *\n" "%*s * Since: %s\n" % (indent, "", indent, "", obj.since)) if obj.deprecated: if isinstance(obj, dbustypes.Interface): - thing = 'The D-Bus interface' + thing = "The D-Bus interface" elif isinstance(obj, dbustypes.Method): - thing = 'The D-Bus method' + thing = "The D-Bus method" elif isinstance(obj, dbustypes.Signal): - thing = 'The D-Bus signal' + thing = "The D-Bus signal" elif isinstance(obj, dbustypes.Property): - thing = 'The D-Bus property' + thing = "The D-Bus property" else: print_error('Cannot handle object "{}"'.format(obj)) - f.write(self.docbook_gen.expand( - '%*s *\n' - '%*s * Deprecated: %s has been deprecated.\n' - %(indent, '', indent, '', thing), False)) - f.write('%*s */\n'%(indent, '')) + f.write( + self.docbook_gen.expand( + "%*s *\n" + "%*s * Deprecated: %s has been deprecated.\n" + % (indent, "", indent, "", thing), + False, + ) + ) + f.write("%*s */\n" % (indent, "")) # --------------------------------------------------------------------------------------------------- def generate_interface_intro(self, i): - self.outfile.write('/* ------------------------------------------------------------------------\n' - ' * Code for interface %s\n' - ' * ------------------------------------------------------------------------\n' - ' */\n' - '\n'%(i.name)) - - self.outfile.write(self.docbook_gen.expand( - '/**\n' - ' * SECTION:%s\n' - ' * @title: %s\n' - ' * @short_description: Generated C code for the %s D-Bus interface\n' - ' *\n' - ' * This section contains code for working with the #%s D-Bus interface in C.\n' - ' */\n' - %(i.camel_name, i.camel_name, i.name, i.name), False)) - self.outfile.write('\n') + self.outfile.write( + "/* ------------------------------------------------------------------------\n" + " * Code for interface %s\n" + " * ------------------------------------------------------------------------\n" + " */\n" + "\n" % (i.name) + ) + + self.outfile.write( + self.docbook_gen.expand( + "/**\n" + " * SECTION:%s\n" + " * @title: %s\n" + " * @short_description: Generated C code for the %s D-Bus interface\n" + " *\n" + " * This section contains code for working with the #%s D-Bus interface in C.\n" + " */\n" % (i.camel_name, i.camel_name, i.name, i.name), + False, + ) + ) + self.outfile.write("\n") def generate(self): self.generate_body_preamble() diff --git a/gio/gdbus-2.0/codegen/codegen_docbook.py b/gio/gdbus-2.0/codegen/codegen_docbook.py index c08aa1a0e..54dd9decd 100644 --- a/gio/gdbus-2.0/codegen/codegen_docbook.py +++ b/gio/gdbus-2.0/codegen/codegen_docbook.py @@ -30,6 +30,7 @@ from . import parser # ---------------------------------------------------------------------------------------------------- + class DocbookCodeGenerator: def __init__(self, ifaces): self.ifaces = ifaces @@ -57,23 +58,36 @@ class DocbookCodeGenerator: max_signature_len = max(len(a.signature), max_signature_len) if in_synopsis: - self.out.write('<link linkend="gdbus-method-%s.%s">%s</link>%*s (' - %(utils.dots_to_hyphens(i.name), m.name, m.name, max_method_len - len(m.name), '')) + self.out.write( + '<link linkend="gdbus-method-%s.%s">%s</link>%*s (' + % ( + utils.dots_to_hyphens(i.name), + m.name, + m.name, + max_method_len - len(m.name), + "", + ) + ) else: - self.out.write('%s%*s (' - %(m.name, max_method_len - len(m.name), '')) + self.out.write("%s%*s (" % (m.name, max_method_len - len(m.name), "")) count = 0 for a in m.in_args: - if (count > 0): - self.out.write(',\n%*s'%(max_method_len + 2, '')) - self.out.write('IN %s%*s %s'%(a.signature, max_signature_len - len(a.signature), '', a.name)) + if count > 0: + self.out.write(",\n%*s" % (max_method_len + 2, "")) + self.out.write( + "IN %s%*s %s" + % (a.signature, max_signature_len - len(a.signature), "", a.name) + ) count = count + 1 for a in m.out_args: - if (count > 0): - self.out.write(',\n%*s'%(max_method_len + 2, '')) - self.out.write('OUT %s%*s %s'%(a.signature, max_signature_len - len(a.signature), '', a.name)) + if count > 0: + self.out.write(",\n%*s" % (max_method_len + 2, "")) + self.out.write( + "OUT %s%*s %s" + % (a.signature, max_signature_len - len(a.signature), "", a.name) + ) count = count + 1 - self.out.write(');\n') + self.out.write(");\n") def print_signal_prototype(self, i, s, in_synopsis): max_signal_len = 0 @@ -93,18 +107,28 @@ class DocbookCodeGenerator: max_signature_len = max(len(a.signature), max_signature_len) if in_synopsis: - self.out.write('<link linkend="gdbus-signal-%s.%s">%s</link>%*s (' - %(utils.dots_to_hyphens(i.name), s.name, s.name, max_signal_len - len(s.name), '')) + self.out.write( + '<link linkend="gdbus-signal-%s.%s">%s</link>%*s (' + % ( + utils.dots_to_hyphens(i.name), + s.name, + s.name, + max_signal_len - len(s.name), + "", + ) + ) else: - self.out.write('%s%*s (' - %(s.name, max_signal_len - len(s.name), '')) + self.out.write("%s%*s (" % (s.name, max_signal_len - len(s.name), "")) count = 0 for a in s.args: - if (count > 0): - self.out.write(',\n%*s'%(max_signal_len + 2, '')) - self.out.write('%s%*s %s'%(a.signature, max_signature_len - len(a.signature), '', a.name)) + if count > 0: + self.out.write(",\n%*s" % (max_signal_len + 2, "")) + self.out.write( + "%s%*s %s" + % (a.signature, max_signature_len - len(a.signature), "", a.name) + ) count = count + 1 - self.out.write(');\n') + self.out.write(");\n") def print_property_prototype(self, i, p, in_synopsis): max_property_len = 0 @@ -122,109 +146,181 @@ class DocbookCodeGenerator: max_signature_len = max(len(p.signature), max_signature_len) if in_synopsis: - self.out.write('<link linkend="gdbus-property-%s.%s">%s</link>%*s' - %(utils.dots_to_hyphens(i.name), p.name, p.name, max_property_len - len(p.name), '')) + self.out.write( + '<link linkend="gdbus-property-%s.%s">%s</link>%*s' + % ( + utils.dots_to_hyphens(i.name), + p.name, + p.name, + max_property_len - len(p.name), + "", + ) + ) else: - self.out.write('%s%*s' - %(p.name, max_property_len - len(p.name), '')) + self.out.write("%s%*s" % (p.name, max_property_len - len(p.name), "")) if p.readable and p.writable: - access = 'readwrite' + access = "readwrite" elif p.readable: - access = 'readable ' + access = "readable " else: - access = 'writable ' - self.out.write(' %s %s\n'%(access, p.signature)) - + access = "writable " + self.out.write(" %s %s\n" % (access, p.signature)) def print_synopsis_methods(self, i): - self.out.write(' <refsynopsisdiv role="synopsis">\n'%()) - self.out.write(' <title role="synopsis.title">Methods</title>\n'%()) - self.out.write(' <synopsis>\n'%()) + self.out.write(' <refsynopsisdiv role="synopsis">\n' % ()) + self.out.write(' <title role="synopsis.title">Methods</title>\n' % ()) + self.out.write(" <synopsis>\n" % ()) for m in i.methods: self.print_method_prototype(i, m, in_synopsis=True) - self.out.write('</synopsis>\n'%()) - self.out.write(' </refsynopsisdiv>\n'%()) + self.out.write("</synopsis>\n" % ()) + self.out.write(" </refsynopsisdiv>\n" % ()) def print_synopsis_signals(self, i): - self.out.write(' <refsect1 role="signal_proto">\n'%()) - self.out.write(' <title role="signal_proto.title">Signals</title>\n'%()) - self.out.write(' <synopsis>\n'%()) + self.out.write(' <refsect1 role="signal_proto">\n' % ()) + self.out.write(' <title role="signal_proto.title">Signals</title>\n' % ()) + self.out.write(" <synopsis>\n" % ()) for s in i.signals: self.print_signal_prototype(i, s, in_synopsis=True) - self.out.write('</synopsis>\n'%()) - self.out.write(' </refsect1>\n'%()) + self.out.write("</synopsis>\n" % ()) + self.out.write(" </refsect1>\n" % ()) def print_synopsis_properties(self, i): - self.out.write(' <refsect1 role="properties">\n'%()) - self.out.write(' <title role="properties.title">Properties</title>\n'%()) - self.out.write(' <synopsis>\n'%()) + self.out.write(' <refsect1 role="properties">\n' % ()) + self.out.write(' <title role="properties.title">Properties</title>\n' % ()) + self.out.write(" <synopsis>\n" % ()) for p in i.properties: self.print_property_prototype(i, p, in_synopsis=True) - self.out.write('</synopsis>\n'%()) - self.out.write(' </refsect1>\n'%()) + self.out.write("</synopsis>\n" % ()) + self.out.write(" </refsect1>\n" % ()) def print_method(self, i, m): - self.out.write('<refsect2 role="method" id="gdbus-method-%s.%s">\n'%(utils.dots_to_hyphens(i.name), m.name)) - self.out.write(' <title>The %s() method</title>\n'%(m.name)) - self.out.write(' <indexterm zone="gdbus-method-%s.%s"><primary sortas="%s.%s">%s.%s()</primary></indexterm>\n'%(utils.dots_to_hyphens(i.name), m.name, i.name_without_prefix, m.name, i.name, m.name)) - self.out.write('<programlisting>\n') + self.out.write( + '<refsect2 role="method" id="gdbus-method-%s.%s">\n' + % (utils.dots_to_hyphens(i.name), m.name) + ) + self.out.write(" <title>The %s() method</title>\n" % (m.name)) + self.out.write( + ' <indexterm zone="gdbus-method-%s.%s"><primary sortas="%s.%s">%s.%s()</primary></indexterm>\n' + % ( + utils.dots_to_hyphens(i.name), + m.name, + i.name_without_prefix, + m.name, + i.name, + m.name, + ) + ) + self.out.write("<programlisting>\n") self.print_method_prototype(i, m, in_synopsis=False) - self.out.write('</programlisting>\n') - self.out.write('%s\n'%(self.expand_paras(m.doc_string, True))) + self.out.write("</programlisting>\n") + self.out.write("%s\n" % (self.expand_paras(m.doc_string, True))) if m.in_args or m.out_args: self.out.write('<variablelist role="params">\n') for a in m.in_args: - self.out.write('<varlistentry>\n'%()) - self.out.write(' <term><literal>IN %s <parameter>%s</parameter></literal>:</term>\n'%(a.signature, a.name)) - self.out.write(' <listitem>%s</listitem>\n'%(self.expand_paras(a.doc_string, True))) - self.out.write('</varlistentry>\n'%()) + self.out.write("<varlistentry>\n" % ()) + self.out.write( + " <term><literal>IN %s <parameter>%s</parameter></literal>:</term>\n" + % (a.signature, a.name) + ) + self.out.write( + " <listitem>%s</listitem>\n" + % (self.expand_paras(a.doc_string, True)) + ) + self.out.write("</varlistentry>\n" % ()) for a in m.out_args: - self.out.write('<varlistentry>\n'%()) - self.out.write(' <term><literal>OUT %s <parameter>%s</parameter></literal>:</term>\n'%(a.signature, a.name)) - self.out.write(' <listitem>%s</listitem>\n'%(self.expand_paras(a.doc_string, True))) - self.out.write('</varlistentry>\n'%()) - self.out.write('</variablelist>\n') + self.out.write("<varlistentry>\n" % ()) + self.out.write( + " <term><literal>OUT %s <parameter>%s</parameter></literal>:</term>\n" + % (a.signature, a.name) + ) + self.out.write( + " <listitem>%s</listitem>\n" + % (self.expand_paras(a.doc_string, True)) + ) + self.out.write("</varlistentry>\n" % ()) + self.out.write("</variablelist>\n") if len(m.since) > 0: - self.out.write('<para role="since">Since %s</para>\n'%(m.since)) + self.out.write('<para role="since">Since %s</para>\n' % (m.since)) if m.deprecated: - self.out.write('<warning><para>The %s() method is deprecated.</para></warning>'%(m.name)) - self.out.write('</refsect2>\n') + self.out.write( + "<warning><para>The %s() method is deprecated.</para></warning>" + % (m.name) + ) + self.out.write("</refsect2>\n") def print_signal(self, i, s): - self.out.write('<refsect2 role="signal" id="gdbus-signal-%s.%s">\n'%(utils.dots_to_hyphens(i.name), s.name)) - self.out.write(' <title>The "%s" signal</title>\n'%(s.name)) - self.out.write(' <indexterm zone="gdbus-signal-%s.%s"><primary sortas="%s::%s">%s::%s</primary></indexterm>\n'%(utils.dots_to_hyphens(i.name), s.name, i.name_without_prefix, s.name, i.name, s.name)) - self.out.write('<programlisting>\n') + self.out.write( + '<refsect2 role="signal" id="gdbus-signal-%s.%s">\n' + % (utils.dots_to_hyphens(i.name), s.name) + ) + self.out.write(' <title>The "%s" signal</title>\n' % (s.name)) + self.out.write( + ' <indexterm zone="gdbus-signal-%s.%s"><primary sortas="%s::%s">%s::%s</primary></indexterm>\n' + % ( + utils.dots_to_hyphens(i.name), + s.name, + i.name_without_prefix, + s.name, + i.name, + s.name, + ) + ) + self.out.write("<programlisting>\n") self.print_signal_prototype(i, s, in_synopsis=False) - self.out.write('</programlisting>\n') - self.out.write('%s\n'%(self.expand_paras(s.doc_string, True))) + self.out.write("</programlisting>\n") + self.out.write("%s\n" % (self.expand_paras(s.doc_string, True))) if s.args: self.out.write('<variablelist role="params">\n') for a in s.args: - self.out.write('<varlistentry>\n'%()) - self.out.write(' <term><literal>%s <parameter>%s</parameter></literal>:</term>\n'%(a.signature, a.name)) - self.out.write(' <listitem>%s</listitem>\n'%(self.expand_paras(a.doc_string, True))) - self.out.write('</varlistentry>\n'%()) - self.out.write('</variablelist>\n') + self.out.write("<varlistentry>\n" % ()) + self.out.write( + " <term><literal>%s <parameter>%s</parameter></literal>:</term>\n" + % (a.signature, a.name) + ) + self.out.write( + " <listitem>%s</listitem>\n" + % (self.expand_paras(a.doc_string, True)) + ) + self.out.write("</varlistentry>\n" % ()) + self.out.write("</variablelist>\n") if len(s.since) > 0: - self.out.write('<para role="since">Since %s</para>\n'%(s.since)) + self.out.write('<para role="since">Since %s</para>\n' % (s.since)) if s.deprecated: - self.out.write('<warning><para>The "%s" signal is deprecated.</para></warning>'%(s.name)) - self.out.write('</refsect2>\n') + self.out.write( + '<warning><para>The "%s" signal is deprecated.</para></warning>' + % (s.name) + ) + self.out.write("</refsect2>\n") def print_property(self, i, p): - self.out.write('<refsect2 role="property" id="gdbus-property-%s.%s">\n'%(utils.dots_to_hyphens(i.name), p.name)) - self.out.write(' <title>The "%s" property</title>\n'%(p.name)) - self.out.write(' <indexterm zone="gdbus-property-%s.%s"><primary sortas="%s:%s">%s:%s</primary></indexterm>\n'%(utils.dots_to_hyphens(i.name), p.name, i.name_without_prefix, p.name, i.name, p.name)) - self.out.write('<programlisting>\n') + self.out.write( + '<refsect2 role="property" id="gdbus-property-%s.%s">\n' + % (utils.dots_to_hyphens(i.name), p.name) + ) + self.out.write(' <title>The "%s" property</title>\n' % (p.name)) + self.out.write( + ' <indexterm zone="gdbus-property-%s.%s"><primary sortas="%s:%s">%s:%s</primary></indexterm>\n' + % ( + utils.dots_to_hyphens(i.name), + p.name, + i.name_without_prefix, + p.name, + i.name, + p.name, + ) + ) + self.out.write("<programlisting>\n") self.print_property_prototype(i, p, in_synopsis=False) - self.out.write('</programlisting>\n') - self.out.write('%s\n'%(self.expand_paras(p.doc_string, True))) + self.out.write("</programlisting>\n") + self.out.write("%s\n" % (self.expand_paras(p.doc_string, True))) if len(p.since) > 0: - self.out.write('<para role="since">Since %s</para>\n'%(p.since)) + self.out.write('<para role="since">Since %s</para>\n' % (p.since)) if p.deprecated: - self.out.write('<warning><para>The "%s" property is deprecated.</para></warning>'%(p.name)) - self.out.write('</refsect2>\n') + self.out.write( + '<warning><para>The "%s" property is deprecated.</para></warning>' + % (p.name) + ) + self.out.write("</refsect2>\n") def expand(self, s, expandParamsAndConstants): for key in self.expand_member_dict_keys: @@ -233,9 +329,17 @@ class DocbookCodeGenerator: s = s.replace(key, self.expand_iface_dict[key]) if expandParamsAndConstants: # replace @foo with <parameter>foo</parameter> - s = re.sub('@[a-zA-Z0-9_]*', lambda m: '<parameter>' + m.group(0)[1:] + '</parameter>', s) + s = re.sub( + "@[a-zA-Z0-9_]*", + lambda m: "<parameter>" + m.group(0)[1:] + "</parameter>", + s, + ) # replace e.g. %TRUE with <constant>TRUE</constant> - s = re.sub('%[a-zA-Z0-9_]*', lambda m: '<constant>' + m.group(0)[1:] + '</constant>', s) + s = re.sub( + "%[a-zA-Z0-9_]*", + lambda m: "<constant>" + m.group(0)[1:] + "</constant>", + s, + ) return s def expand_paras(self, s, expandParamsAndConstants): @@ -248,44 +352,75 @@ class DocbookCodeGenerator: self.expand_member_dict = {} self.expand_iface_dict = {} for i in self.ifaces: - key = '#%s'%(i.name) - value = '<link linkend="gdbus-interface-%s.top_of_page">%s</link>'%(utils.dots_to_hyphens(i.name), i.name) + key = "#%s" % (i.name) + value = '<link linkend="gdbus-interface-%s.top_of_page">%s</link>' % ( + utils.dots_to_hyphens(i.name), + i.name, + ) self.expand_iface_dict[key] = value for m in i.methods: - key = '%s.%s()'%(i.name, m.name) - value = '<link linkend="gdbus-method-%s.%s">%s()</link>'%(utils.dots_to_hyphens(i.name), m.name, m.name) + key = "%s.%s()" % (i.name, m.name) + value = '<link linkend="gdbus-method-%s.%s">%s()</link>' % ( + utils.dots_to_hyphens(i.name), + m.name, + m.name, + ) self.expand_member_dict[key] = value for s in i.signals: - key = '#%s::%s'%(i.name, s.name) - value = '<link linkend="gdbus-signal-%s.%s">"%s"</link>'%(utils.dots_to_hyphens(i.name), s.name, s.name) + key = "#%s::%s" % (i.name, s.name) + value = '<link linkend="gdbus-signal-%s.%s">"%s"</link>' % ( + utils.dots_to_hyphens(i.name), + s.name, + s.name, + ) self.expand_member_dict[key] = value for p in i.properties: - key = '#%s:%s'%(i.name, p.name) - value = '<link linkend="gdbus-property-%s.%s">"%s"</link>'%(utils.dots_to_hyphens(i.name), p.name, p.name) + key = "#%s:%s" % (i.name, p.name) + value = '<link linkend="gdbus-property-%s.%s">"%s"</link>' % ( + utils.dots_to_hyphens(i.name), + p.name, + p.name, + ) self.expand_member_dict[key] = value # Make sure to expand the keys in reverse order so e.g. #org.foo.Iface:MediaCompat # is evaluated before #org.foo.Iface:Media ... - self.expand_member_dict_keys = sorted(self.expand_member_dict.keys(), reverse=True) - self.expand_iface_dict_keys = sorted(self.expand_iface_dict.keys(), reverse=True) + self.expand_member_dict_keys = sorted( + self.expand_member_dict.keys(), reverse=True + ) + self.expand_iface_dict_keys = sorted( + self.expand_iface_dict.keys(), reverse=True + ) def generate(self, docbook, outdir): for i in self.ifaces: - self.out = open(path.join(outdir, '%s-%s.xml'%(docbook, i.name)), 'w') - self.out.write(''%()) - self.out.write('<?xml version="1.0" encoding="utf-8"?>\n'%()) - self.out.write('<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.1.2//EN"\n'%()) - self.out.write(' "http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd" [\n'%()) - self.out.write(']>\n'%()) - self.out.write('<refentry id="gdbus-%s">\n'%(i.name)) - self.out.write(' <refmeta>'%()) - self.out.write(' <refentrytitle role="top_of_page" id="gdbus-interface-%s.top_of_page">%s</refentrytitle>\n'%(utils.dots_to_hyphens(i.name), i.name)) - self.out.write(' <indexterm zone="gdbus-interface-%s.top_of_page"><primary sortas="%s">%s</primary></indexterm>\n'%(utils.dots_to_hyphens(i.name), i.name_without_prefix, i.name)) - self.out.write(' </refmeta>'%()) - - self.out.write(' <refnamediv>'%()) - self.out.write(' <refname>%s</refname>'%(i.name)) - self.out.write(' <refpurpose>%s</refpurpose>'%(i.doc_string_brief)) - self.out.write(' </refnamediv>'%()) + self.out = open(path.join(outdir, "%s-%s.xml" % (docbook, i.name)), "w") + self.out.write("" % ()) + self.out.write('<?xml version="1.0" encoding="utf-8"?>\n' % ()) + self.out.write( + '<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.1.2//EN"\n' + % () + ) + self.out.write( + ' "http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd" [\n' + % () + ) + self.out.write("]>\n" % ()) + self.out.write('<refentry id="gdbus-%s">\n' % (i.name)) + self.out.write(" <refmeta>" % ()) + self.out.write( + ' <refentrytitle role="top_of_page" id="gdbus-interface-%s.top_of_page">%s</refentrytitle>\n' + % (utils.dots_to_hyphens(i.name), i.name) + ) + self.out.write( + ' <indexterm zone="gdbus-interface-%s.top_of_page"><primary sortas="%s">%s</primary></indexterm>\n' + % (utils.dots_to_hyphens(i.name), i.name_without_prefix, i.name) + ) + self.out.write(" </refmeta>" % ()) + + self.out.write(" <refnamediv>" % ()) + self.out.write(" <refname>%s</refname>" % (i.name)) + self.out.write(" <refpurpose>%s</refpurpose>" % (i.doc_string_brief)) + self.out.write(" </refnamediv>" % ()) if len(i.methods) > 0: self.print_synopsis_methods(i) @@ -294,36 +429,53 @@ class DocbookCodeGenerator: if len(i.properties) > 0: self.print_synopsis_properties(i) - self.out.write('<refsect1 role="desc" id="gdbus-interface-%s">\n'%(utils.dots_to_hyphens(i.name))) - self.out.write(' <title role="desc.title">Description</title>\n'%()) - self.out.write(' %s\n'%(self.expand_paras(i.doc_string, True))) + self.out.write( + '<refsect1 role="desc" id="gdbus-interface-%s">\n' + % (utils.dots_to_hyphens(i.name)) + ) + self.out.write(' <title role="desc.title">Description</title>\n' % ()) + self.out.write(" %s\n" % (self.expand_paras(i.doc_string, True))) if len(i.since) > 0: - self.out.write(' <para role="since">Since %s</para>\n'%(i.since)) + self.out.write(' <para role="since">Since %s</para>\n' % (i.since)) if i.deprecated: - self.out.write('<warning><para>The %s interface is deprecated.</para></warning>'%(i.name)) - self.out.write('</refsect1>\n'%()) + self.out.write( + "<warning><para>The %s interface is deprecated.</para></warning>" + % (i.name) + ) + self.out.write("</refsect1>\n" % ()) if len(i.methods) > 0: - self.out.write('<refsect1 role="details" id="gdbus-methods-%s">\n'%(i.name)) - self.out.write(' <title role="details.title">Method Details</title>\n'%()) + self.out.write( + '<refsect1 role="details" id="gdbus-methods-%s">\n' % (i.name) + ) + self.out.write( + ' <title role="details.title">Method Details</title>\n' % () + ) for m in i.methods: self.print_method(i, m) - self.out.write('</refsect1>\n'%()) + self.out.write("</refsect1>\n" % ()) if len(i.signals) > 0: - self.out.write('<refsect1 role="details" id="gdbus-signals-%s">\n'%(i.name)) - self.out.write(' <title role="details.title">Signal Details</title>\n'%()) + self.out.write( + '<refsect1 role="details" id="gdbus-signals-%s">\n' % (i.name) + ) + self.out.write( + ' <title role="details.title">Signal Details</title>\n' % () + ) for s in i.signals: self.print_signal(i, s) - self.out.write('</refsect1>\n'%()) + self.out.write("</refsect1>\n" % ()) if len(i.properties) > 0: - self.out.write('<refsect1 role="details" id="gdbus-properties-%s">\n'%(i.name)) - self.out.write(' <title role="details.title">Property Details</title>\n'%()) + self.out.write( + '<refsect1 role="details" id="gdbus-properties-%s">\n' % (i.name) + ) + self.out.write( + ' <title role="details.title">Property Details</title>\n' % () + ) for s in i.properties: self.print_property(i, s) - self.out.write('</refsect1>\n'%()) - - self.out.write('</refentry>\n') - self.out.write('\n') + self.out.write("</refsect1>\n" % ()) + self.out.write("</refentry>\n") + self.out.write("\n") diff --git a/gio/gdbus-2.0/codegen/codegen_main.py b/gio/gdbus-2.0/codegen/codegen_main.py index bd7fef528..7adf0864b 100644 --- a/gio/gdbus-2.0/codegen/codegen_main.py +++ b/gio/gdbus-2.0/codegen/codegen_main.py @@ -32,30 +32,35 @@ from . import codegen from . import codegen_docbook from .utils import print_error, print_warning + def find_arg(arg_list, arg_name): for a in arg_list: if a.name == arg_name: return a return None + def find_method(iface, method): for m in iface.methods: if m.name == method: return m return None + def find_signal(iface, signal): for m in iface.signals: if m.name == signal: return m return None + def find_prop(iface, prop): for m in iface.properties: if m.name == prop: return m return None + def apply_annotation(iface_list, iface, method, signal, prop, arg, key, value): iface_obj = None for i in iface_list: @@ -74,10 +79,14 @@ def apply_annotation(iface_list, iface, method, signal, prop, arg, key, value): print_error('No method "{}" on interface "{}"'.format(method, iface)) if arg: arg_obj = find_arg(method_obj.in_args, arg) - if (arg_obj is None): + if arg_obj is None: arg_obj = find_arg(method_obj.out_args, arg) - if (arg_obj is None): - print_error('No arg "{}" on method "{}" on interface "{}"'.format(arg, method, iface)) + if arg_obj is None: + print_error( + 'No arg "{}" on method "{}" on interface "{}"'.format( + arg, method, iface + ) + ) target_obj = arg_obj else: target_obj = method_obj @@ -87,8 +96,12 @@ def apply_annotation(iface_list, iface, method, signal, prop, arg, key, value): print_error('No signal "{}" on interface "{}"'.format(signal, iface)) if arg: arg_obj = find_arg(signal_obj.args, arg) - if (arg_obj is None): - print_error('No arg "{}" on signal "{}" on interface "{}"'.format(arg, signal, iface)) + if arg_obj is None: + print_error( + 'No arg "{}" on signal "{}" on interface "{}"'.format( + arg, signal, iface + ) + ) target_obj = arg_obj else: target_obj = signal_obj @@ -105,198 +118,287 @@ def apply_annotation(iface_list, iface, method, signal, prop, arg, key, value): def apply_annotations(iface_list, annotation_list): # apply annotations given on the command line for (what, key, value) in annotation_list: - pos = what.find('::') + pos = what.find("::") if pos != -1: # signal - iface = what[0:pos]; - signal = what[pos + 2:] - pos = signal.find('[') + iface = what[0:pos] + signal = what[pos + 2 :] + pos = signal.find("[") if pos != -1: - arg = signal[pos + 1:] + arg = signal[pos + 1 :] signal = signal[0:pos] - pos = arg.find(']') + pos = arg.find("]") arg = arg[0:pos] apply_annotation(iface_list, iface, None, signal, None, arg, key, value) else: - apply_annotation(iface_list, iface, None, signal, None, None, key, value) + apply_annotation( + iface_list, iface, None, signal, None, None, key, value + ) else: - pos = what.find(':') + pos = what.find(":") if pos != -1: # property - iface = what[0:pos]; - prop = what[pos + 1:] + iface = what[0:pos] + prop = what[pos + 1 :] apply_annotation(iface_list, iface, None, None, prop, None, key, value) else: - pos = what.find('()') + pos = what.find("()") if pos != -1: # method combined = what[0:pos] - pos = combined.rfind('.') + pos = combined.rfind(".") iface = combined[0:pos] - method = combined[pos + 1:] - pos = what.find('[') + method = combined[pos + 1 :] + pos = what.find("[") if pos != -1: - arg = what[pos + 1:] - pos = arg.find(']') + arg = what[pos + 1 :] + pos = arg.find("]") arg = arg[0:pos] - apply_annotation(iface_list, iface, method, None, None, arg, key, value) + apply_annotation( + iface_list, iface, method, None, None, arg, key, value + ) else: - apply_annotation(iface_list, iface, method, None, None, None, key, value) + apply_annotation( + iface_list, iface, method, None, None, None, key, value + ) else: # must be an interface iface = what - apply_annotation(iface_list, iface, None, None, None, None, key, value) + apply_annotation( + iface_list, iface, None, None, None, None, key, value + ) + def codegen_main(): - arg_parser = argparse.ArgumentParser(description='D-Bus code and documentation generator') - arg_parser.add_argument('files', metavar='FILE', nargs='+', - help='D-Bus introspection XML file') - arg_parser.add_argument('--xml-files', metavar='FILE', action='append', default=[], - help=argparse.SUPPRESS) - arg_parser.add_argument('--interface-prefix', metavar='PREFIX', default='', - help='String to strip from D-Bus interface names for code and docs') - arg_parser.add_argument('--c-namespace', metavar='NAMESPACE', default='', - help='The namespace to use for generated C code') - arg_parser.add_argument('--c-generate-object-manager', action='store_true', - help='Generate a GDBusObjectManagerClient subclass when generating C code') - arg_parser.add_argument('--c-generate-autocleanup', choices=['none', 'objects', 'all'], default='objects', - help='Generate autocleanup support') - arg_parser.add_argument('--generate-docbook', metavar='OUTFILES', - help='Generate Docbook in OUTFILES-org.Project.IFace.xml') - arg_parser.add_argument('--pragma-once', action='store_true', - help='Use "pragma once" as the inclusion guard') - arg_parser.add_argument('--annotate', nargs=3, action='append', metavar='WHAT KEY VALUE', - help='Add annotation (may be used several times)') - arg_parser.add_argument('--glib-min-required', metavar='VERSION', - help='Minimum version of GLib to be supported by the outputted code (default: 2.30)') - arg_parser.add_argument('--glib-max-allowed', metavar='VERSION', - help='Maximum version of GLib to be used by the outputted code (default: current GLib version)') - arg_parser.add_argument('--symbol-decorator', - help='Macro used to decorate a symbol in the outputted header, possibly to export symbols') - arg_parser.add_argument('--symbol-decorator-header', - help='Additional header required for decorator specified by --symbol-decorator') - arg_parser.add_argument('--symbol-decorator-define', - help='Additional define required for decorator specified by --symbol-decorator') + arg_parser = argparse.ArgumentParser( + description="D-Bus code and documentation generator" + ) + arg_parser.add_argument( + "files", metavar="FILE", nargs="+", help="D-Bus introspection XML file" + ) + arg_parser.add_argument( + "--xml-files", + metavar="FILE", + action="append", + default=[], + help=argparse.SUPPRESS, + ) + arg_parser.add_argument( + "--interface-prefix", + metavar="PREFIX", + default="", + help="String to strip from D-Bus interface names for code and docs", + ) + arg_parser.add_argument( + "--c-namespace", + metavar="NAMESPACE", + default="", + help="The namespace to use for generated C code", + ) + arg_parser.add_argument( + "--c-generate-object-manager", + action="store_true", + help="Generate a GDBusObjectManagerClient subclass when generating C code", + ) + arg_parser.add_argument( + "--c-generate-autocleanup", + choices=["none", "objects", "all"], + default="objects", + help="Generate autocleanup support", + ) + arg_parser.add_argument( + "--generate-docbook", + metavar="OUTFILES", + help="Generate Docbook in OUTFILES-org.Project.IFace.xml", + ) + arg_parser.add_argument( + "--pragma-once", + action="store_true", + help='Use "pragma once" as the inclusion guard', + ) + arg_parser.add_argument( + "--annotate", + nargs=3, + action="append", + metavar="WHAT KEY VALUE", + help="Add annotation (may be used several times)", + ) + arg_parser.add_argument( + "--glib-min-required", + metavar="VERSION", + help="Minimum version of GLib to be supported by the outputted code (default: 2.30)", + ) + arg_parser.add_argument( + "--glib-max-allowed", + metavar="VERSION", + help="Maximum version of GLib to be used by the outputted code (default: current GLib version)", + ) + arg_parser.add_argument( + "--symbol-decorator", + help="Macro used to decorate a symbol in the outputted header, possibly to export symbols", + ) + arg_parser.add_argument( + "--symbol-decorator-header", + help="Additional header required for decorator specified by --symbol-decorator", + ) + arg_parser.add_argument( + "--symbol-decorator-define", + help="Additional define required for decorator specified by --symbol-decorator", + ) group = arg_parser.add_mutually_exclusive_group() - group.add_argument('--generate-c-code', metavar='OUTFILES', - help='Generate C code in OUTFILES.[ch]') - group.add_argument('--header', action='store_true', - help='Generate C headers') - group.add_argument('--body', action='store_true', - help='Generate C code') - group.add_argument('--interface-info-header', action='store_true', - help='Generate GDBusInterfaceInfo C header') - group.add_argument('--interface-info-body', action='store_true', - help='Generate GDBusInterfaceInfo C code') + group.add_argument( + "--generate-c-code", metavar="OUTFILES", help="Generate C code in OUTFILES.[ch]" + ) + group.add_argument("--header", action="store_true", help="Generate C headers") + group.add_argument("--body", action="store_true", help="Generate C code") + group.add_argument( + "--interface-info-header", + action="store_true", + help="Generate GDBusInterfaceInfo C header", + ) + group.add_argument( + "--interface-info-body", + action="store_true", + help="Generate GDBusInterfaceInfo C code", + ) group = arg_parser.add_mutually_exclusive_group() - group.add_argument('--output', metavar='FILE', - help='Write output into the specified file') - group.add_argument('--output-directory', metavar='OUTDIR', default='', - help='Location to output generated files') - - args = arg_parser.parse_args(); + group.add_argument( + "--output", metavar="FILE", help="Write output into the specified file" + ) + group.add_argument( + "--output-directory", + metavar="OUTDIR", + default="", + help="Location to output generated files", + ) + + args = arg_parser.parse_args() if len(args.xml_files) > 0: - print_warning('The "--xml-files" option is deprecated; use positional arguments instead') - - if ((args.generate_c_code is not None or args.generate_docbook is not None) and - args.output is not None): - print_error('Using --generate-c-code or --generate-docbook and ' - '--output at the same time is not allowed') + print_warning( + 'The "--xml-files" option is deprecated; use positional arguments instead' + ) + + if ( + args.generate_c_code is not None or args.generate_docbook is not None + ) and args.output is not None: + print_error( + "Using --generate-c-code or --generate-docbook and " + "--output at the same time is not allowed" + ) if args.generate_c_code: - header_name = args.generate_c_code + '.h' + header_name = args.generate_c_code + ".h" h_file = os.path.join(args.output_directory, header_name) args.header = True - c_file = os.path.join(args.output_directory, args.generate_c_code + '.c') + c_file = os.path.join(args.output_directory, args.generate_c_code + ".c") args.body = True elif args.header: if args.output is None: - print_error('Using --header requires --output') + print_error("Using --header requires --output") h_file = args.output header_name = os.path.basename(h_file) elif args.body: if args.output is None: - print_error('Using --body requires --output') + print_error("Using --body requires --output") c_file = args.output - header_name = os.path.splitext(os.path.basename(c_file))[0] + '.h' + header_name = os.path.splitext(os.path.basename(c_file))[0] + ".h" elif args.interface_info_header: if args.output is None: - print_error('Using --interface-info-header requires --output') + print_error("Using --interface-info-header requires --output") if args.c_generate_object_manager: - print_error('--c-generate-object-manager is incompatible with ' - '--interface-info-header') + print_error( + "--c-generate-object-manager is incompatible with " + "--interface-info-header" + ) h_file = args.output header_name = os.path.basename(h_file) elif args.interface_info_body: if args.output is None: - print_error('Using --interface-info-body requires --output') + print_error("Using --interface-info-body requires --output") if args.c_generate_object_manager: - print_error('--c-generate-object-manager is incompatible with ' - '--interface-info-body') + print_error( + "--c-generate-object-manager is incompatible with " + "--interface-info-body" + ) c_file = args.output - header_name = os.path.splitext(os.path.basename(c_file))[0] + '.h' + header_name = os.path.splitext(os.path.basename(c_file))[0] + ".h" # Check the minimum GLib version. The minimum --glib-min-required is 2.30, # because that’s when gdbus-codegen was introduced. Support 1, 2 or 3 # component versions, but ignore the micro component if it’s present. if args.glib_min_required: try: - parts = args.glib_min_required.split('.', 3) - glib_min_required = (int(parts[0]), - int(parts[1] if len(parts) > 1 else 0)) + parts = args.glib_min_required.split(".", 3) + glib_min_required = (int(parts[0]), int(parts[1] if len(parts) > 1 else 0)) # Ignore micro component, but still validate it: _ = int(parts[2] if len(parts) > 2 else 0) except (ValueError, IndexError): - print_error('Unrecognized --glib-min-required string ‘{}’'.format( - args.glib_min_required)) + print_error( + "Unrecognized --glib-min-required string ‘{}’".format( + args.glib_min_required + ) + ) if glib_min_required < (2, 30): - print_error('Invalid --glib-min-required string ‘{}’: minimum ' - 'version is 2.30'.format(args.glib_min_required)) + print_error( + "Invalid --glib-min-required string ‘{}’: minimum " + "version is 2.30".format(args.glib_min_required) + ) else: glib_min_required = (2, 30) # And the maximum GLib version. if args.glib_max_allowed: try: - parts = args.glib_max_allowed.split('.', 3) - glib_max_allowed = (int(parts[0]), - int(parts[1] if len(parts) > 1 else 0)) + parts = args.glib_max_allowed.split(".", 3) + glib_max_allowed = (int(parts[0]), int(parts[1] if len(parts) > 1 else 0)) # Ignore micro component, but still validate it: _ = int(parts[2] if len(parts) > 2 else 0) except (ValueError, IndexError): - print_error('Unrecognized --glib-max-allowed string ‘{}’'.format( - args.glib_max_allowed)) + print_error( + "Unrecognized --glib-max-allowed string ‘{}’".format( + args.glib_max_allowed + ) + ) else: glib_max_allowed = (config.MAJOR_VERSION, config.MINOR_VERSION) # Only allow --symbol-decorator-define and --symbol-decorator-header if --symbol-decorator is used if args.symbol_decorator is None: if args.symbol_decorator_header or args.symbol_decorator_define: - print_error('--symbol-decorator-define and --symbol-decorator-header must be used with --symbol-decorator') + print_error( + "--symbol-decorator-define and --symbol-decorator-header must be used with --symbol-decorator" + ) # Round --glib-max-allowed up to the next stable release. - glib_max_allowed = \ - (glib_max_allowed[0], glib_max_allowed[1] + (glib_max_allowed[1] % 2)) + glib_max_allowed = ( + glib_max_allowed[0], + glib_max_allowed[1] + (glib_max_allowed[1] % 2), + ) if glib_max_allowed < glib_min_required: - print_error('Invalid versions: --glib-min-required ({}) must be ' - 'less than or equal to --glib-max-allowed ({})'.format(glib_min_required, glib_max_allowed)) + print_error( + "Invalid versions: --glib-min-required ({}) must be " + "less than or equal to --glib-max-allowed ({})".format( + glib_min_required, glib_max_allowed + ) + ) all_ifaces = [] input_files_basenames = [] for fname in sorted(args.files + args.xml_files): - with open(fname, 'rb') as f: + with open(fname, "rb") as f: xml_data = f.read() - parsed_ifaces = parser.parse_dbus_xml(xml_data, - h_type_implies_unix_fd=(glib_min_required >= (2, 64))) + parsed_ifaces = parser.parse_dbus_xml( + xml_data, h_type_implies_unix_fd=(glib_min_required >= (2, 64)) + ) all_ifaces.extend(parsed_ifaces) input_files_basenames.append(os.path.basename(fname)) @@ -307,63 +409,72 @@ def codegen_main(): i.post_process(args.interface_prefix, args.c_namespace) docbook = args.generate_docbook - docbook_gen = codegen_docbook.DocbookCodeGenerator(all_ifaces); + docbook_gen = codegen_docbook.DocbookCodeGenerator(all_ifaces) if docbook: ret = docbook_gen.generate(docbook, args.output_directory) if args.header: - with open(h_file, 'w') as outfile: - gen = codegen.HeaderCodeGenerator(all_ifaces, - args.c_namespace, - args.c_generate_object_manager, - args.c_generate_autocleanup, - header_name, - input_files_basenames, - args.pragma_once, - glib_min_required, - args.symbol_decorator, - args.symbol_decorator_header, - outfile) + with open(h_file, "w") as outfile: + gen = codegen.HeaderCodeGenerator( + all_ifaces, + args.c_namespace, + args.c_generate_object_manager, + args.c_generate_autocleanup, + header_name, + input_files_basenames, + args.pragma_once, + glib_min_required, + args.symbol_decorator, + args.symbol_decorator_header, + outfile, + ) gen.generate() if args.body: - with open(c_file, 'w') as outfile: - gen = codegen.CodeGenerator(all_ifaces, - args.c_namespace, - args.c_generate_object_manager, - header_name, - input_files_basenames, - docbook_gen, - glib_min_required, - args.symbol_decorator_define, - outfile) + with open(c_file, "w") as outfile: + gen = codegen.CodeGenerator( + all_ifaces, + args.c_namespace, + args.c_generate_object_manager, + header_name, + input_files_basenames, + docbook_gen, + glib_min_required, + args.symbol_decorator_define, + outfile, + ) gen.generate() if args.interface_info_header: - with open(h_file, 'w') as outfile: - gen = codegen.InterfaceInfoHeaderCodeGenerator(all_ifaces, - args.c_namespace, - header_name, - input_files_basenames, - args.pragma_once, - glib_min_required, - args.symbol_decorator, - args.symbol_decorator_header, - outfile) + with open(h_file, "w") as outfile: + gen = codegen.InterfaceInfoHeaderCodeGenerator( + all_ifaces, + args.c_namespace, + header_name, + input_files_basenames, + args.pragma_once, + glib_min_required, + args.symbol_decorator, + args.symbol_decorator_header, + outfile, + ) gen.generate() if args.interface_info_body: - with open(c_file, 'w') as outfile: - gen = codegen.InterfaceInfoBodyCodeGenerator(all_ifaces, - args.c_namespace, - header_name, - input_files_basenames, - glib_min_required, - args.symbol_decorator_define, - outfile) + with open(c_file, "w") as outfile: + gen = codegen.InterfaceInfoBodyCodeGenerator( + all_ifaces, + args.c_namespace, + header_name, + input_files_basenames, + glib_min_required, + args.symbol_decorator_define, + outfile, + ) gen.generate() sys.exit(0) + if __name__ == "__main__": codegen_main() diff --git a/gio/gdbus-2.0/codegen/dbustypes.py b/gio/gdbus-2.0/codegen/dbustypes.py index 415a5cc7a..218681979 100644 --- a/gio/gdbus-2.0/codegen/dbustypes.py +++ b/gio/gdbus-2.0/codegen/dbustypes.py @@ -22,22 +22,30 @@ from . import utils from .utils import print_error + class Annotation: def __init__(self, key, value): self.key = key self.value = value self.annotations = [] - self.since = '' + self.since = "" def post_process(self, interface_prefix, cns, cns_upper, cns_lower, container): key = self.key - overridden_key = utils.lookup_annotation(self.annotations, 'org.gtk.GDBus.C.Name') + overridden_key = utils.lookup_annotation( + self.annotations, "org.gtk.GDBus.C.Name" + ) if utils.is_ugly_case(overridden_key): self.key_lower = overridden_key.lower() else: if overridden_key: key = overridden_key - self.key_lower = utils.camel_case_to_uscore(key).lower().replace('-', '_').replace('.', '_') + self.key_lower = ( + utils.camel_case_to_uscore(key) + .lower() + .replace("-", "_") + .replace(".", "_") + ) if len(self.since) == 0: self.since = utils.lookup_since(self.annotations) @@ -47,13 +55,14 @@ class Annotation: for a in self.annotations: a.post_process(interface_prefix, cns, cns_upper, cns_lower, self) + class Arg: def __init__(self, name, signature): self.name = name self.signature = signature self.annotations = [] - self.doc_string = '' - self.since = '' + self.doc_string = "" + self.since = "" def post_process(self, interface_prefix, cns, cns_upper, cns_lower, arg_number): if len(self.doc_string) == 0: @@ -62,195 +71,198 @@ class Arg: self.since = utils.lookup_since(self.annotations) if self.name is None: - self.name = 'unnamed_arg%d'%arg_number + self.name = "unnamed_arg%d" % arg_number # default to GVariant - self.ctype_in_g = 'GVariant *' - self.ctype_in = 'GVariant *' - self.ctype_in_dup = 'GVariant *' - self.ctype_out = 'GVariant **' - self.gtype = 'G_TYPE_VARIANT' - self.free_func = 'g_variant_unref' - self.format_in = '@' + self.signature - self.format_out = '@' + self.signature - self.gvariant_get = 'XXX' - self.gvalue_get = 'g_value_get_variant' - self.array_annotation = '' - - if not utils.lookup_annotation(self.annotations, 'org.gtk.GDBus.C.ForceGVariant'): - if self.signature == 'b': - self.ctype_in_g = 'gboolean ' - self.ctype_in = 'gboolean ' - self.ctype_out = 'gboolean *' - self.gtype = 'G_TYPE_BOOLEAN' + self.ctype_in_g = "GVariant *" + self.ctype_in = "GVariant *" + self.ctype_in_dup = "GVariant *" + self.ctype_out = "GVariant **" + self.gtype = "G_TYPE_VARIANT" + self.free_func = "g_variant_unref" + self.format_in = "@" + self.signature + self.format_out = "@" + self.signature + self.gvariant_get = "XXX" + self.gvalue_get = "g_value_get_variant" + self.array_annotation = "" + + if not utils.lookup_annotation( + self.annotations, "org.gtk.GDBus.C.ForceGVariant" + ): + if self.signature == "b": + self.ctype_in_g = "gboolean " + self.ctype_in = "gboolean " + self.ctype_out = "gboolean *" + self.gtype = "G_TYPE_BOOLEAN" self.free_func = None - self.format_in = 'b' - self.format_out = 'b' - self.gvariant_get = 'g_variant_get_boolean' - self.gvalue_get = 'g_value_get_boolean' - elif self.signature == 'y': - self.ctype_in_g = 'guchar ' - self.ctype_in = 'guchar ' - self.ctype_out = 'guchar *' - self.gtype = 'G_TYPE_UCHAR' + self.format_in = "b" + self.format_out = "b" + self.gvariant_get = "g_variant_get_boolean" + self.gvalue_get = "g_value_get_boolean" + elif self.signature == "y": + self.ctype_in_g = "guchar " + self.ctype_in = "guchar " + self.ctype_out = "guchar *" + self.gtype = "G_TYPE_UCHAR" self.free_func = None - self.format_in = 'y' - self.format_out = 'y' - self.gvariant_get = 'g_variant_get_byte' - self.gvalue_get = 'g_value_get_uchar' - elif self.signature == 'n': - self.ctype_in_g = 'gint ' - self.ctype_in = 'gint16 ' - self.ctype_out = 'gint16 *' - self.gtype = 'G_TYPE_INT' + self.format_in = "y" + self.format_out = "y" + self.gvariant_get = "g_variant_get_byte" + self.gvalue_get = "g_value_get_uchar" + elif self.signature == "n": + self.ctype_in_g = "gint " + self.ctype_in = "gint16 " + self.ctype_out = "gint16 *" + self.gtype = "G_TYPE_INT" self.free_func = None - self.format_in = 'n' - self.format_out = 'n' - self.gvariant_get = 'g_variant_get_int16' - self.gvalue_get = 'g_value_get_int' - elif self.signature == 'q': - self.ctype_in_g = 'guint ' - self.ctype_in = 'guint16 ' - self.ctype_out = 'guint16 *' - self.gtype = 'G_TYPE_UINT' + self.format_in = "n" + self.format_out = "n" + self.gvariant_get = "g_variant_get_int16" + self.gvalue_get = "g_value_get_int" + elif self.signature == "q": + self.ctype_in_g = "guint " + self.ctype_in = "guint16 " + self.ctype_out = "guint16 *" + self.gtype = "G_TYPE_UINT" self.free_func = None - self.format_in = 'q' - self.format_out = 'q' - self.gvariant_get = 'g_variant_get_uint16' - self.gvalue_get = 'g_value_get_uint' - elif self.signature == 'i': - self.ctype_in_g = 'gint ' - self.ctype_in = 'gint ' - self.ctype_out = 'gint *' - self.gtype = 'G_TYPE_INT' + self.format_in = "q" + self.format_out = "q" + self.gvariant_get = "g_variant_get_uint16" + self.gvalue_get = "g_value_get_uint" + elif self.signature == "i": + self.ctype_in_g = "gint " + self.ctype_in = "gint " + self.ctype_out = "gint *" + self.gtype = "G_TYPE_INT" self.free_func = None - self.format_in = 'i' - self.format_out = 'i' - self.gvariant_get = 'g_variant_get_int32' - self.gvalue_get = 'g_value_get_int' - elif self.signature == 'u': - self.ctype_in_g = 'guint ' - self.ctype_in = 'guint ' - self.ctype_out = 'guint *' - self.gtype = 'G_TYPE_UINT' + self.format_in = "i" + self.format_out = "i" + self.gvariant_get = "g_variant_get_int32" + self.gvalue_get = "g_value_get_int" + elif self.signature == "u": + self.ctype_in_g = "guint " + self.ctype_in = "guint " + self.ctype_out = "guint *" + self.gtype = "G_TYPE_UINT" self.free_func = None - self.format_in = 'u' - self.format_out = 'u' - self.gvariant_get = 'g_variant_get_uint32' - self.gvalue_get = 'g_value_get_uint' - elif self.signature == 'x': - self.ctype_in_g = 'gint64 ' - self.ctype_in = 'gint64 ' - self.ctype_out = 'gint64 *' - self.gtype = 'G_TYPE_INT64' + self.format_in = "u" + self.format_out = "u" + self.gvariant_get = "g_variant_get_uint32" + self.gvalue_get = "g_value_get_uint" + elif self.signature == "x": + self.ctype_in_g = "gint64 " + self.ctype_in = "gint64 " + self.ctype_out = "gint64 *" + self.gtype = "G_TYPE_INT64" self.free_func = None - self.format_in = 'x' - self.format_out = 'x' - self.gvariant_get = 'g_variant_get_int64' - self.gvalue_get = 'g_value_get_int64' - elif self.signature == 't': - self.ctype_in_g = 'guint64 ' - self.ctype_in = 'guint64 ' - self.ctype_out = 'guint64 *' - self.gtype = 'G_TYPE_UINT64' + self.format_in = "x" + self.format_out = "x" + self.gvariant_get = "g_variant_get_int64" + self.gvalue_get = "g_value_get_int64" + elif self.signature == "t": + self.ctype_in_g = "guint64 " + self.ctype_in = "guint64 " + self.ctype_out = "guint64 *" + self.gtype = "G_TYPE_UINT64" self.free_func = None - self.format_in = 't' - self.format_out = 't' - self.gvariant_get = 'g_variant_get_uint64' - self.gvalue_get = 'g_value_get_uint64' - elif self.signature == 'd': - self.ctype_in_g = 'gdouble ' - self.ctype_in = 'gdouble ' - self.ctype_out = 'gdouble *' - self.gtype = 'G_TYPE_DOUBLE' + self.format_in = "t" + self.format_out = "t" + self.gvariant_get = "g_variant_get_uint64" + self.gvalue_get = "g_value_get_uint64" + elif self.signature == "d": + self.ctype_in_g = "gdouble " + self.ctype_in = "gdouble " + self.ctype_out = "gdouble *" + self.gtype = "G_TYPE_DOUBLE" self.free_func = None - self.format_in = 'd' - self.format_out = 'd' - self.gvariant_get = 'g_variant_get_double' - self.gvalue_get = 'g_value_get_double' - elif self.signature == 's': - self.ctype_in_g = 'const gchar *' - self.ctype_in = 'const gchar *' - self.ctype_in_dup = 'gchar *' - self.ctype_out = 'gchar **' - self.gtype = 'G_TYPE_STRING' - self.free_func = 'g_free' - self.format_in = 's' - self.format_out = 's' - self.gvariant_get = 'g_variant_get_string' - self.gvalue_get = 'g_value_get_string' - elif self.signature == 'o': - self.ctype_in_g = 'const gchar *' - self.ctype_in = 'const gchar *' - self.ctype_in_dup = 'gchar *' - self.ctype_out = 'gchar **' - self.gtype = 'G_TYPE_STRING' - self.free_func = 'g_free' - self.format_in = 'o' - self.format_out = 'o' - self.gvariant_get = 'g_variant_get_string' - self.gvalue_get = 'g_value_get_string' - elif self.signature == 'g': - self.ctype_in_g = 'const gchar *' - self.ctype_in = 'const gchar *' - self.ctype_in_dup = 'gchar *' - self.ctype_out = 'gchar **' - self.gtype = 'G_TYPE_STRING' - self.free_func = 'g_free' - self.format_in = 'g' - self.format_out = 'g' - self.gvariant_get = 'g_variant_get_string' - self.gvalue_get = 'g_value_get_string' - elif self.signature == 'ay': - self.ctype_in_g = 'const gchar *' - self.ctype_in = 'const gchar *' - self.ctype_in_dup = 'gchar *' - self.ctype_out = 'gchar **' - self.gtype = 'G_TYPE_STRING' - self.free_func = 'g_free' - self.format_in = '^ay' - self.format_out = '^ay' - self.gvariant_get = 'g_variant_get_bytestring' - self.gvalue_get = 'g_value_get_string' - elif self.signature == 'as': - self.ctype_in_g = 'const gchar *const *' - self.ctype_in = 'const gchar *const *' - self.ctype_in_dup = 'gchar **' - self.ctype_out = 'gchar ***' - self.gtype = 'G_TYPE_STRV' - self.free_func = 'g_strfreev' - self.format_in = '^as' - self.format_out = '^as' - self.gvariant_get = 'g_variant_get_strv' - self.gvalue_get = 'g_value_get_boxed' - self.array_annotation = '(array zero-terminated=1)' - elif self.signature == 'ao': - self.ctype_in_g = 'const gchar *const *' - self.ctype_in = 'const gchar *const *' - self.ctype_in_dup = 'gchar **' - self.ctype_out = 'gchar ***' - self.gtype = 'G_TYPE_STRV' - self.free_func = 'g_strfreev' - self.format_in = '^ao' - self.format_out = '^ao' - self.gvariant_get = 'g_variant_get_objv' - self.gvalue_get = 'g_value_get_boxed' - self.array_annotation = '(array zero-terminated=1)' - elif self.signature == 'aay': - self.ctype_in_g = 'const gchar *const *' - self.ctype_in = 'const gchar *const *' - self.ctype_in_dup = 'gchar **' - self.ctype_out = 'gchar ***' - self.gtype = 'G_TYPE_STRV' - self.free_func = 'g_strfreev' - self.format_in = '^aay' - self.format_out = '^aay' - self.gvariant_get = 'g_variant_get_bytestring_array' - self.gvalue_get = 'g_value_get_boxed' - self.array_annotation = '(array zero-terminated=1)' + self.format_in = "d" + self.format_out = "d" + self.gvariant_get = "g_variant_get_double" + self.gvalue_get = "g_value_get_double" + elif self.signature == "s": + self.ctype_in_g = "const gchar *" + self.ctype_in = "const gchar *" + self.ctype_in_dup = "gchar *" + self.ctype_out = "gchar **" + self.gtype = "G_TYPE_STRING" + self.free_func = "g_free" + self.format_in = "s" + self.format_out = "s" + self.gvariant_get = "g_variant_get_string" + self.gvalue_get = "g_value_get_string" + elif self.signature == "o": + self.ctype_in_g = "const gchar *" + self.ctype_in = "const gchar *" + self.ctype_in_dup = "gchar *" + self.ctype_out = "gchar **" + self.gtype = "G_TYPE_STRING" + self.free_func = "g_free" + self.format_in = "o" + self.format_out = "o" + self.gvariant_get = "g_variant_get_string" + self.gvalue_get = "g_value_get_string" + elif self.signature == "g": + self.ctype_in_g = "const gchar *" + self.ctype_in = "const gchar *" + self.ctype_in_dup = "gchar *" + self.ctype_out = "gchar **" + self.gtype = "G_TYPE_STRING" + self.free_func = "g_free" + self.format_in = "g" + self.format_out = "g" + self.gvariant_get = "g_variant_get_string" + self.gvalue_get = "g_value_get_string" + elif self.signature == "ay": + self.ctype_in_g = "const gchar *" + self.ctype_in = "const gchar *" + self.ctype_in_dup = "gchar *" + self.ctype_out = "gchar **" + self.gtype = "G_TYPE_STRING" + self.free_func = "g_free" + self.format_in = "^ay" + self.format_out = "^ay" + self.gvariant_get = "g_variant_get_bytestring" + self.gvalue_get = "g_value_get_string" + elif self.signature == "as": + self.ctype_in_g = "const gchar *const *" + self.ctype_in = "const gchar *const *" + self.ctype_in_dup = "gchar **" + self.ctype_out = "gchar ***" + self.gtype = "G_TYPE_STRV" + self.free_func = "g_strfreev" + self.format_in = "^as" + self.format_out = "^as" + self.gvariant_get = "g_variant_get_strv" + self.gvalue_get = "g_value_get_boxed" + self.array_annotation = "(array zero-terminated=1)" + elif self.signature == "ao": + self.ctype_in_g = "const gchar *const *" + self.ctype_in = "const gchar *const *" + self.ctype_in_dup = "gchar **" + self.ctype_out = "gchar ***" + self.gtype = "G_TYPE_STRV" + self.free_func = "g_strfreev" + self.format_in = "^ao" + self.format_out = "^ao" + self.gvariant_get = "g_variant_get_objv" + self.gvalue_get = "g_value_get_boxed" + self.array_annotation = "(array zero-terminated=1)" + elif self.signature == "aay": + self.ctype_in_g = "const gchar *const *" + self.ctype_in = "const gchar *const *" + self.ctype_in_dup = "gchar **" + self.ctype_out = "gchar ***" + self.gtype = "G_TYPE_STRV" + self.free_func = "g_strfreev" + self.format_in = "^aay" + self.format_out = "^aay" + self.gvariant_get = "g_variant_get_bytestring_array" + self.gvalue_get = "g_value_get_boxed" + self.array_annotation = "(array zero-terminated=1)" for a in self.annotations: a.post_process(interface_prefix, cns, cns_upper, cns_lower, self) + class Method: def __init__(self, name, h_type_implies_unix_fd=True): self.name = name @@ -258,12 +270,14 @@ class Method: self.in_args = [] self.out_args = [] self.annotations = [] - self.doc_string = '' - self.since = '' + self.doc_string = "" + self.since = "" self.deprecated = False self.unix_fd = False - def post_process(self, interface_prefix, cns, cns_upper, cns_lower, containing_iface): + def post_process( + self, interface_prefix, cns, cns_upper, cns_lower, containing_iface + ): if len(self.doc_string) == 0: self.doc_string = utils.lookup_docs(self.annotations) if len(self.since) == 0: @@ -272,47 +286,55 @@ class Method: self.since = containing_iface.since name = self.name - overridden_name = utils.lookup_annotation(self.annotations, 'org.gtk.GDBus.C.Name') + overridden_name = utils.lookup_annotation( + self.annotations, "org.gtk.GDBus.C.Name" + ) if utils.is_ugly_case(overridden_name): self.name_lower = overridden_name.lower() else: if overridden_name: name = overridden_name - self.name_lower = utils.camel_case_to_uscore(name).lower().replace('-', '_') - self.name_hyphen = self.name_lower.replace('_', '-') + self.name_lower = utils.camel_case_to_uscore(name).lower().replace("-", "_") + self.name_hyphen = self.name_lower.replace("_", "-") arg_count = 0 for a in self.in_args: a.post_process(interface_prefix, cns, cns_upper, cns_lower, arg_count) arg_count += 1 - if self.h_type_implies_unix_fd and 'h' in a.signature: + if self.h_type_implies_unix_fd and "h" in a.signature: self.unix_fd = True for a in self.out_args: a.post_process(interface_prefix, cns, cns_upper, cns_lower, arg_count) arg_count += 1 - if self.h_type_implies_unix_fd and 'h' in a.signature: + if self.h_type_implies_unix_fd and "h" in a.signature: self.unix_fd = True - if utils.lookup_annotation(self.annotations, 'org.freedesktop.DBus.Deprecated') == 'true': + if ( + utils.lookup_annotation(self.annotations, "org.freedesktop.DBus.Deprecated") + == "true" + ): self.deprecated = True - if utils.lookup_annotation(self.annotations, 'org.gtk.GDBus.C.UnixFD'): + if utils.lookup_annotation(self.annotations, "org.gtk.GDBus.C.UnixFD"): self.unix_fd = True for a in self.annotations: a.post_process(interface_prefix, cns, cns_upper, cns_lower, self) + class Signal: def __init__(self, name): self.name = name self.args = [] self.annotations = [] - self.doc_string = '' - self.since = '' + self.doc_string = "" + self.since = "" self.deprecated = False - def post_process(self, interface_prefix, cns, cns_upper, cns_lower, containing_iface): + def post_process( + self, interface_prefix, cns, cns_upper, cns_lower, containing_iface + ): if len(self.doc_string) == 0: self.doc_string = utils.lookup_docs(self.annotations) if len(self.since) == 0: @@ -321,51 +343,59 @@ class Signal: self.since = containing_iface.since name = self.name - overridden_name = utils.lookup_annotation(self.annotations, 'org.gtk.GDBus.C.Name') + overridden_name = utils.lookup_annotation( + self.annotations, "org.gtk.GDBus.C.Name" + ) if utils.is_ugly_case(overridden_name): self.name_lower = overridden_name.lower() else: if overridden_name: name = overridden_name - self.name_lower = utils.camel_case_to_uscore(name).lower().replace('-', '_') - self.name_hyphen = self.name_lower.replace('_', '-') + self.name_lower = utils.camel_case_to_uscore(name).lower().replace("-", "_") + self.name_hyphen = self.name_lower.replace("_", "-") arg_count = 0 for a in self.args: a.post_process(interface_prefix, cns, cns_upper, cns_lower, arg_count) arg_count += 1 - if utils.lookup_annotation(self.annotations, 'org.freedesktop.DBus.Deprecated') == 'true': + if ( + utils.lookup_annotation(self.annotations, "org.freedesktop.DBus.Deprecated") + == "true" + ): self.deprecated = True for a in self.annotations: a.post_process(interface_prefix, cns, cns_upper, cns_lower, self) + class Property: def __init__(self, name, signature, access): self.name = name self.signature = signature self.access = access self.annotations = [] - self.arg = Arg('value', self.signature) + self.arg = Arg("value", self.signature) self.arg.annotations = self.annotations self.readable = False self.writable = False - if self.access == 'readwrite': + if self.access == "readwrite": self.readable = True self.writable = True - elif self.access == 'read': + elif self.access == "read": self.readable = True - elif self.access == 'write': + elif self.access == "write": self.writable = True else: print_error('Invalid access type "{}"'.format(self.access)) - self.doc_string = '' - self.since = '' + self.doc_string = "" + self.since = "" self.deprecated = False self.emits_changed_signal = True - def post_process(self, interface_prefix, cns, cns_upper, cns_lower, containing_iface): + def post_process( + self, interface_prefix, cns, cns_upper, cns_lower, containing_iface + ): if len(self.doc_string) == 0: self.doc_string = utils.lookup_docs(self.annotations) if len(self.since) == 0: @@ -374,23 +404,28 @@ class Property: self.since = containing_iface.since name = self.name - overridden_name = utils.lookup_annotation(self.annotations, 'org.gtk.GDBus.C.Name') + overridden_name = utils.lookup_annotation( + self.annotations, "org.gtk.GDBus.C.Name" + ) if utils.is_ugly_case(overridden_name): self.name_lower = overridden_name.lower() else: if overridden_name: name = overridden_name - self.name_lower = utils.camel_case_to_uscore(name).lower().replace('-', '_') - self.name_hyphen = self.name_lower.replace('_', '-') + self.name_lower = utils.camel_case_to_uscore(name).lower().replace("-", "_") + self.name_hyphen = self.name_lower.replace("_", "-") # don't clash with the GType getter, e.g.: GType foo_bar_get_type (void); G_GNUC_CONST - if self.name_lower == 'type': - self.name_lower = 'type_' + if self.name_lower == "type": + self.name_lower = "type_" # recalculate arg self.arg.annotations = self.annotations self.arg.post_process(interface_prefix, cns, cns_upper, cns_lower, 0) - if utils.lookup_annotation(self.annotations, 'org.freedesktop.DBus.Deprecated') == 'true': + if ( + utils.lookup_annotation(self.annotations, "org.freedesktop.DBus.Deprecated") + == "true" + ): self.deprecated = True for a in self.annotations: @@ -399,9 +434,12 @@ class Property: # FIXME: for now we only support 'false' and 'const' on the signal itself, see #674913 and # http://dbus.freedesktop.org/doc/dbus-specification.html#introspection-format # for details - if utils.lookup_annotation(self.annotations, 'org.freedesktop.DBus.Property.EmitsChangedSignal') in ('false', 'const'): + if utils.lookup_annotation( + self.annotations, "org.freedesktop.DBus.Property.EmitsChangedSignal" + ) in ("false", "const"): self.emits_changed_signal = False + class Interface: def __init__(self, name): self.name = name @@ -409,9 +447,9 @@ class Interface: self.signals = [] self.properties = [] self.annotations = [] - self.doc_string = '' - self.doc_string_brief = '' - self.since = '' + self.doc_string = "" + self.doc_string_brief = "" + self.since = "" self.deprecated = False def post_process(self, interface_prefix, c_namespace): @@ -424,21 +462,23 @@ class Interface: if len(c_namespace) > 0: if utils.is_ugly_case(c_namespace): - cns = c_namespace.replace('_', '') - cns_upper = c_namespace.upper() + '_' - cns_lower = c_namespace.lower() + '_' + cns = c_namespace.replace("_", "") + cns_upper = c_namespace.upper() + "_" + cns_lower = c_namespace.lower() + "_" else: cns = c_namespace - cns_upper = utils.camel_case_to_uscore(c_namespace).upper() + '_' - cns_lower = utils.camel_case_to_uscore(c_namespace).lower() + '_' + cns_upper = utils.camel_case_to_uscore(c_namespace).upper() + "_" + cns_lower = utils.camel_case_to_uscore(c_namespace).lower() + "_" else: - cns = '' - cns_upper = '' - cns_lower = '' + cns = "" + cns_upper = "" + cns_lower = "" - overridden_name = utils.lookup_annotation(self.annotations, 'org.gtk.GDBus.C.Name') + overridden_name = utils.lookup_annotation( + self.annotations, "org.gtk.GDBus.C.Name" + ) if utils.is_ugly_case(overridden_name): - name = overridden_name.replace('_', '') + name = overridden_name.replace("_", "") name_with_ns = cns + name self.name_without_prefix = name self.camel_name = name_with_ns @@ -446,25 +486,28 @@ class Interface: self.name_lower = cns_lower + overridden_name.lower() self.name_upper = overridden_name.upper() - #print_error('handle Ugly_Case "{}"'.format(overridden_name)) + # print_error('handle Ugly_Case "{}"'.format(overridden_name)) else: if overridden_name: name = overridden_name else: name = self.name if name.startswith(interface_prefix): - name = name[len(interface_prefix):] + name = name[len(interface_prefix) :] self.name_without_prefix = name name = utils.strip_dots(name) - name_with_ns = utils.strip_dots(cns + '.' + name) + name_with_ns = utils.strip_dots(cns + "." + name) self.camel_name = name_with_ns self.ns_upper = cns_upper self.name_lower = cns_lower + utils.camel_case_to_uscore(name) self.name_upper = utils.camel_case_to_uscore(name).upper() - self.name_hyphen = self.name_upper.lower().replace('_', '-') + self.name_hyphen = self.name_upper.lower().replace("_", "-") - if utils.lookup_annotation(self.annotations, 'org.freedesktop.DBus.Deprecated') == 'true': + if ( + utils.lookup_annotation(self.annotations, "org.freedesktop.DBus.Deprecated") + == "true" + ): self.deprecated = True for m in self.methods: diff --git a/gio/gdbus-2.0/codegen/parser.py b/gio/gdbus-2.0/codegen/parser.py index 7dcc73558..d5aa0bfb5 100644 --- a/gio/gdbus-2.0/codegen/parser.py +++ b/gio/gdbus-2.0/codegen/parser.py @@ -25,16 +25,17 @@ import xml.parsers.expat from . import dbustypes from .utils import print_error + class DBusXMLParser: - STATE_TOP = 'top' - STATE_NODE = 'node' - STATE_INTERFACE = 'interface' - STATE_METHOD = 'method' - STATE_SIGNAL = 'signal' - STATE_PROPERTY = 'property' - STATE_ARG = 'arg' - STATE_ANNOTATION = 'annotation' - STATE_IGNORED = 'ignored' + STATE_TOP = "top" + STATE_NODE = "node" + STATE_INTERFACE = "interface" + STATE_METHOD = "method" + STATE_SIGNAL = "signal" + STATE_PROPERTY = "property" + STATE_ARG = "arg" + STATE_ANNOTATION = "annotation" + STATE_IGNORED = "ignored" def __init__(self, xml_data, h_type_implies_unix_fd=True): self._parser = xml.parsers.expat.ParserCreate() @@ -51,21 +52,22 @@ class DBusXMLParser: self._cur_object = None self._cur_object_stack = [] - self.doc_comment_last_symbol = '' + self.doc_comment_last_symbol = "" self._h_type_implies_unix_fd = h_type_implies_unix_fd self._parser.Parse(xml_data) - COMMENT_STATE_BEGIN = 'begin' - COMMENT_STATE_PARAMS = 'params' - COMMENT_STATE_BODY = 'body' - COMMENT_STATE_SKIP = 'skip' + COMMENT_STATE_BEGIN = "begin" + COMMENT_STATE_PARAMS = "params" + COMMENT_STATE_BODY = "body" + COMMENT_STATE_SKIP = "skip" + def handle_comment(self, data): - comment_state = DBusXMLParser.COMMENT_STATE_BEGIN; - lines = data.split('\n') - symbol = '' - body = '' + comment_state = DBusXMLParser.COMMENT_STATE_BEGIN + lines = data.split("\n") + symbol = "" + body = "" in_para = False params = {} for line in lines: @@ -73,59 +75,59 @@ class DBusXMLParser: line = line.lstrip() if comment_state == DBusXMLParser.COMMENT_STATE_BEGIN: if len(line) > 0: - colon_index = line.find(': ') + colon_index = line.find(": ") if colon_index == -1: - if line.endswith(':'): - symbol = line[0:len(line)-1] + if line.endswith(":"): + symbol = line[0 : len(line) - 1] comment_state = DBusXMLParser.COMMENT_STATE_PARAMS else: comment_state = DBusXMLParser.COMMENT_STATE_SKIP else: symbol = line[0:colon_index] - rest_of_line = line[colon_index+2:].strip() + rest_of_line = line[colon_index + 2 :].strip() if len(rest_of_line) > 0: - body += '<para>' + rest_of_line + '</para>' + body += "<para>" + rest_of_line + "</para>" comment_state = DBusXMLParser.COMMENT_STATE_PARAMS elif comment_state == DBusXMLParser.COMMENT_STATE_PARAMS: - if line.startswith('@'): - colon_index = line.find(': ') + if line.startswith("@"): + colon_index = line.find(": ") if colon_index == -1: comment_state = DBusXMLParser.COMMENT_STATE_BODY if not in_para: - body += '<para>' + body += "<para>" in_para = True - body += orig_line + '\n' + body += orig_line + "\n" else: param = line[1:colon_index] - docs = line[colon_index + 2:] + docs = line[colon_index + 2 :] params[param] = docs else: comment_state = DBusXMLParser.COMMENT_STATE_BODY if len(line) > 0: if not in_para: - body += '<para>' + body += "<para>" in_para = True - body += orig_line + '\n' + body += orig_line + "\n" elif comment_state == DBusXMLParser.COMMENT_STATE_BODY: if len(line) > 0: if not in_para: - body += '<para>' + body += "<para>" in_para = True - body += orig_line + '\n' + body += orig_line + "\n" else: if in_para: - body += '</para>' + body += "</para>" in_para = False if in_para: - body += '</para>' + body += "</para>" - if symbol != '': + if symbol != "": self.doc_comment_last_symbol = symbol self.doc_comment_params = params self.doc_comment_body = body def handle_char_data(self, data): - #print 'char_data=%s'%data + # print 'char_data=%s'%data pass def handle_start_element(self, name, attrs): @@ -141,77 +143,76 @@ class DBusXMLParser: elif self.state == DBusXMLParser.STATE_NODE: if name == DBusXMLParser.STATE_INTERFACE: self.state = DBusXMLParser.STATE_INTERFACE - iface = dbustypes.Interface(attrs['name']) + iface = dbustypes.Interface(attrs["name"]) self._cur_object = iface self.parsed_interfaces.append(iface) elif name == DBusXMLParser.STATE_ANNOTATION: self.state = DBusXMLParser.STATE_ANNOTATION - anno = dbustypes.Annotation(attrs['name'], attrs['value']) + anno = dbustypes.Annotation(attrs["name"], attrs["value"]) self._cur_object.annotations.append(anno) self._cur_object = anno else: self.state = DBusXMLParser.STATE_IGNORED # assign docs, if any - if 'name' in attrs and self.doc_comment_last_symbol == attrs['name']: + if "name" in attrs and self.doc_comment_last_symbol == attrs["name"]: self._cur_object.doc_string = self.doc_comment_body - if 'short_description' in self.doc_comment_params: - short_description = self.doc_comment_params['short_description'] + if "short_description" in self.doc_comment_params: + short_description = self.doc_comment_params["short_description"] self._cur_object.doc_string_brief = short_description - if 'since' in self.doc_comment_params: - self._cur_object.since = \ - self.doc_comment_params['since'].strip() + if "since" in self.doc_comment_params: + self._cur_object.since = self.doc_comment_params["since"].strip() elif self.state == DBusXMLParser.STATE_INTERFACE: if name == DBusXMLParser.STATE_METHOD: self.state = DBusXMLParser.STATE_METHOD - method = dbustypes.Method(attrs['name'], - h_type_implies_unix_fd=self._h_type_implies_unix_fd) + method = dbustypes.Method( + attrs["name"], h_type_implies_unix_fd=self._h_type_implies_unix_fd + ) self._cur_object.methods.append(method) self._cur_object = method elif name == DBusXMLParser.STATE_SIGNAL: self.state = DBusXMLParser.STATE_SIGNAL - signal = dbustypes.Signal(attrs['name']) + signal = dbustypes.Signal(attrs["name"]) self._cur_object.signals.append(signal) self._cur_object = signal elif name == DBusXMLParser.STATE_PROPERTY: self.state = DBusXMLParser.STATE_PROPERTY - prop = dbustypes.Property(attrs['name'], attrs['type'], attrs['access']) + prop = dbustypes.Property(attrs["name"], attrs["type"], attrs["access"]) self._cur_object.properties.append(prop) self._cur_object = prop elif name == DBusXMLParser.STATE_ANNOTATION: self.state = DBusXMLParser.STATE_ANNOTATION - anno = dbustypes.Annotation(attrs['name'], attrs['value']) + anno = dbustypes.Annotation(attrs["name"], attrs["value"]) self._cur_object.annotations.append(anno) self._cur_object = anno else: self.state = DBusXMLParser.STATE_IGNORED # assign docs, if any - if 'name' in attrs and self.doc_comment_last_symbol == attrs['name']: + if "name" in attrs and self.doc_comment_last_symbol == attrs["name"]: self._cur_object.doc_string = self.doc_comment_body - if 'since' in self.doc_comment_params: - self._cur_object.since = \ - self.doc_comment_params['since'].strip() + if "since" in self.doc_comment_params: + self._cur_object.since = self.doc_comment_params["since"].strip() elif self.state == DBusXMLParser.STATE_METHOD: if name == DBusXMLParser.STATE_ARG: self.state = DBusXMLParser.STATE_ARG arg_name = None - if 'name' in attrs: - arg_name = attrs['name'] - arg = dbustypes.Arg(arg_name, attrs['type']) - direction = attrs.get('direction', 'in') - if direction == 'in': + if "name" in attrs: + arg_name = attrs["name"] + arg = dbustypes.Arg(arg_name, attrs["type"]) + direction = attrs.get("direction", "in") + if direction == "in": self._cur_object.in_args.append(arg) - elif direction == 'out': + elif direction == "out": self._cur_object.out_args.append(arg) else: print_error('Invalid direction "{}"'.format(direction)) self._cur_object = arg elif name == DBusXMLParser.STATE_ANNOTATION: self.state = DBusXMLParser.STATE_ANNOTATION - anno = dbustypes.Annotation(attrs['name'], attrs['value']) + anno = dbustypes.Annotation(attrs["name"], attrs["value"]) self._cur_object.annotations.append(anno) self._cur_object = anno else: @@ -219,26 +220,27 @@ class DBusXMLParser: # assign docs, if any if self.doc_comment_last_symbol == old_cur_object.name: - if 'name' in attrs and attrs['name'] in self.doc_comment_params: - doc_string = self.doc_comment_params[attrs['name']] + if "name" in attrs and attrs["name"] in self.doc_comment_params: + doc_string = self.doc_comment_params[attrs["name"]] if doc_string != None: self._cur_object.doc_string = doc_string - if 'since' in self.doc_comment_params: - self._cur_object.since = \ - self.doc_comment_params['since'].strip() + if "since" in self.doc_comment_params: + self._cur_object.since = self.doc_comment_params[ + "since" + ].strip() elif self.state == DBusXMLParser.STATE_SIGNAL: if name == DBusXMLParser.STATE_ARG: self.state = DBusXMLParser.STATE_ARG arg_name = None - if 'name' in attrs: - arg_name = attrs['name'] - arg = dbustypes.Arg(arg_name, attrs['type']) + if "name" in attrs: + arg_name = attrs["name"] + arg = dbustypes.Arg(arg_name, attrs["type"]) self._cur_object.args.append(arg) self._cur_object = arg elif name == DBusXMLParser.STATE_ANNOTATION: self.state = DBusXMLParser.STATE_ANNOTATION - anno = dbustypes.Annotation(attrs['name'], attrs['value']) + anno = dbustypes.Annotation(attrs["name"], attrs["value"]) self._cur_object.annotations.append(anno) self._cur_object = anno else: @@ -246,18 +248,19 @@ class DBusXMLParser: # assign docs, if any if self.doc_comment_last_symbol == old_cur_object.name: - if 'name' in attrs and attrs['name'] in self.doc_comment_params: - doc_string = self.doc_comment_params[attrs['name']] + if "name" in attrs and attrs["name"] in self.doc_comment_params: + doc_string = self.doc_comment_params[attrs["name"]] if doc_string != None: self._cur_object.doc_string = doc_string - if 'since' in self.doc_comment_params: - self._cur_object.since = \ - self.doc_comment_params['since'].strip() + if "since" in self.doc_comment_params: + self._cur_object.since = self.doc_comment_params[ + "since" + ].strip() elif self.state == DBusXMLParser.STATE_PROPERTY: if name == DBusXMLParser.STATE_ANNOTATION: self.state = DBusXMLParser.STATE_ANNOTATION - anno = dbustypes.Annotation(attrs['name'], attrs['value']) + anno = dbustypes.Annotation(attrs["name"], attrs["value"]) self._cur_object.annotations.append(anno) self._cur_object = anno else: @@ -266,7 +269,7 @@ class DBusXMLParser: elif self.state == DBusXMLParser.STATE_ARG: if name == DBusXMLParser.STATE_ANNOTATION: self.state = DBusXMLParser.STATE_ANNOTATION - anno = dbustypes.Annotation(attrs['name'], attrs['value']) + anno = dbustypes.Annotation(attrs["name"], attrs["value"]) self._cur_object.annotations.append(anno) self._cur_object = anno else: @@ -275,14 +278,18 @@ class DBusXMLParser: elif self.state == DBusXMLParser.STATE_ANNOTATION: if name == DBusXMLParser.STATE_ANNOTATION: self.state = DBusXMLParser.STATE_ANNOTATION - anno = dbustypes.Annotation(attrs['name'], attrs['value']) + anno = dbustypes.Annotation(attrs["name"], attrs["value"]) self._cur_object.annotations.append(anno) self._cur_object = anno else: self.state = DBusXMLParser.STATE_IGNORED else: - print_error('Unhandled state "{}" while entering element with name "{}"'.format(self.state, name)) + print_error( + 'Unhandled state "{}" while entering element with name "{}"'.format( + self.state, name + ) + ) self.state_stack.append(old_state) self._cur_object_stack.append(old_cur_object) @@ -291,6 +298,7 @@ class DBusXMLParser: self.state = self.state_stack.pop() self._cur_object = self._cur_object_stack.pop() + def parse_dbus_xml(xml_data, h_type_implies_unix_fd): parser = DBusXMLParser(xml_data, h_type_implies_unix_fd) return parser.parsed_interfaces diff --git a/gio/gdbus-2.0/codegen/utils.py b/gio/gdbus-2.0/codegen/utils.py index 95ba107d3..af78e888b 100644 --- a/gio/gdbus-2.0/codegen/utils.py +++ b/gio/gdbus-2.0/codegen/utils.py @@ -25,47 +25,55 @@ import sys # pylint: disable=too-few-public-methods class Color: - '''ANSI Terminal colors''' - GREEN = '\033[1;32m' - BLUE = '\033[1;34m' - YELLOW = '\033[1;33m' - RED = '\033[1;31m' - END = '\033[0m' - -def print_color(msg, color=Color.END, prefix='MESSAGE'): - '''Print a string with a color prefix''' + """ANSI Terminal colors""" + + GREEN = "\033[1;32m" + BLUE = "\033[1;34m" + YELLOW = "\033[1;33m" + RED = "\033[1;31m" + END = "\033[0m" + + +def print_color(msg, color=Color.END, prefix="MESSAGE"): + """Print a string with a color prefix""" if os.isatty(sys.stderr.fileno()): - real_prefix = '{start}{prefix}{end}'.format(start=color, prefix=prefix, end=Color.END) + real_prefix = "{start}{prefix}{end}".format( + start=color, prefix=prefix, end=Color.END + ) else: real_prefix = prefix - sys.stderr.write('{prefix}: {msg}\n'.format(prefix=real_prefix, msg=msg)) + sys.stderr.write("{prefix}: {msg}\n".format(prefix=real_prefix, msg=msg)) + def print_error(msg): - '''Print an error, and terminate''' - print_color(msg, color=Color.RED, prefix='ERROR') + """Print an error, and terminate""" + print_color(msg, color=Color.RED, prefix="ERROR") sys.exit(1) + def print_warning(msg, fatal=False): - '''Print a warning, and optionally terminate''' + """Print a warning, and optionally terminate""" if fatal: color = Color.RED - prefix = 'ERROR' + prefix = "ERROR" else: color = Color.YELLOW - prefix = 'WARNING' + prefix = "WARNING" print_color(msg, color, prefix) if fatal: sys.exit(1) + def print_info(msg): - '''Print a message''' - print_color(msg, color=Color.GREEN, prefix='INFO') + """Print a message""" + print_color(msg, color=Color.GREEN, prefix="INFO") + def strip_dots(s): - ret = '' + ret = "" force_upper = False for c in s: - if c == '.': + if c == ".": force_upper = True else: if force_upper: @@ -75,19 +83,21 @@ def strip_dots(s): ret += c return ret + def dots_to_hyphens(s): - return s.replace('.', '-') + return s.replace(".", "-") + def camel_case_to_uscore(s): - ret = '' + ret = "" insert_uscore = False prev_was_lower = False - initial = True; + initial = True for c in s: # Keep initial underscores in camel case - if initial and c == '_': - ret += '_' - continue; + if initial and c == "_": + ret += "_" + continue initial = False if c.isupper(): @@ -97,16 +107,18 @@ def camel_case_to_uscore(s): else: prev_was_lower = True if insert_uscore: - ret += '_' + ret += "_" ret += c.lower() insert_uscore = False return ret + def is_ugly_case(s): - if s and s.find('_') > 0: + if s and s.find("_") > 0: return True return False + def lookup_annotation(annotations, key): if annotations: for a in annotations: @@ -114,35 +126,39 @@ def lookup_annotation(annotations, key): return a.value return None + def lookup_docs(annotations): - s = lookup_annotation(annotations, 'org.gtk.GDBus.DocString') + s = lookup_annotation(annotations, "org.gtk.GDBus.DocString") if s is None: - return '' + return "" else: return s + def lookup_since(annotations): - s = lookup_annotation(annotations, 'org.gtk.GDBus.Since') + s = lookup_annotation(annotations, "org.gtk.GDBus.Since") if s is None: - return '' + return "" else: return s + def lookup_brief_docs(annotations): - s = lookup_annotation(annotations, 'org.gtk.GDBus.DocString.Short') + s = lookup_annotation(annotations, "org.gtk.GDBus.DocString.Short") if s is None: - return '' + return "" else: return s + def version_cmp_key(key): # If the 'since' version is 'UNRELEASED', compare higher than anything else # If it is empty put a 0 in its place as this will # allow LooseVersion to work and will always compare lower. - if key[0] == 'UNRELEASED': - v = '9999' + if key[0] == "UNRELEASED": + v = "9999" elif key[0]: v = str(key[0]) else: - v = '0' + v = "0" return (distutils.version.LooseVersion(v), key[1]) diff --git a/gio/gio-querymodules-wrapper.py b/gio/gio-querymodules-wrapper.py index 8960540b4..351700d39 100644 --- a/gio/gio-querymodules-wrapper.py +++ b/gio/gio-querymodules-wrapper.py @@ -4,6 +4,6 @@ import os import subprocess import sys -if not os.environ.get('DESTDIR'): - print('GIO module cache creation...') - subprocess.call([sys.argv[1], sys.argv[2]]) +if not os.environ.get("DESTDIR"): + print("GIO module cache creation...") + subprocess.call([sys.argv[1], sys.argv[2]]) diff --git a/gio/tests/codegen.py b/gio/tests/codegen.py index 51de0ede4..8dbfc2245 100644 --- a/gio/tests/codegen.py +++ b/gio/tests/codegen.py @@ -32,7 +32,7 @@ import unittest import taptestrunner -Result = collections.namedtuple('Result', ('info', 'out', 'err', 'subs')) +Result = collections.namedtuple("Result", ("info", "out", "err", "subs")) class TestCodegen(unittest.TestCase): @@ -47,22 +47,27 @@ class TestCodegen(unittest.TestCase): parsing and generation code of gdbus-codegen into separate unit tests, and just test command line behaviour in this integration test. """ + # Track the cwd, we want to back out to that to clean up our tempdir - cwd = '' + cwd = "" def setUp(self): self.timeout_seconds = 10 # seconds per test self.tmpdir = tempfile.TemporaryDirectory() self.cwd = os.getcwd() os.chdir(self.tmpdir.name) - print('tmpdir:', self.tmpdir.name) - if 'G_TEST_BUILDDIR' in os.environ: - self.__codegen = \ - os.path.join(os.environ['G_TEST_BUILDDIR'], '..', - 'gdbus-2.0', 'codegen', 'gdbus-codegen') + print("tmpdir:", self.tmpdir.name) + if "G_TEST_BUILDDIR" in os.environ: + self.__codegen = os.path.join( + os.environ["G_TEST_BUILDDIR"], + "..", + "gdbus-2.0", + "codegen", + "gdbus-codegen", + ) else: - self.__codegen = shutil.which('gdbus-codegen') - print('codegen:', self.__codegen) + self.__codegen = shutil.which("gdbus-codegen") + print("codegen:", self.__codegen) def tearDown(self): os.chdir(self.cwd) @@ -73,201 +78,200 @@ class TestCodegen(unittest.TestCase): # shebang lines are not supported on native # Windows consoles - if os.name == 'nt': + if os.name == "nt": argv.insert(0, sys.executable) argv.extend(args) - print('Running:', argv) + print("Running:", argv) env = os.environ.copy() - env['LC_ALL'] = 'C.UTF-8' - print('Environment:', env) + env["LC_ALL"] = "C.UTF-8" + print("Environment:", env) # We want to ensure consistent line endings... - info = subprocess.run(argv, timeout=self.timeout_seconds, - stdout=subprocess.PIPE, - stderr=subprocess.PIPE, - env=env, - universal_newlines=True) + info = subprocess.run( + argv, + timeout=self.timeout_seconds, + stdout=subprocess.PIPE, + stderr=subprocess.PIPE, + env=env, + universal_newlines=True, + ) info.check_returncode() out = info.stdout.strip() err = info.stderr.strip() # Known substitutions for standard boilerplate subs = { - 'standard_top_comment': - '/*\n' - ' * This file is generated by gdbus-codegen, do not modify it.\n' - ' *\n' - ' * The license of this code is the same as for the D-Bus interface description\n' - ' * it was derived from. Note that it links to GLib, so must comply with the\n' - ' * LGPL linking clauses.\n' - ' */', - 'standard_config_h_include': - '#ifdef HAVE_CONFIG_H\n' - '# include "config.h"\n' - '#endif', - 'standard_header_includes': - '#include <string.h>\n' - '#ifdef G_OS_UNIX\n' - '# include <gio/gunixfdlist.h>\n' - '#endif', - 'standard_typedefs_and_helpers': - 'typedef struct\n' - '{\n' - ' GDBusArgInfo parent_struct;\n' - ' gboolean use_gvariant;\n' - '} _ExtendedGDBusArgInfo;\n' - '\n' - 'typedef struct\n' - '{\n' - ' GDBusMethodInfo parent_struct;\n' - ' const gchar *signal_name;\n' - ' gboolean pass_fdlist;\n' - '} _ExtendedGDBusMethodInfo;\n' - '\n' - 'typedef struct\n' - '{\n' - ' GDBusSignalInfo parent_struct;\n' - ' const gchar *signal_name;\n' - '} _ExtendedGDBusSignalInfo;\n' - '\n' - 'typedef struct\n' - '{\n' - ' GDBusPropertyInfo parent_struct;\n' - ' const gchar *hyphen_name;\n' - ' guint use_gvariant : 1;\n' - ' guint emits_changed_signal : 1;\n' - '} _ExtendedGDBusPropertyInfo;\n' - '\n' - 'typedef struct\n' - '{\n' - ' GDBusInterfaceInfo parent_struct;\n' - ' const gchar *hyphen_name;\n' - '} _ExtendedGDBusInterfaceInfo;\n' - '\n' - 'typedef struct\n' - '{\n' - ' const _ExtendedGDBusPropertyInfo *info;\n' - ' guint prop_id;\n' - ' GValue orig_value; /* the value before the change */\n' - '} ChangedProperty;\n' - '\n' - 'static void\n' - '_changed_property_free (ChangedProperty *data)\n' - '{\n' - ' g_value_unset (&data->orig_value);\n' - ' g_free (data);\n' - '}\n' - '\n' - 'static gboolean\n' - '_g_strv_equal0 (gchar **a, gchar **b)\n' - '{\n' - ' gboolean ret = FALSE;\n' - ' guint n;\n' - ' if (a == NULL && b == NULL)\n' - ' {\n' - ' ret = TRUE;\n' - ' goto out;\n' - ' }\n' - ' if (a == NULL || b == NULL)\n' - ' goto out;\n' - ' if (g_strv_length (a) != g_strv_length (b))\n' - ' goto out;\n' - ' for (n = 0; a[n] != NULL; n++)\n' - ' if (g_strcmp0 (a[n], b[n]) != 0)\n' - ' goto out;\n' - ' ret = TRUE;\n' - 'out:\n' - ' return ret;\n' - '}\n' - '\n' - 'static gboolean\n' - '_g_variant_equal0 (GVariant *a, GVariant *b)\n' - '{\n' - ' gboolean ret = FALSE;\n' - ' if (a == NULL && b == NULL)\n' - ' {\n' - ' ret = TRUE;\n' - ' goto out;\n' - ' }\n' - ' if (a == NULL || b == NULL)\n' - ' goto out;\n' - ' ret = g_variant_equal (a, b);\n' - 'out:\n' - ' return ret;\n' - '}\n' - '\n' - 'G_GNUC_UNUSED static gboolean\n' - '_g_value_equal (const GValue *a, const GValue *b)\n' - '{\n' - ' gboolean ret = FALSE;\n' - ' g_assert (G_VALUE_TYPE (a) == G_VALUE_TYPE (b));\n' - ' switch (G_VALUE_TYPE (a))\n' - ' {\n' - ' case G_TYPE_BOOLEAN:\n' - ' ret = (g_value_get_boolean (a) == g_value_get_boolean (b));\n' - ' break;\n' - ' case G_TYPE_UCHAR:\n' - ' ret = (g_value_get_uchar (a) == g_value_get_uchar (b));\n' - ' break;\n' - ' case G_TYPE_INT:\n' - ' ret = (g_value_get_int (a) == g_value_get_int (b));\n' - ' break;\n' - ' case G_TYPE_UINT:\n' - ' ret = (g_value_get_uint (a) == g_value_get_uint (b));\n' - ' break;\n' - ' case G_TYPE_INT64:\n' - ' ret = (g_value_get_int64 (a) == g_value_get_int64 (b));\n' - ' break;\n' - ' case G_TYPE_UINT64:\n' - ' ret = (g_value_get_uint64 (a) == g_value_get_uint64 (b));\n' - ' break;\n' - ' case G_TYPE_DOUBLE:\n' - ' {\n' - ' /* Avoid -Wfloat-equal warnings by doing a direct bit compare */\n' - ' gdouble da = g_value_get_double (a);\n' - ' gdouble db = g_value_get_double (b);\n' - ' ret = memcmp (&da, &db, sizeof (gdouble)) == 0;\n' - ' }\n' - ' break;\n' - ' case G_TYPE_STRING:\n' - ' ret = (g_strcmp0 (g_value_get_string (a), g_value_get_string (b)) == 0);\n' - ' break;\n' - ' case G_TYPE_VARIANT:\n' - ' ret = _g_variant_equal0 (g_value_get_variant (a), g_value_get_variant (b));\n' - ' break;\n' - ' default:\n' - ' if (G_VALUE_TYPE (a) == G_TYPE_STRV)\n' - ' ret = _g_strv_equal0 (g_value_get_boxed (a), g_value_get_boxed (b));\n' - ' else\n' - ' g_critical ("_g_value_equal() does not handle type %s", g_type_name (G_VALUE_TYPE (a)));\n' - ' break;\n' - ' }\n' - ' return ret;\n' - '}', + "standard_top_comment": "/*\n" + " * This file is generated by gdbus-codegen, do not modify it.\n" + " *\n" + " * The license of this code is the same as for the D-Bus interface description\n" + " * it was derived from. Note that it links to GLib, so must comply with the\n" + " * LGPL linking clauses.\n" + " */", + "standard_config_h_include": "#ifdef HAVE_CONFIG_H\n" + '# include "config.h"\n' + "#endif", + "standard_header_includes": "#include <string.h>\n" + "#ifdef G_OS_UNIX\n" + "# include <gio/gunixfdlist.h>\n" + "#endif", + "standard_typedefs_and_helpers": "typedef struct\n" + "{\n" + " GDBusArgInfo parent_struct;\n" + " gboolean use_gvariant;\n" + "} _ExtendedGDBusArgInfo;\n" + "\n" + "typedef struct\n" + "{\n" + " GDBusMethodInfo parent_struct;\n" + " const gchar *signal_name;\n" + " gboolean pass_fdlist;\n" + "} _ExtendedGDBusMethodInfo;\n" + "\n" + "typedef struct\n" + "{\n" + " GDBusSignalInfo parent_struct;\n" + " const gchar *signal_name;\n" + "} _ExtendedGDBusSignalInfo;\n" + "\n" + "typedef struct\n" + "{\n" + " GDBusPropertyInfo parent_struct;\n" + " const gchar *hyphen_name;\n" + " guint use_gvariant : 1;\n" + " guint emits_changed_signal : 1;\n" + "} _ExtendedGDBusPropertyInfo;\n" + "\n" + "typedef struct\n" + "{\n" + " GDBusInterfaceInfo parent_struct;\n" + " const gchar *hyphen_name;\n" + "} _ExtendedGDBusInterfaceInfo;\n" + "\n" + "typedef struct\n" + "{\n" + " const _ExtendedGDBusPropertyInfo *info;\n" + " guint prop_id;\n" + " GValue orig_value; /* the value before the change */\n" + "} ChangedProperty;\n" + "\n" + "static void\n" + "_changed_property_free (ChangedProperty *data)\n" + "{\n" + " g_value_unset (&data->orig_value);\n" + " g_free (data);\n" + "}\n" + "\n" + "static gboolean\n" + "_g_strv_equal0 (gchar **a, gchar **b)\n" + "{\n" + " gboolean ret = FALSE;\n" + " guint n;\n" + " if (a == NULL && b == NULL)\n" + " {\n" + " ret = TRUE;\n" + " goto out;\n" + " }\n" + " if (a == NULL || b == NULL)\n" + " goto out;\n" + " if (g_strv_length (a) != g_strv_length (b))\n" + " goto out;\n" + " for (n = 0; a[n] != NULL; n++)\n" + " if (g_strcmp0 (a[n], b[n]) != 0)\n" + " goto out;\n" + " ret = TRUE;\n" + "out:\n" + " return ret;\n" + "}\n" + "\n" + "static gboolean\n" + "_g_variant_equal0 (GVariant *a, GVariant *b)\n" + "{\n" + " gboolean ret = FALSE;\n" + " if (a == NULL && b == NULL)\n" + " {\n" + " ret = TRUE;\n" + " goto out;\n" + " }\n" + " if (a == NULL || b == NULL)\n" + " goto out;\n" + " ret = g_variant_equal (a, b);\n" + "out:\n" + " return ret;\n" + "}\n" + "\n" + "G_GNUC_UNUSED static gboolean\n" + "_g_value_equal (const GValue *a, const GValue *b)\n" + "{\n" + " gboolean ret = FALSE;\n" + " g_assert (G_VALUE_TYPE (a) == G_VALUE_TYPE (b));\n" + " switch (G_VALUE_TYPE (a))\n" + " {\n" + " case G_TYPE_BOOLEAN:\n" + " ret = (g_value_get_boolean (a) == g_value_get_boolean (b));\n" + " break;\n" + " case G_TYPE_UCHAR:\n" + " ret = (g_value_get_uchar (a) == g_value_get_uchar (b));\n" + " break;\n" + " case G_TYPE_INT:\n" + " ret = (g_value_get_int (a) == g_value_get_int (b));\n" + " break;\n" + " case G_TYPE_UINT:\n" + " ret = (g_value_get_uint (a) == g_value_get_uint (b));\n" + " break;\n" + " case G_TYPE_INT64:\n" + " ret = (g_value_get_int64 (a) == g_value_get_int64 (b));\n" + " break;\n" + " case G_TYPE_UINT64:\n" + " ret = (g_value_get_uint64 (a) == g_value_get_uint64 (b));\n" + " break;\n" + " case G_TYPE_DOUBLE:\n" + " {\n" + " /* Avoid -Wfloat-equal warnings by doing a direct bit compare */\n" + " gdouble da = g_value_get_double (a);\n" + " gdouble db = g_value_get_double (b);\n" + " ret = memcmp (&da, &db, sizeof (gdouble)) == 0;\n" + " }\n" + " break;\n" + " case G_TYPE_STRING:\n" + " ret = (g_strcmp0 (g_value_get_string (a), g_value_get_string (b)) == 0);\n" + " break;\n" + " case G_TYPE_VARIANT:\n" + " ret = _g_variant_equal0 (g_value_get_variant (a), g_value_get_variant (b));\n" + " break;\n" + " default:\n" + " if (G_VALUE_TYPE (a) == G_TYPE_STRV)\n" + " ret = _g_strv_equal0 (g_value_get_boxed (a), g_value_get_boxed (b));\n" + " else\n" + ' g_critical ("_g_value_equal() does not handle type %s", g_type_name (G_VALUE_TYPE (a)));\n' + " break;\n" + " }\n" + " return ret;\n" + "}", } result = Result(info, out, err, subs) - print('Output:', result.out) + print("Output:", result.out) return result def runCodegenWithInterface(self, interface_contents, *args): - with tempfile.NamedTemporaryFile(dir=self.tmpdir.name, - suffix='.xml', - delete=False) as interface_file: + with tempfile.NamedTemporaryFile( + dir=self.tmpdir.name, suffix=".xml", delete=False + ) as interface_file: # Write out the interface. - interface_file.write(interface_contents.encode('utf-8')) - print(interface_file.name + ':', interface_contents) + interface_file.write(interface_contents.encode("utf-8")) + print(interface_file.name + ":", interface_contents) interface_file.flush() return self.runCodegen(interface_file.name, *args) def test_help(self): """Test the --help argument.""" - result = self.runCodegen('--help') - self.assertIn('usage: gdbus-codegen', result.out) + result = self.runCodegen("--help") + self.assertIn("usage: gdbus-codegen", result.out) def test_no_args(self): """Test running with no arguments at all.""" @@ -276,11 +280,10 @@ class TestCodegen(unittest.TestCase): def test_empty_interface_header(self): """Test generating a header with an empty interface file.""" - result = self.runCodegenWithInterface('', - '--output', '/dev/stdout', - '--header') - self.assertEqual('', result.err) - self.assertEqual('''{standard_top_comment} + result = self.runCodegenWithInterface("", "--output", "/dev/stdout", "--header") + self.assertEqual("", result.err) + self.assertEqual( + """{standard_top_comment} #ifndef __STDOUT__ #define __STDOUT__ @@ -292,16 +295,18 @@ G_BEGIN_DECLS G_END_DECLS -#endif /* __STDOUT__ */'''.format(**result.subs), - result.out.strip()) +#endif /* __STDOUT__ */""".format( + **result.subs + ), + result.out.strip(), + ) def test_empty_interface_body(self): """Test generating a body with an empty interface file.""" - result = self.runCodegenWithInterface('', - '--output', '/dev/stdout', - '--body') - self.assertEqual('', result.err) - self.assertEqual('''{standard_top_comment} + result = self.runCodegenWithInterface("", "--output", "/dev/stdout", "--body") + self.assertEqual("", result.err) + self.assertEqual( + """{standard_top_comment} {standard_config_h_include} @@ -309,12 +314,15 @@ G_END_DECLS {standard_header_includes} -{standard_typedefs_and_helpers}'''.format(**result.subs), - result.out.strip()) +{standard_typedefs_and_helpers}""".format( + **result.subs + ), + result.out.strip(), + ) def test_reproducible(self): """Test builds are reproducible regardless of file ordering.""" - xml_contents1 = ''' + xml_contents1 = """ <node> <interface name="com.acme.Coyote"> <method name="Run"/> @@ -324,40 +332,49 @@ G_END_DECLS <property name="Mood" type="s" access="read"/> </interface> </node> - ''' + """ - xml_contents2 = ''' + xml_contents2 = """ <node> <interface name="org.project.Bar.Frobnicator"> <method name="RandomMethod"/> </interface> </node> - ''' + """ - with tempfile.NamedTemporaryFile(dir=self.tmpdir.name, - suffix='1.xml', delete=False) as xml_file1, \ - tempfile.NamedTemporaryFile(dir=self.tmpdir.name, - suffix='2.xml', delete=False) as xml_file2: + with tempfile.NamedTemporaryFile( + dir=self.tmpdir.name, suffix="1.xml", delete=False + ) as xml_file1, tempfile.NamedTemporaryFile( + dir=self.tmpdir.name, suffix="2.xml", delete=False + ) as xml_file2: # Write out the interfaces. - xml_file1.write(xml_contents1.encode('utf-8')) - xml_file2.write(xml_contents2.encode('utf-8')) + xml_file1.write(xml_contents1.encode("utf-8")) + xml_file2.write(xml_contents2.encode("utf-8")) xml_file1.flush() xml_file2.flush() # Repeat this for headers and bodies. - for header_or_body in ['--header', '--body']: + for header_or_body in ["--header", "--body"]: # Run gdbus-codegen with the interfaces in one order, and then # again in another order. - result1 = self.runCodegen(xml_file1.name, xml_file2.name, - '--output', '/dev/stdout', - header_or_body) - self.assertEqual('', result1.err) - - result2 = self.runCodegen(xml_file2.name, xml_file1.name, - '--output', '/dev/stdout', - header_or_body) - self.assertEqual('', result2.err) + result1 = self.runCodegen( + xml_file1.name, + xml_file2.name, + "--output", + "/dev/stdout", + header_or_body, + ) + self.assertEqual("", result1.err) + + result2 = self.runCodegen( + xml_file2.name, + xml_file1.name, + "--output", + "/dev/stdout", + header_or_body, + ) + self.assertEqual("", result2.err) # The output should be the same. self.assertEqual(result1.out, result2.out) @@ -365,94 +382,108 @@ G_END_DECLS def test_glib_min_required_invalid(self): """Test running with an invalid --glib-min-required.""" with self.assertRaises(subprocess.CalledProcessError): - self.runCodegenWithInterface('', - '--output', '/dev/stdout', - '--body', - '--glib-min-required', 'hello mum') + self.runCodegenWithInterface( + "", + "--output", + "/dev/stdout", + "--body", + "--glib-min-required", + "hello mum", + ) def test_glib_min_required_too_low(self): """Test running with a --glib-min-required which is too low (and hence probably a typo).""" with self.assertRaises(subprocess.CalledProcessError): - self.runCodegenWithInterface('', - '--output', '/dev/stdout', - '--body', - '--glib-min-required', '2.6') + self.runCodegenWithInterface( + "", "--output", "/dev/stdout", "--body", "--glib-min-required", "2.6" + ) def test_glib_min_required_major_only(self): """Test running with a --glib-min-required which contains only a major version.""" - result = self.runCodegenWithInterface('', - '--output', '/dev/stdout', - '--header', - '--glib-min-required', '3', - '--glib-max-allowed', '3.2') - self.assertEqual('', result.err) - self.assertNotEqual('', result.out.strip()) + result = self.runCodegenWithInterface( + "", + "--output", + "/dev/stdout", + "--header", + "--glib-min-required", + "3", + "--glib-max-allowed", + "3.2", + ) + self.assertEqual("", result.err) + self.assertNotEqual("", result.out.strip()) def test_glib_min_required_with_micro(self): """Test running with a --glib-min-required which contains a micro version.""" - result = self.runCodegenWithInterface('', - '--output', '/dev/stdout', - '--header', - '--glib-min-required', '2.46.2') - self.assertEqual('', result.err) - self.assertNotEqual('', result.out.strip()) + result = self.runCodegenWithInterface( + "", "--output", "/dev/stdout", "--header", "--glib-min-required", "2.46.2" + ) + self.assertEqual("", result.err) + self.assertNotEqual("", result.out.strip()) def test_glib_max_allowed_too_low(self): """Test running with a --glib-max-allowed which is too low (and hence probably a typo).""" with self.assertRaises(subprocess.CalledProcessError): - self.runCodegenWithInterface('', - '--output', '/dev/stdout', - '--body', - '--glib-max-allowed', '2.6') + self.runCodegenWithInterface( + "", "--output", "/dev/stdout", "--body", "--glib-max-allowed", "2.6" + ) def test_glib_max_allowed_major_only(self): """Test running with a --glib-max-allowed which contains only a major version.""" - result = self.runCodegenWithInterface('', - '--output', '/dev/stdout', - '--header', - '--glib-max-allowed', '3') - self.assertEqual('', result.err) - self.assertNotEqual('', result.out.strip()) + result = self.runCodegenWithInterface( + "", "--output", "/dev/stdout", "--header", "--glib-max-allowed", "3" + ) + self.assertEqual("", result.err) + self.assertNotEqual("", result.out.strip()) def test_glib_max_allowed_with_micro(self): """Test running with a --glib-max-allowed which contains a micro version.""" - result = self.runCodegenWithInterface('', - '--output', '/dev/stdout', - '--header', - '--glib-max-allowed', '2.46.2') - self.assertEqual('', result.err) - self.assertNotEqual('', result.out.strip()) + result = self.runCodegenWithInterface( + "", "--output", "/dev/stdout", "--header", "--glib-max-allowed", "2.46.2" + ) + self.assertEqual("", result.err) + self.assertNotEqual("", result.out.strip()) def test_glib_max_allowed_unstable(self): """Test running with a --glib-max-allowed which is unstable. It should be rounded up to the next stable version number, and hence should not end up less than --glib-min-required.""" - result = self.runCodegenWithInterface('', - '--output', '/dev/stdout', - '--header', - '--glib-max-allowed', '2.63', - '--glib-min-required', '2.64') - self.assertEqual('', result.err) - self.assertNotEqual('', result.out.strip()) + result = self.runCodegenWithInterface( + "", + "--output", + "/dev/stdout", + "--header", + "--glib-max-allowed", + "2.63", + "--glib-min-required", + "2.64", + ) + self.assertEqual("", result.err) + self.assertNotEqual("", result.out.strip()) def test_glib_max_allowed_less_than_min_required(self): """Test running with a --glib-max-allowed which is less than --glib-min-required.""" with self.assertRaises(subprocess.CalledProcessError): - self.runCodegenWithInterface('', - '--output', '/dev/stdout', - '--body', - '--glib-max-allowed', '2.62', - '--glib-min-required', '2.64') + self.runCodegenWithInterface( + "", + "--output", + "/dev/stdout", + "--body", + "--glib-max-allowed", + "2.62", + "--glib-min-required", + "2.64", + ) def test_unix_fd_types_and_annotations(self): """Test an interface with `h` arguments, no annotation, and GLib < 2.64. See issue #1726. """ - interface_xml = ''' + interface_xml = """ <node> <interface name="FDPassing"> <method name="HelloFD"> @@ -470,71 +501,87 @@ G_END_DECLS <arg name="files" type="a{sh}" direction="in"/> </method> </interface> - </node>''' + </node>""" # Try without specifying --glib-min-required. - result = self.runCodegenWithInterface(interface_xml, - '--output', '/dev/stdout', - '--header') - self.assertEqual('', result.err) - self.assertEqual(result.out.strip().count('GUnixFDList'), 6) + result = self.runCodegenWithInterface( + interface_xml, "--output", "/dev/stdout", "--header" + ) + self.assertEqual("", result.err) + self.assertEqual(result.out.strip().count("GUnixFDList"), 6) # Specify an old --glib-min-required. - result = self.runCodegenWithInterface(interface_xml, - '--output', '/dev/stdout', - '--header', - '--glib-min-required', '2.32') - self.assertEqual('', result.err) - self.assertEqual(result.out.strip().count('GUnixFDList'), 6) + result = self.runCodegenWithInterface( + interface_xml, + "--output", + "/dev/stdout", + "--header", + "--glib-min-required", + "2.32", + ) + self.assertEqual("", result.err) + self.assertEqual(result.out.strip().count("GUnixFDList"), 6) # Specify a --glib-min-required ≥ 2.64. There should be more # mentions of `GUnixFDList` now, since the annotation is not needed to # trigger its use. - result = self.runCodegenWithInterface(interface_xml, - '--output', '/dev/stdout', - '--header', - '--glib-min-required', '2.64') - self.assertEqual('', result.err) - self.assertEqual(result.out.strip().count('GUnixFDList'), 18) + result = self.runCodegenWithInterface( + interface_xml, + "--output", + "/dev/stdout", + "--header", + "--glib-min-required", + "2.64", + ) + self.assertEqual("", result.err) + self.assertEqual(result.out.strip().count("GUnixFDList"), 18) def test_call_flags_and_timeout_method_args(self): """Test that generated method call functions have @call_flags and @timeout_msec args if and only if GLib >= 2.64. """ - interface_xml = ''' + interface_xml = """ <node> <interface name="org.project.UsefulInterface"> <method name="UsefulMethod"/> </interface> - </node>''' + </node>""" # Try without specifying --glib-min-required. - result = self.runCodegenWithInterface(interface_xml, - '--output', '/dev/stdout', - '--header') - self.assertEqual('', result.err) - self.assertEqual(result.out.strip().count('GDBusCallFlags call_flags,'), 0) - self.assertEqual(result.out.strip().count('gint timeout_msec,'), 0) + result = self.runCodegenWithInterface( + interface_xml, "--output", "/dev/stdout", "--header" + ) + self.assertEqual("", result.err) + self.assertEqual(result.out.strip().count("GDBusCallFlags call_flags,"), 0) + self.assertEqual(result.out.strip().count("gint timeout_msec,"), 0) # Specify an old --glib-min-required. - result = self.runCodegenWithInterface(interface_xml, - '--output', '/dev/stdout', - '--header', - '--glib-min-required', '2.32') - self.assertEqual('', result.err) - self.assertEqual(result.out.strip().count('GDBusCallFlags call_flags,'), 0) - self.assertEqual(result.out.strip().count('gint timeout_msec,'), 0) + result = self.runCodegenWithInterface( + interface_xml, + "--output", + "/dev/stdout", + "--header", + "--glib-min-required", + "2.32", + ) + self.assertEqual("", result.err) + self.assertEqual(result.out.strip().count("GDBusCallFlags call_flags,"), 0) + self.assertEqual(result.out.strip().count("gint timeout_msec,"), 0) # Specify a --glib-min-required ≥ 2.64. The two arguments should be # present for both the async and sync method call functions. - result = self.runCodegenWithInterface(interface_xml, - '--output', '/dev/stdout', - '--header', - '--glib-min-required', '2.64') - self.assertEqual('', result.err) - self.assertEqual(result.out.strip().count('GDBusCallFlags call_flags,'), 2) - self.assertEqual(result.out.strip().count('gint timeout_msec,'), 2) - - -if __name__ == '__main__': + result = self.runCodegenWithInterface( + interface_xml, + "--output", + "/dev/stdout", + "--header", + "--glib-min-required", + "2.64", + ) + self.assertEqual("", result.err) + self.assertEqual(result.out.strip().count("GDBusCallFlags call_flags,"), 2) + self.assertEqual(result.out.strip().count("gint timeout_msec,"), 2) + + +if __name__ == "__main__": unittest.main(testRunner=taptestrunner.TAPTestRunner()) diff --git a/gio/tests/gen-big-test-resource.py b/gio/tests/gen-big-test-resource.py index e031a0a08..8e5e61efe 100644 --- a/gio/tests/gen-big-test-resource.py +++ b/gio/tests/gen-big-test-resource.py @@ -13,9 +13,9 @@ import string import sys if len(sys.argv) != 2: - raise SystemExit('Usage: %s <output-file>' % sys.argv[0]) + raise SystemExit("Usage: %s <output-file>" % sys.argv[0]) -with open(sys.argv[1], 'w', newline='\n') as f: +with open(sys.argv[1], "w", newline="\n") as f: for count in range(12): for c in string.ascii_lowercase: f.write("%s\n" % (c * 100)) diff --git a/gio/tests/gengiotypefuncs.py b/gio/tests/gengiotypefuncs.py index 47219f357..4585d29ae 100644 --- a/gio/tests/gengiotypefuncs.py +++ b/gio/tests/gengiotypefuncs.py @@ -5,7 +5,7 @@ import sys import re import os -debug = os.getenv('GIO_GENTYPEFUNCS_DEBUG') is not None +debug = os.getenv("GIO_GENTYPEFUNCS_DEBUG") is not None out_file = sys.argv[1] in_files = sys.argv[2:] @@ -13,32 +13,37 @@ in_files = sys.argv[2:] funcs = [] -if debug: print ('Output file: ', out_file) +if debug: + print("Output file: ", out_file) -if debug: print (len(in_files), 'input files') +if debug: + print(len(in_files), "input files") for filename in in_files: - if debug: print ('Input file: ', filename) - with open(filename, 'rb') as f: - for line in f: - line = line.rstrip(b'\n').rstrip(b'\r') - # print line - match = re.search(b'\bg_[a-zA-Z0-9_]*_get_type\b', line) - if match: - func = match.group(0) - if not func in funcs: - funcs.append(func) - if debug: print ('Found ', func) - -file_output = 'G_GNUC_BEGIN_IGNORE_DEPRECATIONS\n' + if debug: + print("Input file: ", filename) + with open(filename, "rb") as f: + for line in f: + line = line.rstrip(b"\n").rstrip(b"\r") + # print line + match = re.search(b"\bg_[a-zA-Z0-9_]*_get_type\b", line) + if match: + func = match.group(0) + if not func in funcs: + funcs.append(func) + if debug: + print("Found ", func) + +file_output = "G_GNUC_BEGIN_IGNORE_DEPRECATIONS\n" funcs = sorted(funcs) for f in funcs: - if f not in ['g_io_extension_get_type', 'g_settings_backend_get_type']: - file_output += '*tp++ = {0} ();\n'.format(f) + if f not in ["g_io_extension_get_type", "g_settings_backend_get_type"]: + file_output += "*tp++ = {0} ();\n".format(f) -if debug: print (len(funcs), 'functions') +if debug: + print(len(funcs), "functions") ofile = open(out_file, "w") ofile.write(file_output) diff --git a/gio/tests/static-link.py b/gio/tests/static-link.py index e0a064a7a..8bd26359b 100755 --- a/gio/tests/static-link.py +++ b/gio/tests/static-link.py @@ -23,29 +23,33 @@ import sys import tempfile import subprocess -if not 'GLIB_TEST_COMPILATION' in os.environ: - print('''Test disabled because GLIB_TEST_COMPILATION is not set in the env. +if not "GLIB_TEST_COMPILATION" in os.environ: + print( + """Test disabled because GLIB_TEST_COMPILATION is not set in the env. If you wish to run this test, set GLIB_TEST_COMPILATION=1 in the env, and make sure you have glib build dependencies installed, including -meson.''') - sys.exit(77) +meson.""" + ) + sys.exit(77) if len(sys.argv) != 2: - print('Usage: {} <gio-2.0.pc dir>'.format(os.path.basename(sys.argv[0]))) - sys.exit(1) + print("Usage: {} <gio-2.0.pc dir>".format(os.path.basename(sys.argv[0]))) + sys.exit(1) test_dir = os.path.dirname(sys.argv[0]) with tempfile.TemporaryDirectory() as builddir: - env = os.environ.copy() - env['PKG_CONFIG_PATH'] = sys.argv[1] - sourcedir = os.path.join(test_dir, 'static-link') + env = os.environ.copy() + env["PKG_CONFIG_PATH"] = sys.argv[1] + sourcedir = os.path.join(test_dir, "static-link") - # Ensure we can static link and run a test app - subprocess.check_call(['meson', sourcedir, builddir], env=env) - subprocess.check_call(['ninja', '-C', builddir, 'test'], env=env) - # FIXME: This probably only works on Linux - out = subprocess.check_output(['ldd', os.path.join(builddir, 'test-static-link')], env=env).decode() - if 'libgio' in out: - print('test-static-link is dynamically linked on libgio') - exit(1) + # Ensure we can static link and run a test app + subprocess.check_call(["meson", sourcedir, builddir], env=env) + subprocess.check_call(["ninja", "-C", builddir, "test"], env=env) + # FIXME: This probably only works on Linux + out = subprocess.check_output( + ["ldd", os.path.join(builddir, "test-static-link")], env=env + ).decode() + if "libgio" in out: + print("test-static-link is dynamically linked on libgio") + exit(1) diff --git a/gio/tests/taptestrunner.py b/gio/tests/taptestrunner.py index 261496197..af53db43e 100644 --- a/gio/tests/taptestrunner.py +++ b/gio/tests/taptestrunner.py @@ -31,146 +31,155 @@ import base64 from io import StringIO # Log modes -class LogMode(object) : - LogToError, LogToDiagnostics, LogToYAML, LogToAttachment = range(4) +class LogMode(object): + LogToError, LogToDiagnostics, LogToYAML, LogToAttachment = range(4) class TAPTestResult(unittest.TestResult): - def __init__(self, output_stream, error_stream, message_log, test_output_log): - super(TAPTestResult, self).__init__(self, output_stream) - self.output_stream = output_stream - self.error_stream = error_stream - self.orig_stdout = None - self.orig_stderr = None - self.message = None - self.test_output = None - self.message_log = message_log - self.test_output_log = test_output_log - self.output_stream.write("TAP version 13\n") - self._set_streams() - - def printErrors(self): - self.print_raw("1..%d\n" % self.testsRun) - self._reset_streams() - - def _set_streams(self): - self.orig_stdout = sys.stdout - self.orig_stderr = sys.stderr - if self.message_log == LogMode.LogToError: - self.message = self.error_stream - else: - self.message = StringIO() - if self.test_output_log == LogMode.LogToError: - self.test_output = self.error_stream - else: - self.test_output = StringIO() - - if self.message_log == self.test_output_log: - self.test_output = self.message - sys.stdout = sys.stderr = self.test_output - - def _reset_streams(self): - sys.stdout = self.orig_stdout - sys.stderr = self.orig_stderr - - - def print_raw(self, text): - self.output_stream.write(text) - self.output_stream.flush() - - def print_result(self, result, test, directive = None): - self.output_stream.write("%s %d %s" % (result, self.testsRun, test.id())) - if directive: - self.output_stream.write(" # " + directive) - self.output_stream.write("\n") - self.output_stream.flush() - - def ok(self, test, directive = None): - self.print_result("ok", test, directive) - - def not_ok(self, test): - self.print_result("not ok", test) - - def startTest(self, test): - super(TAPTestResult, self).startTest(test) - - def stopTest(self, test): - super(TAPTestResult, self).stopTest(test) - if self.message_log == self.test_output_log: - logs = [(self.message_log, self.message, "output")] - else: - logs = [ - (self.test_output_log, self.test_output, "test_output"), - (self.message_log, self.message, "message") - ] - for log_mode, log, log_name in logs: - if log_mode != LogMode.LogToError: - output = log.getvalue() - if len(output): - if log_mode == LogMode.LogToYAML: - self.print_raw(" ---\n") - self.print_raw(" " + log_name + ": |\n") - self.print_raw(" " + output.rstrip().replace("\n", "\n ") + "\n") - self.print_raw(" ...\n") - elif log_mode == LogMode.LogToAttachment: - self.print_raw(" ---\n") - self.print_raw(" " + log_name + ":\n") - self.print_raw(" File-Name: " + log_name + ".txt\n") - self.print_raw(" File-Type: text/plain\n") - self.print_raw(" File-Content: " + base64.b64encode(output) + "\n") - self.print_raw(" ...\n") - else: - self.print_raw("# " + output.rstrip().replace("\n", "\n# ") + "\n") - # Truncate doesn't change the current stream position. - # Seek to the beginning to avoid extensions on subsequent writes. - log.seek(0) - log.truncate(0) - - def addSuccess(self, test): - super(TAPTestResult, self).addSuccess(test) - self.ok(test) - - def addError(self, test, err): - super(TAPTestResult, self).addError(test, err) - self.message.write(self.errors[-1][1] + "\n") - self.not_ok(test) - - def addFailure(self, test, err): - super(TAPTestResult, self).addFailure(test, err) - self.message.write(self.failures[-1][1] + "\n") - self.not_ok(test) - - def addSkip(self, test, reason): - super(TAPTestResult, self).addSkip(test, reason) - self.ok(test, "SKIP " + reason) - - def addExpectedFailure(self, test, err): - super(TAPTestResult, self).addExpectedFailure(test, err) - self.ok(test) - - def addUnexpectedSuccess(self, test): - super(TAPTestResult, self).addUnexpectedSuccess(test) - self.message.write("Unexpected success" + "\n") - self.not_ok(test) + def __init__(self, output_stream, error_stream, message_log, test_output_log): + super(TAPTestResult, self).__init__(self, output_stream) + self.output_stream = output_stream + self.error_stream = error_stream + self.orig_stdout = None + self.orig_stderr = None + self.message = None + self.test_output = None + self.message_log = message_log + self.test_output_log = test_output_log + self.output_stream.write("TAP version 13\n") + self._set_streams() + + def printErrors(self): + self.print_raw("1..%d\n" % self.testsRun) + self._reset_streams() + + def _set_streams(self): + self.orig_stdout = sys.stdout + self.orig_stderr = sys.stderr + if self.message_log == LogMode.LogToError: + self.message = self.error_stream + else: + self.message = StringIO() + if self.test_output_log == LogMode.LogToError: + self.test_output = self.error_stream + else: + self.test_output = StringIO() + + if self.message_log == self.test_output_log: + self.test_output = self.message + sys.stdout = sys.stderr = self.test_output + + def _reset_streams(self): + sys.stdout = self.orig_stdout + sys.stderr = self.orig_stderr + + def print_raw(self, text): + self.output_stream.write(text) + self.output_stream.flush() + + def print_result(self, result, test, directive=None): + self.output_stream.write("%s %d %s" % (result, self.testsRun, test.id())) + if directive: + self.output_stream.write(" # " + directive) + self.output_stream.write("\n") + self.output_stream.flush() + + def ok(self, test, directive=None): + self.print_result("ok", test, directive) + + def not_ok(self, test): + self.print_result("not ok", test) + + def startTest(self, test): + super(TAPTestResult, self).startTest(test) + + def stopTest(self, test): + super(TAPTestResult, self).stopTest(test) + if self.message_log == self.test_output_log: + logs = [(self.message_log, self.message, "output")] + else: + logs = [ + (self.test_output_log, self.test_output, "test_output"), + (self.message_log, self.message, "message"), + ] + for log_mode, log, log_name in logs: + if log_mode != LogMode.LogToError: + output = log.getvalue() + if len(output): + if log_mode == LogMode.LogToYAML: + self.print_raw(" ---\n") + self.print_raw(" " + log_name + ": |\n") + self.print_raw( + " " + output.rstrip().replace("\n", "\n ") + "\n" + ) + self.print_raw(" ...\n") + elif log_mode == LogMode.LogToAttachment: + self.print_raw(" ---\n") + self.print_raw(" " + log_name + ":\n") + self.print_raw(" File-Name: " + log_name + ".txt\n") + self.print_raw(" File-Type: text/plain\n") + self.print_raw( + " File-Content: " + base64.b64encode(output) + "\n" + ) + self.print_raw(" ...\n") + else: + self.print_raw( + "# " + output.rstrip().replace("\n", "\n# ") + "\n" + ) + # Truncate doesn't change the current stream position. + # Seek to the beginning to avoid extensions on subsequent writes. + log.seek(0) + log.truncate(0) + + def addSuccess(self, test): + super(TAPTestResult, self).addSuccess(test) + self.ok(test) + + def addError(self, test, err): + super(TAPTestResult, self).addError(test, err) + self.message.write(self.errors[-1][1] + "\n") + self.not_ok(test) + + def addFailure(self, test, err): + super(TAPTestResult, self).addFailure(test, err) + self.message.write(self.failures[-1][1] + "\n") + self.not_ok(test) + + def addSkip(self, test, reason): + super(TAPTestResult, self).addSkip(test, reason) + self.ok(test, "SKIP " + reason) + + def addExpectedFailure(self, test, err): + super(TAPTestResult, self).addExpectedFailure(test, err) + self.ok(test) + + def addUnexpectedSuccess(self, test): + super(TAPTestResult, self).addUnexpectedSuccess(test) + self.message.write("Unexpected success" + "\n") + self.not_ok(test) class TAPTestRunner(object): - def __init__(self, - message_log = LogMode.LogToYAML, - test_output_log = LogMode.LogToDiagnostics, - output_stream = sys.stdout, error_stream = sys.stderr): - self.output_stream = output_stream - self.error_stream = error_stream - self.message_log = message_log - self.test_output_log = test_output_log - - def run(self, test): - result = TAPTestResult( - self.output_stream, - self.error_stream, - self.message_log, - self.test_output_log) - test(result) - result.printErrors() - - return result + def __init__( + self, + message_log=LogMode.LogToYAML, + test_output_log=LogMode.LogToDiagnostics, + output_stream=sys.stdout, + error_stream=sys.stderr, + ): + self.output_stream = output_stream + self.error_stream = error_stream + self.message_log = message_log + self.test_output_log = test_output_log + + def run(self, test): + result = TAPTestResult( + self.output_stream, + self.error_stream, + self.message_log, + self.test_output_log, + ) + test(result) + result.printErrors() + + return result |