From 533b8cab120a06545f31c88dbdf8e0f51e2528f9 Mon Sep 17 00:00:00 2001 From: Joseph Perez Date: Tue, 16 Jul 2024 14:18:48 +0200 Subject: [PATCH] refactor: use safe version of unimportant unsafe code --- commons/zenoh-keyexpr/src/key_expr/canon.rs | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/commons/zenoh-keyexpr/src/key_expr/canon.rs b/commons/zenoh-keyexpr/src/key_expr/canon.rs index d747a9a5ac..ed653dc8a7 100644 --- a/commons/zenoh-keyexpr/src/key_expr/canon.rs +++ b/commons/zenoh-keyexpr/src/key_expr/canon.rs @@ -17,6 +17,7 @@ pub trait Canonizable { fn canonize(&mut self); } +// Return the length of the canonized string fn canonize(bytes: &mut [u8]) -> usize { let mut index = 0; let mut written = 0; @@ -96,8 +97,7 @@ impl Canonizable for &mut str { // and remaining garbage bytes are zeroed let bytes = unsafe { self.as_bytes_mut() }; let length = canonize(bytes); - // SAFETY: canonized length is lesser than or equal to the original length - unsafe { bytes.get_unchecked_mut(length..) }.fill(b'\0'); + bytes[length..].fill(b'\0'); } } @@ -107,8 +107,7 @@ impl Canonizable for String { // and remaining garbage bytes are truncated let bytes = unsafe { self.as_mut_vec() }; let length = canonize(bytes); - // SAFETY: canonized length is lesser than or equal to the original length - unsafe { bytes.set_len(length) }; + bytes.truncate(length); } }