From 790bd8a474c2820564afc57a60f20f3deb4e0d42 Mon Sep 17 00:00:00 2001 From: Emmanuele Bassi Date: Sun, 8 Jan 2023 14:20:06 +0000 Subject: Skip default-value for non-transformable properties If we can't transform a property default value to string, we are not going to add a default-value attribute to the GIR. This is necessary because non-transformable values may not always be pointers, so we cannot default to "NULL". --- girepository/gdump.c | 32 ++++++++++++++++-------- giscanner/gdumpparser.py | 2 +- tests/scanner/Regress-1.0-expected.gir | 45 +++++++++------------------------- 3 files changed, 34 insertions(+), 45 deletions(-) diff --git a/girepository/gdump.c b/girepository/gdump.c index 3ee687b6..e68c4d14 100644 --- a/girepository/gdump.c +++ b/girepository/gdump.c @@ -137,20 +137,22 @@ value_to_string (const GValue *value) else if (g_value_type_transformable (G_VALUE_TYPE (value), G_TYPE_STRING)) { GValue tmp = G_VALUE_INIT; - char *s; + char *s = NULL; g_value_init (&tmp, G_TYPE_STRING); - g_value_transform (value, &tmp); - s = g_strescape (g_value_get_string (&tmp), NULL); + + if (g_value_transform (value, &tmp)) + s = g_strescape (g_value_get_string (&tmp), NULL); + g_value_unset (&tmp); if (s == NULL) - return g_strdup ("NULL"); + return NULL; return s; } else - return g_strdup ("NULL"); + return NULL; } static void @@ -184,11 +186,21 @@ dump_properties (GType type, GOutputStream *out) const GValue *v = g_param_spec_get_default_value (prop); char *default_value = value_to_string (v); - escaped_printf (out, " \n", - prop->name, - g_type_name (prop->value_type), - prop->flags, - default_value); + if (default_value != NULL) + { + escaped_printf (out, " \n", + prop->name, + g_type_name (prop->value_type), + prop->flags, + default_value); + } + else + { + escaped_printf (out, " \n", + prop->name, + g_type_name (prop->value_type), + prop->flags); + } g_free (default_value); } diff --git a/giscanner/gdumpparser.py b/giscanner/gdumpparser.py index 21fbadf4..b5ca4362 100644 --- a/giscanner/gdumpparser.py +++ b/giscanner/gdumpparser.py @@ -414,7 +414,7 @@ different --identifier-prefix.""" % (xmlnode.attrib['name'], self._namespace.ide writable = (flags & G_PARAM_WRITABLE) != 0 construct = (flags & G_PARAM_CONSTRUCT) != 0 construct_only = (flags & G_PARAM_CONSTRUCT_ONLY) != 0 - default_value = pspec.attrib['default-value'] + default_value = pspec.attrib.get('default-value') prop = ast.Property( pspec.attrib['name'], ast.Type.create_from_gtype_name(ctype), diff --git a/tests/scanner/Regress-1.0-expected.gir b/tests/scanner/Regress-1.0-expected.gir index 42db6105..608f120c 100644 --- a/tests/scanner/Regress-1.0-expected.gir +++ b/tests/scanner/Regress-1.0-expected.gir @@ -1088,8 +1088,7 @@ regress_annotation_object_watch_full(). + transfer-ownership="none"> introspectable="0" writable="1" construct-only="1" - transfer-ownership="none" - default-value="NULL"> + transfer-ownership="none"> + setter="set_bare"> - + + transfer-ownership="none"> @@ -4877,16 +4870,10 @@ raise an error. default-value="1.000000"> - + - + @@ -4894,8 +4881,7 @@ raise an error. + transfer-ownership="container"> @@ -4907,18 +4893,12 @@ raise an error. default-value="0"> - + - + @@ -4930,10 +4910,7 @@ raise an error. default-value="42"> - + -- cgit v1.2.1