From 3ab75b83ce4d4b72abd8d07ae3be11029c299737 Mon Sep 17 00:00:00 2001 From: TSC21 <n.marques21@hotmail.com> Date: Wed, 15 May 2019 23:58:42 +0100 Subject: [PATCH] microcdr and IDL: remove field ordering, causing improper serialization/deserialization --- msg/templates/uorb_microcdr/msg.cpp.template | 8 ++------ msg/templates/urtps/msg.idl.template | 5 +---- 2 files changed, 3 insertions(+), 10 deletions(-) diff --git a/msg/templates/uorb_microcdr/msg.cpp.template b/msg/templates/uorb_microcdr/msg.cpp.template index a08ddcb55e..fdbdb9d2ee 100644 --- a/msg/templates/uorb_microcdr/msg.cpp.template +++ b/msg/templates/uorb_microcdr/msg.cpp.template @@ -131,14 +131,10 @@ def add_deserialize_functions(fields, scope_name): add_deserialize_functions(children_fields, name + ('[%d].' %i)) def add_code_to_serialize(): - # sort fields (using a stable sort) as in the declaration of the type - sorted_fields = sorted(spec.parsed_fields(), key=sizeof_field_type, reverse=True) - add_serialize_functions(sorted_fields, "") + add_serialize_functions(spec.parsed_fields(), "") def add_code_to_deserialize(): - # sort fields (using a stable sort) as in the declaration of the type - sorted_fields = sorted(spec.parsed_fields(), key=sizeof_field_type, reverse=True) - add_deserialize_functions(sorted_fields, "") + add_deserialize_functions(spec.parsed_fields(), "") }@ void serialize_@(topic_name)(ucdrBuffer *writer, const struct @(uorb_struct) *input, char *output, uint32_t *length) diff --git a/msg/templates/urtps/msg.idl.template b/msg/templates/urtps/msg.idl.template index 3cfabba707..57536f3629 100644 --- a/msg/templates/urtps/msg.idl.template +++ b/msg/templates/urtps/msg.idl.template @@ -78,10 +78,7 @@ def add_msg_field(field): def add_msg_fields(): - # sort fields (using a stable sort) as in the declaration of the type - sorted_fields = sorted(spec.parsed_fields(), - key=sizeof_field_type, reverse=True) - for field in sorted_fields: + for field in spec.parsed_fields(): add_msg_field(field) -- GitLab