gvariant: Handle ^ay, ^&ay, ^aay, ^a&ay in g_variant_valist_free_nnp

g_variant_valist_free_nnp does not take into account ^*ay, which causes
crash when trying to use these types together with
g_variant_iter_loop().
This commit is contained in:
Christophe Fergeau 2018-10-25 11:22:31 +01:00 committed by Philip Withnall
parent 741482085e
commit 46e493437c
2 changed files with 17 additions and 10 deletions

View File

@ -4662,7 +4662,15 @@ g_variant_valist_free_nnp (const gchar *str,
break;
case '^':
if (str[2] != '&') /* '^as', '^ao' */
if (g_str_has_suffix (str, "y"))
{
if (str[2] != 'a') /* '^a&ay', '^ay' */
g_free (ptr);
else if (str[1] == 'a') /* '^aay' */
g_strfreev (ptr);
break; /* '^&ay' */
}
else if (str[2] != '&') /* '^as', '^ao' */
g_strfreev (ptr);
else /* '^a&s', '^a&o' */
g_free (ptr);

View File

@ -3072,28 +3072,27 @@ test_varargs (void)
g_variant_builder_add (&builder, "^aay", strvector);
g_variant_builder_add (&builder, "^aay", strvector);
value = g_variant_new ("aaay", &builder);
g_variant_iter_init (&tuple, value);
array = g_variant_iter_new (value);
i = 0;
while (g_variant_iter_loop (&tuple, "^aay", &my_strv)) {
i++;
}
while (g_variant_iter_loop (array, "^aay", &my_strv))
i++;
g_assert (i == 3);
/* start over */
g_variant_iter_init (&tuple, value);
g_variant_iter_init (array, value);
i = 0;
while (g_variant_iter_loop (&tuple, "^a&ay", &strv)) {
i++;
}
while (g_variant_iter_loop (array, "^a&ay", &strv))
i++;
g_assert (i == 3);
g_variant_unref (value);
g_variant_iter_free (array);
/* next test */
g_variant_builder_init (&builder, G_VARIANT_TYPE ("aay"));
g_variant_builder_add (&builder, "^ay", "/foo");
g_variant_builder_add (&builder, "^ay", "/bar");
g_variant_builder_add (&builder, "^ay", "/baz");
value = g_variant_new("(aay^aay^a&ay)", &builder, strvector, strvector);
value = g_variant_new ("(aay^aay^a&ay)", &builder, strvector, strvector);
g_variant_iter_init (&tuple, value);
g_variant_iter_next (&tuple, "aay", &array);