protobuf-c.c: Fix repeated field concatenation order in merge_messages (fixes #147)

This commit is contained in:
Ilya Lipnitskiy 2014-06-19 11:18:41 -07:00 committed by Robert Edmonds
parent e7dc76c54b
commit a2100d1f39
2 changed files with 9 additions and 9 deletions

View File

@ -1933,12 +1933,12 @@ merge_messages(ProtobufCMessage *earlier_msg,
if (!new_field)
return FALSE;
memcpy(new_field, *p_latter,
*n_latter * el_size);
memcpy(new_field +
*n_latter * el_size,
*p_earlier,
memcpy(new_field, *p_earlier,
*n_earlier * el_size);
memcpy(new_field +
*n_earlier * el_size,
*p_latter,
*n_latter * el_size);
do_free(allocator, *p_latter);
do_free(allocator, *p_earlier);

View File

@ -1469,8 +1469,8 @@ test_field_merge (void)
msg2.test_message = &sub2;
sub2.has_val2 = 1;
sub2.val2 = 666;
int32_t arr2[] = {2, 3};
sub2.n_rep = 2;
int32_t arr2[] = {2, 3, 4};
sub2.n_rep = 3;
sub2.rep = arr2;
sub2.sub1 = &subsub2;
subsub2.has_val1 = 1;
@ -1496,8 +1496,8 @@ test_field_merge (void)
assert (merged->test_message->has_val1 && merged->test_message->val1 == sub1.val1);
assert (merged->test_message->has_val2 && merged->test_message->val2 == sub2.val2);
/* Repeated fields should get concatenated */
int32_t merged_arr[] = {2, 3, 0, 1};
assert (merged->test_message->n_rep == 4 &&
int32_t merged_arr[] = {0, 1, 2, 3, 4};
assert (merged->test_message->n_rep == 5 &&
memcmp(merged->test_message->rep, merged_arr, sizeof(merged_arr)) == 0);
assert (merged->test_message->sub1->val1 == subsub2.val1);