mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-24 21:16:15 +01:00
Merge branch '2049-array-crash' into 'master'
garray: Fix copying an array with reserved elements Closes #2049 See merge request GNOME/glib!1390
This commit is contained in:
commit
21471b4258
@ -1242,9 +1242,12 @@ g_array_copy (GArray *array)
|
|||||||
|
|
||||||
new_rarray =
|
new_rarray =
|
||||||
(GRealArray *) g_array_sized_new (rarray->zero_terminated, rarray->clear,
|
(GRealArray *) g_array_sized_new (rarray->zero_terminated, rarray->clear,
|
||||||
rarray->elt_size, rarray->len);
|
rarray->elt_size, rarray->alloc / rarray->elt_size);
|
||||||
new_rarray->len = rarray->len;
|
new_rarray->len = rarray->len;
|
||||||
memcpy (new_rarray->data, rarray->data, rarray->alloc);
|
if (rarray->len > 0)
|
||||||
|
memcpy (new_rarray->data, rarray->data, rarray->len * rarray->elt_size);
|
||||||
|
|
||||||
|
g_array_zero_terminate (new_rarray);
|
||||||
|
|
||||||
return (GArray *) new_rarray;
|
return (GArray *) new_rarray;
|
||||||
}
|
}
|
||||||
|
@ -811,6 +811,32 @@ test_array_binary_search (void)
|
|||||||
g_array_free (garray, TRUE);
|
g_array_free (garray, TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_array_copy_sized (void)
|
||||||
|
{
|
||||||
|
GArray *array1 = NULL, *array2 = NULL, *array3 = NULL;
|
||||||
|
int val = 5;
|
||||||
|
|
||||||
|
g_test_summary ("Test that copying a newly-allocated sized array works.");
|
||||||
|
|
||||||
|
array1 = g_array_sized_new (FALSE, FALSE, sizeof (int), 1);
|
||||||
|
array2 = g_array_copy (array1);
|
||||||
|
|
||||||
|
g_assert_cmpuint (array2->len, ==, array1->len);
|
||||||
|
|
||||||
|
g_array_append_val (array1, val);
|
||||||
|
array3 = g_array_copy (array1);
|
||||||
|
|
||||||
|
g_assert_cmpuint (array3->len, ==, array1->len);
|
||||||
|
g_assert_cmpuint (g_array_index (array3, int, 0), ==, g_array_index (array1, int, 0));
|
||||||
|
g_assert_cmpuint (array3->len, ==, 1);
|
||||||
|
g_assert_cmpuint (g_array_index (array3, int, 0), ==, val);
|
||||||
|
|
||||||
|
g_array_unref (array3);
|
||||||
|
g_array_unref (array2);
|
||||||
|
g_array_unref (array1);
|
||||||
|
}
|
||||||
|
|
||||||
/* Check g_ptr_array_steal() function */
|
/* Check g_ptr_array_steal() function */
|
||||||
static void
|
static void
|
||||||
pointer_array_steal (void)
|
pointer_array_steal (void)
|
||||||
@ -1955,6 +1981,7 @@ main (int argc, char *argv[])
|
|||||||
g_test_add_func ("/array/steal", array_steal);
|
g_test_add_func ("/array/steal", array_steal);
|
||||||
g_test_add_func ("/array/clear-func", array_clear_func);
|
g_test_add_func ("/array/clear-func", array_clear_func);
|
||||||
g_test_add_func ("/array/binary-search", test_array_binary_search);
|
g_test_add_func ("/array/binary-search", test_array_binary_search);
|
||||||
|
g_test_add_func ("/array/copy-sized", test_array_copy_sized);
|
||||||
|
|
||||||
for (i = 0; i < G_N_ELEMENTS (array_configurations); i++)
|
for (i = 0; i < G_N_ELEMENTS (array_configurations); i++)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user