Skip to content

Commit

Permalink
Optimize Varint encoding (#60)
Browse files Browse the repository at this point in the history
  • Loading branch information
bugadani committed Jun 20, 2022
1 parent ce5ee88 commit 2edf154
Showing 1 changed file with 25 additions and 25 deletions.
50 changes: 25 additions & 25 deletions src/varint.rs
Expand Up @@ -18,13 +18,13 @@ pub const fn varint_max<T: Sized>() -> usize {
pub fn varint_usize(n: usize, out: &mut [u8; varint_max::<usize>()]) -> &mut [u8] {
let mut value = n;
for i in 0..varint_max::<usize>() {
out[i] = (value & 0x7F) as u8;
value >>= 7;
if value != 0 {
out[i] |= 0x80;
} else {
out[i] = value.to_le_bytes()[0];
if value < 128 {
return &mut out[..=i];
}

out[i] |= 0x80;
value >>= 7;
}
debug_assert_eq!(value, 0);
&mut out[..]
Expand All @@ -34,13 +34,13 @@ pub fn varint_usize(n: usize, out: &mut [u8; varint_max::<usize>()]) -> &mut [u8
pub fn varint_u16(n: u16, out: &mut [u8; varint_max::<u16>()]) -> &mut [u8] {
let mut value = n;
for i in 0..varint_max::<u16>() {
out[i] = (value & 0x7F) as u8;
value >>= 7;
if value != 0 {
out[i] |= 0x80;
} else {
out[i] = value.to_le_bytes()[0];
if value < 128 {
return &mut out[..=i];
}

out[i] |= 0x80;
value >>= 7;
}
debug_assert_eq!(value, 0);
&mut out[..]
Expand All @@ -50,13 +50,13 @@ pub fn varint_u16(n: u16, out: &mut [u8; varint_max::<u16>()]) -> &mut [u8] {
pub fn varint_u32(n: u32, out: &mut [u8; varint_max::<u32>()]) -> &mut [u8] {
let mut value = n;
for i in 0..varint_max::<u32>() {
out[i] = (value & 0x7F) as u8;
value >>= 7;
if value != 0 {
out[i] |= 0x80;
} else {
out[i] = value.to_le_bytes()[0];
if value < 128 {
return &mut out[..=i];
}

out[i] |= 0x80;
value >>= 7;
}
debug_assert_eq!(value, 0);
&mut out[..]
Expand All @@ -66,13 +66,13 @@ pub fn varint_u32(n: u32, out: &mut [u8; varint_max::<u32>()]) -> &mut [u8] {
pub fn varint_u64(n: u64, out: &mut [u8; varint_max::<u64>()]) -> &mut [u8] {
let mut value = n;
for i in 0..varint_max::<u64>() {
out[i] = (value & 0x7F) as u8;
value >>= 7;
if value != 0 {
out[i] |= 0x80;
} else {
out[i] = value.to_le_bytes()[0];
if value < 128 {
return &mut out[..=i];
}

out[i] |= 0x80;
value >>= 7;
}
debug_assert_eq!(value, 0);
&mut out[..]
Expand All @@ -82,13 +82,13 @@ pub fn varint_u64(n: u64, out: &mut [u8; varint_max::<u64>()]) -> &mut [u8] {
pub fn varint_u128(n: u128, out: &mut [u8; varint_max::<u128>()]) -> &mut [u8] {
let mut value = n;
for i in 0..varint_max::<u128>() {
out[i] = (value & 0x7F) as u8;
value >>= 7;
if value != 0 {
out[i] |= 0x80;
} else {
out[i] = value.to_le_bytes()[0];
if value < 128 {
return &mut out[..=i];
}

out[i] |= 0x80;
value >>= 7;
}
debug_assert_eq!(value, 0);
&mut out[..]
Expand Down

0 comments on commit 2edf154

Please sign in to comment.