From d773b99dbaa7dc180f7627690cc394a79da68a09 Mon Sep 17 00:00:00 2001 From: Kornel Date: Tue, 31 Dec 2024 14:30:13 +0000 Subject: [PATCH] Avoid panic branches in TextDecoder --- src/base/encoding.rs | 3 ++- src/rewritable_units/text_decoder.rs | 10 ++++++++-- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/src/base/encoding.rs b/src/base/encoding.rs index 92c517d8..5c525e85 100644 --- a/src/base/encoding.rs +++ b/src/base/encoding.rs @@ -80,7 +80,8 @@ impl SharedEncoding { #[must_use] pub fn get(&self) -> &'static Encoding { let encoding = self.encoding.load(Ordering::Relaxed); - ALL_ENCODINGS[encoding] + // it will never be out of range, but get() avoids a panic branch + ALL_ENCODINGS.get(encoding).unwrap_or(&ALL_ENCODINGS[0]) } pub fn set(&self, encoding: AsciiCompatibleEncoding) { diff --git a/src/rewritable_units/text_decoder.rs b/src/rewritable_units/text_decoder.rs index 5ed1740c..9fe325f4 100644 --- a/src/rewritable_units/text_decoder.rs +++ b/src/rewritable_units/text_decoder.rs @@ -67,7 +67,13 @@ impl TextDecoder { // the last call to feed_text() may make multiple calls to output_handler, // but only one call to output_handler can be *the* last one. let really_last = last_in_text_node && finished_decoding; - (output_handler)(&buffer[..written], really_last, encoding)?; + + (output_handler)( + // this will always be in bounds, but unwrap_or_default optimizes better + buffer.get(..written).unwrap_or_default(), + really_last, + encoding, + )?; } if finished_decoding { @@ -76,7 +82,7 @@ impl TextDecoder { } return Ok(()); } - raw_input = &raw_input[read..]; + raw_input = raw_input.get(read..).unwrap_or_default(); } }