mirror of
https://github.com/italicsjenga/valence.git
synced 2025-01-11 15:21:31 +11:00
Improve valence_nbt write perf and remove zerocopy dependency (#174)
This commit is contained in:
parent
4194acaa67
commit
2fc59d90a8
|
@ -14,7 +14,6 @@ edition = "2021"
|
||||||
byteorder = "1.4.3"
|
byteorder = "1.4.3"
|
||||||
cesu8 = "1.1.0"
|
cesu8 = "1.1.0"
|
||||||
indexmap = { version = "1.9.1", optional = true }
|
indexmap = { version = "1.9.1", optional = true }
|
||||||
zerocopy = "0.6.1"
|
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
# When enabled, the order of fields in compounds are preserved.
|
# When enabled, the order of fields in compounds are preserved.
|
||||||
|
|
|
@ -83,15 +83,15 @@ pub fn encoded_len(text: &str) -> usize {
|
||||||
|
|
||||||
while i < bytes.len() {
|
while i < bytes.len() {
|
||||||
match bytes[i] {
|
match bytes[i] {
|
||||||
0 => {
|
|
||||||
n += 2;
|
|
||||||
i += 1;
|
|
||||||
}
|
|
||||||
// Fast path for ASCII here makes a huge difference in benchmarks.
|
// Fast path for ASCII here makes a huge difference in benchmarks.
|
||||||
1..=127 => {
|
1..=127 => {
|
||||||
n += 1;
|
n += 1;
|
||||||
i += 1;
|
i += 1;
|
||||||
}
|
}
|
||||||
|
0 => {
|
||||||
|
n += 2;
|
||||||
|
i += 1;
|
||||||
|
}
|
||||||
b => {
|
b => {
|
||||||
let w = utf8_char_width(b);
|
let w = utf8_char_width(b);
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
use std::io::Write;
|
use std::io::Write;
|
||||||
|
|
||||||
use byteorder::{BigEndian, WriteBytesExt};
|
use byteorder::{BigEndian, WriteBytesExt};
|
||||||
use zerocopy::AsBytes;
|
|
||||||
|
|
||||||
use crate::tag::Tag;
|
use crate::tag::Tag;
|
||||||
use crate::{modified_utf8, Compound, Error, List, Result, Value};
|
use crate::{modified_utf8, Compound, Error, List, Result, Value};
|
||||||
|
@ -135,7 +134,10 @@ impl<W: Write> EncodeState<W> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(self.writer.write_all(bytes.as_bytes())?)
|
// SAFETY: i8 has the same layout as u8.
|
||||||
|
let bytes: &[u8] = unsafe { std::mem::transmute(bytes) };
|
||||||
|
|
||||||
|
Ok(self.writer.write_all(bytes)?)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn write_string(&mut self, s: &str) -> Result<()> {
|
fn write_string(&mut self, s: &str) -> Result<()> {
|
||||||
|
@ -177,7 +179,10 @@ impl<W: Write> EncodeState<W> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(self.writer.write_all(bl.as_bytes())?)
|
// SAFETY: i8 has the same layout as u8.
|
||||||
|
let bytes: &[u8] = unsafe { std::mem::transmute(bl.as_slice()) };
|
||||||
|
|
||||||
|
Ok(self.writer.write_all(bytes)?)
|
||||||
}
|
}
|
||||||
List::Short(sl) => self.write_list(sl, Tag::Short, |st, s| st.write_short(*s)),
|
List::Short(sl) => self.write_list(sl, Tag::Short, |st, s| st.write_short(*s)),
|
||||||
List::Int(il) => self.write_list(il, Tag::Int, |st, i| st.write_int(*i)),
|
List::Int(il) => self.write_list(il, Tag::Int, |st, i| st.write_int(*i)),
|
||||||
|
|
Loading…
Reference in a new issue