aboutsummaryrefslogtreecommitdiff
path: root/src/nbt.rs
diff options
context:
space:
mode:
authorJoey Sacchini <joey@sacchini.net>2020-10-19 13:02:48 -0400
committerJoey Sacchini <joey@sacchini.net>2020-10-19 13:02:48 -0400
commitefc2924f61f3729638ef0fa1d8ffe0191612394a (patch)
treeae39fe20f948cb0bd28351decfffcaaf2e1f37a8 /src/nbt.rs
parentb1630cb4decff257085ea1e55ba72c7dcfbdfd4b (diff)
downloadmcproto-rs-efc2924f61f3729638ef0fa1d8ffe0191612394a.tar.gz
mcproto-rs-efc2924f61f3729638ef0fa1d8ffe0191612394a.tar.bz2
mcproto-rs-efc2924f61f3729638ef0fa1d8ffe0191612394a.zip
fix bug in nbt.rs (<= 0 on unsigned type)
Diffstat (limited to 'src/nbt.rs')
-rw-r--r--src/nbt.rs36
1 files changed, 13 insertions, 23 deletions
diff --git a/src/nbt.rs b/src/nbt.rs
index c58c2d2..8c5500e 100644
--- a/src/nbt.rs
+++ b/src/nbt.rs
@@ -171,8 +171,8 @@ impl TestRandom for Tag {
#[inline]
fn write_contents<F>(contents: &Vec<F>) -> String
-where
- F: fmt::Display,
+ where
+ F: fmt::Display,
{
format!(
"{} entries\n{{\n{}\n}}",
@@ -284,20 +284,10 @@ fn read_tag_string(data: &[u8]) -> DeserializeResult<Tag> {
}
fn read_tag_list(data: &[u8]) -> DeserializeResult<Tag> {
- let Deserialized {
- value: contents_tag_type_id,
- data,
- } = read_one_byte(data)?;
- let Deserialized {
- value: list_length,
- data,
- } = read_int(data)?;
- if list_length <= 0 {
- if contents_tag_type_id != 0x00 {
- Err(DeserializeErr::NbtBadLength(list_length as isize))
- } else {
- Deserialized::ok(Tag::List(vec![]), data)
- }
+ let Deserialized { value: contents_tag_type_id, data } = read_one_byte(data)?;
+ let Deserialized { value: list_length, data } = read_int(data)?;
+ if list_length == 0 {
+ Deserialized::ok(Tag::List(vec![]), data)
} else {
let mut out_vec = Vec::with_capacity(list_length as usize);
let mut remaining_data = data;
@@ -356,9 +346,9 @@ fn read_array_tag<'a, R, F, M>(
parser: F,
finalizer: M,
) -> DeserializeResult<'a, Tag>
-where
- F: Fn(&'a [u8]) -> DeserializeResult<'a, R>,
- M: Fn(Vec<R>) -> Tag,
+ where
+ F: Fn(&'a [u8]) -> DeserializeResult<'a, R>,
+ M: Fn(Vec<R>) -> Tag,
{
let Deserialized { value: count, data } = read_int(data)?.map(move |v| v as i32);
if count < 0 {
@@ -587,8 +577,8 @@ mod tests {
let original = Tag::Compound(vec![Tag::IntArray(vec![
1, 2, -5, 123127, -12373, 0, 0, 4, 2,
])
- .with_name("test ints")])
- .with_name("test");
+ .with_name("test ints")])
+ .with_name("test");
let bytes = original.bytes();
let Deserialized {
@@ -612,8 +602,8 @@ mod tests {
4,
2,
])
- .with_name("test ints")])
- .with_name("test");
+ .with_name("test ints")])
+ .with_name("test");
let bytes = original.bytes();
let Deserialized {