From 1b72f2b34bccd40abef5f283034540b4cb460856 Mon Sep 17 00:00:00 2001 From: David Tolnay Date: Tue, 11 Jul 2023 15:59:44 -0700 Subject: [PATCH] Inline SerializeSeq::serialize_element into serialize_bytes --- src/ser.rs | 21 ++++++++++++++------- 1 file changed, 14 insertions(+), 7 deletions(-) diff --git a/src/ser.rs b/src/ser.rs index 62f5c4f01..5d91fa8f6 100644 --- a/src/ser.rs +++ b/src/ser.rs @@ -193,7 +193,7 @@ where .formatter .begin_array(&mut self.writer) .map_err(Error::io)); - let mut seq = if value.is_empty() { + let seq = if value.is_empty() { tri!(self .formatter .end_array(&mut self.writer) @@ -203,14 +203,21 @@ where state: State::Empty, } } else { - Compound::Map { - ser: self, - state: State::First, + let mut state = State::First; + for byte in value { + tri!(self + .formatter + .begin_array_value(&mut self.writer, state == State::First) + .map_err(Error::io)); + state = State::Rest; + tri!(byte.serialize(&mut *self)); + tri!(self + .formatter + .end_array_value(&mut self.writer) + .map_err(Error::io)); } + Compound::Map { ser: self, state } }; - for byte in value { - tri!(seq.serialize_element(byte)); - } seq.end() }