Skip to content

Commit

Permalink
fix: Don't forget to zero-terminate in octal_into
Browse files Browse the repository at this point in the history
Usually, numeric fields like `size` are set only once, implicitly
assuming that the previous data is zero-initialized.  However, it's not
always the case, particularly when overriding large values written in
the extended form.
  • Loading branch information
xzfc committed Aug 22, 2024
1 parent 6adcb40 commit 8e18fc5
Show file tree
Hide file tree
Showing 2 changed files with 5 additions and 3 deletions.
6 changes: 3 additions & 3 deletions src/header.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ use std::fmt;
use std::fs;
use std::io;
use std::iter;
use std::iter::repeat;
use std::iter::{once, repeat};
use std::mem;
use std::path::{Component, Path, PathBuf};
use std::str;
Expand Down Expand Up @@ -1413,8 +1413,8 @@ fn octal_from(slice: &[u8]) -> io::Result<u64> {

fn octal_into<T: fmt::Octal>(dst: &mut [u8], val: T) {
let o = format!("{:o}", val);
let value = o.bytes().rev().chain(repeat(b'0'));
for (slot, value) in dst.iter_mut().rev().skip(1).zip(value) {
let value = once(b'\0').chain(o.bytes().rev().chain(repeat(b'0')));
for (slot, value) in dst.iter_mut().rev().zip(value) {
*slot = value;
}
}
Expand Down
2 changes: 2 additions & 0 deletions tests/header/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -218,6 +218,8 @@ fn extended_numeric_format() {
assert_eq!(h.size, [48, 48, 48, 48, 48, 48, 48, 48, 48, 53, 50, 0]);
h.as_header_mut().set_size(8589934593);
assert_eq!(h.size, [0x80, 0, 0, 0, 0, 0, 0, 0x02, 0, 0, 0, 1]);
h.as_header_mut().set_size(44);
assert_eq!(h.size, [48, 48, 48, 48, 48, 48, 48, 48, 48, 53, 52, 0]);
h.size = [0x80, 0, 0, 0, 0, 0, 0, 0x02, 0, 0, 0, 0];
assert_eq!(h.as_header().entry_size().unwrap(), 0x0200000000);
h.size = [48, 48, 48, 48, 48, 48, 48, 48, 48, 53, 51, 0];
Expand Down

0 comments on commit 8e18fc5

Please sign in to comment.