mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-13 07:56:17 +01:00
gstrvbuilder: Add g_strv_builder_take
g_strv_builder_take() allows to transfer ownership of the passed in string. This can be useful to avoid additional allocations when using functions that transfer ownership to the caller like g_strdup_printf(). The testcase uses g_strv_builder_take and g_strv_builder_add to demo that calls can be mixed.
This commit is contained in:
parent
046f70cc0d
commit
bc4ba05d34
@ -1604,6 +1604,7 @@ g_strv_builder_unref
|
|||||||
g_strv_builder_add
|
g_strv_builder_add
|
||||||
g_strv_builder_addv
|
g_strv_builder_addv
|
||||||
g_strv_builder_add_many
|
g_strv_builder_add_many
|
||||||
|
g_strv_builder_take
|
||||||
g_strv_builder_end
|
g_strv_builder_end
|
||||||
|
|
||||||
<SUBSECTION>
|
<SUBSECTION>
|
||||||
|
@ -156,6 +156,24 @@ g_strv_builder_add_many (GStrvBuilder *builder,
|
|||||||
va_end (var_args);
|
va_end (var_args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* g_strv_builder_take:
|
||||||
|
* @builder: a #GStrvBuilder
|
||||||
|
* @value: (transfer full): a string.
|
||||||
|
* Ownership of the string is transferred to the #GStrvBuilder
|
||||||
|
*
|
||||||
|
* Add a string to the end of the array. After @value belongs to the
|
||||||
|
* #GStrvBuilder and may no longer be modified by the caller.
|
||||||
|
*
|
||||||
|
* Since 2.80
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
g_strv_builder_take (GStrvBuilder *builder,
|
||||||
|
char *value)
|
||||||
|
{
|
||||||
|
g_ptr_array_add (&builder->array, value);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* g_strv_builder_end:
|
* g_strv_builder_end:
|
||||||
* @builder: a #GStrvBuilder
|
* @builder: a #GStrvBuilder
|
||||||
|
@ -53,6 +53,10 @@ GLIB_AVAILABLE_IN_2_70
|
|||||||
void g_strv_builder_add_many (GStrvBuilder *builder,
|
void g_strv_builder_add_many (GStrvBuilder *builder,
|
||||||
...) G_GNUC_NULL_TERMINATED;
|
...) G_GNUC_NULL_TERMINATED;
|
||||||
|
|
||||||
|
GLIB_AVAILABLE_IN_2_80
|
||||||
|
void g_strv_builder_take (GStrvBuilder *builder,
|
||||||
|
char *value);
|
||||||
|
|
||||||
GLIB_AVAILABLE_IN_2_68
|
GLIB_AVAILABLE_IN_2_68
|
||||||
GStrv g_strv_builder_end (GStrvBuilder *builder);
|
GStrv g_strv_builder_end (GStrvBuilder *builder);
|
||||||
|
|
||||||
|
@ -92,6 +92,25 @@ test_strvbuilder_add_many (void)
|
|||||||
g_strv_builder_unref (builder);
|
g_strv_builder_unref (builder);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_strvbuilder_take (void)
|
||||||
|
{
|
||||||
|
GStrvBuilder *builder;
|
||||||
|
GStrv result;
|
||||||
|
const gchar *expected[] = { "one", "two", "three", NULL };
|
||||||
|
|
||||||
|
builder = g_strv_builder_new ();
|
||||||
|
g_strv_builder_take (builder, g_strdup ("one"));
|
||||||
|
g_strv_builder_add (builder, "two");
|
||||||
|
g_strv_builder_take (builder, g_strdup ("three"));
|
||||||
|
result = g_strv_builder_end (builder);
|
||||||
|
g_assert_nonnull (result);
|
||||||
|
g_assert_true (g_strv_equal ((const gchar *const *) result, expected));
|
||||||
|
|
||||||
|
g_strfreev (result);
|
||||||
|
g_strv_builder_unref (builder);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
test_strvbuilder_ref (void)
|
test_strvbuilder_ref (void)
|
||||||
{
|
{
|
||||||
@ -113,6 +132,7 @@ main (int argc,
|
|||||||
g_test_add_func ("/strvbuilder/add", test_strvbuilder_add);
|
g_test_add_func ("/strvbuilder/add", test_strvbuilder_add);
|
||||||
g_test_add_func ("/strvbuilder/addv", test_strvbuilder_addv);
|
g_test_add_func ("/strvbuilder/addv", test_strvbuilder_addv);
|
||||||
g_test_add_func ("/strvbuilder/add_many", test_strvbuilder_add_many);
|
g_test_add_func ("/strvbuilder/add_many", test_strvbuilder_add_many);
|
||||||
|
g_test_add_func ("/strvbuilder/take", test_strvbuilder_take);
|
||||||
g_test_add_func ("/strvbuilder/ref", test_strvbuilder_ref);
|
g_test_add_func ("/strvbuilder/ref", test_strvbuilder_ref);
|
||||||
|
|
||||||
return g_test_run ();
|
return g_test_run ();
|
||||||
|
Loading…
Reference in New Issue
Block a user