From 8cead2a5eda1882ee12567d463784169c38c62a9 Mon Sep 17 00:00:00 2001 From: Marko Lindqvist Date: Thu, 12 May 2022 19:52:09 +0300 Subject: [PATCH 39/39] generate_packets.py: Do not introduce unused variables See osdn #44563 Signed-off-by: Marko Lindqvist --- common/generate_packets.py | 69 +++++++++++++++++++++++++++----------- 1 file changed, 50 insertions(+), 19 deletions(-) diff --git a/common/generate_packets.py b/common/generate_packets.py index 6a18eade03..e530cc6ade 100755 --- a/common/generate_packets.py +++ b/common/generate_packets.py @@ -453,28 +453,43 @@ class Field: # in the "fields" bitvector. The bit is either a "content-differs" # bit or (for bools which gets folded in the header) the actual # value of the bool. - def get_cmp_wrapper(self,i): - cmp=self.get_cmp() + def get_cmp_wrapper(self, i, pack): if fold_bool_into_header and self.struct_type=="bool" and \ not self.is_array: - b="packet->%(name)s"%self.get_dict(vars()) - return '''%s + if pack.is_info != "no": + cmp = self.get_cmp() + differ_part = ''' if (differ) { different++; } - if (%s) { +''' + else: + cmp = '''''' + differ_part = '''''' + b="packet->%(name)s"%self.get_dict(vars()) + return '''%s'''%(cmp) + differ_part + ''' if (%s) { BV_SET(fields, %d); } -'''%(cmp,b,i) +'''%(b,i) else: - return '''%s + cmp = self.get_cmp() + if pack.is_info != "no": + return '''%s if (differ) { different++; BV_SET(fields, %d); } -'''%(cmp,i) +'''%(cmp, i) + else: + pack.differ_used = True + return '''%s + if (differ) { + BV_SET(fields, %d); + } + +'''%(cmp, i) # Returns a code fragment which will put this field if the # content has changed. Does nothing for bools-in-header. @@ -887,21 +902,22 @@ field_addr.name = \"%(name)s\"; elif deltafragment and self.diff and self.is_array == 1: return ''' { +#ifdef FREECIV_JSON_CONNECTION int count; -#ifdef FREECIV_JSON_CONNECTION /* Enter array. */ field_addr.sub_location = plocation_elem_new(0); -#endif /* FREECIV_JSON_CONNECTION */ for (count = 0;; count++) { int i; -#ifdef FREECIV_JSON_CONNECTION field_addr.sub_location->number = count; /* Enter diff array element (start at the index address). */ field_addr.sub_location->sub_location = plocation_elem_new(0); +#else /* FREECIV_JSON_CONNECTION */ +while (TRUE) { + int i; #endif /* FREECIV_JSON_CONNECTION */ if (!DIO_GET(uint8, &din, &field_addr, &i)) { @@ -975,6 +991,7 @@ class Variant: self.type=packet.type self.delta=packet.delta self.is_info=packet.is_info + self.differ_used = False self.cancel=packet.cancel self.want_force=packet.want_force @@ -1185,13 +1202,18 @@ static char *stats_%(name)s_names[] = {%(names)s}; diff='force_to_send' else: diff='0' - delta_header='''#ifdef FREECIV_DELTA_PROTOCOL + delta_header = '''#ifdef FREECIV_DELTA_PROTOCOL %(name)s_fields fields; struct %(packet_name)s *old; - bool differ; - struct genhash **hash = pc->phs.sent + %(type)s; - int different = %(diff)s; -#endif /* FREECIV_DELTA_PROTOCOL */ +''' + if self.is_info != "no": + self.differ_used = True + delta_header2 = ''' struct genhash **hash = pc->phs.sent + %(type)s; +''' + if self.is_info != "no": + delta_header2 = delta_header2 + ''' int different = %(diff)s; +''' + delta_header2 = delta_header2 + '''#endif /* FREECIV_DELTA_PROTOCOL */ ''' body=self.get_delta_send_body()+"\n#ifndef FREECIV_DELTA_PROTOCOL" else: @@ -1226,6 +1248,12 @@ static char *stats_%(name)s_names[] = {%(names)s}; else: faddr = "" + if delta_header != "": + if self.differ_used: + delta_header = delta_header + ''' bool differ; +''' + delta_header2 + else: + delta_header = delta_header + delta_header2 for i in range(2): for k,v in vars().items(): if type(v)==type(""): @@ -1249,12 +1277,15 @@ static char *stats_%(name)s_names[] = {%(names)s}; *old = *real_packet; genhash_insert(*hash, old, old); memset(old, 0, sizeof(*old)); - different = 1; /* Force to send. */ - } +''' + if self.is_info != "no": + intro = intro + ''' different = 1; /* Force to send. */ +''' + intro = intro + ''' } ''' body="" for i, field in enumerate(self.other_fields): - body=body+field.get_cmp_wrapper(i) + body = body + field.get_cmp_wrapper(i, self) if self.gen_log: fl=' %(log_macro)s(" no change -> discard");\n' else: -- 2.35.1