From cfd56d86ee4294eddc88378c78fe1bc71ef0a3c6 Mon Sep 17 00:00:00 2001 From: lisa neigut Date: Tue, 23 Jul 2019 14:38:27 -0500 Subject: [PATCH] bolt-gen: keep single instance of type_obj per type we rely, perhaps a bit hackily, on there only being one copy of each type object floating about. using `deepcopy` on a Message for message extensions destroys this paradigm, which breaks things in the case where it's a later defined subtype that contains variable-length members. to fix this, we modify `__deepcopy__` on the Field class, such that it preserves the reference to the original type_obj instance. --- tools/generate-bolts.py | 9 +++++++++ tools/test/test_cases | 2 ++ 2 files changed, 11 insertions(+) diff --git a/tools/generate-bolts.py b/tools/generate-bolts.py index c1392b300..096f1d0ba 100755 --- a/tools/generate-bolts.py +++ b/tools/generate-bolts.py @@ -50,6 +50,15 @@ class Field(object): self.is_optional = optional self.field_comments = field_comments + def __deepcopy__(self, memo): + deepcopy_method = self.__deepcopy__ + self.__deepcopy__ = None + field = copy.deepcopy(self, memo) + self.__deepcopy__ = deepcopy_method + + field.type_obj = self.type_obj + return field + def add_count(self, count): self.count = int(count) diff --git a/tools/test/test_cases b/tools/test/test_cases index 1eda0352f..eb87c3c1b 100644 --- a/tools/test/test_cases +++ b/tools/test/test_cases @@ -40,6 +40,8 @@ msgdata,test_msg,test_sbt_varsize_var_assign,subtype_var_assign, msgdata,test_msg,test_sbt_var_len,subtype_var_len, msgdata,test_msg,test_sbt_varlen_varsize,subtype_varlen_varsize, msgdata,test_msg,test_sbt_arrays,subtype_arrays, +# test extension fields +msgdata,test_msg,extension_1,test_features,,option_short_id msgtype,test_tlv1,2 msgdata,test_tlv1,test_struct,test_short_id,