paramdef: handle bit sizes
This commit is contained in:
parent
0664822332
commit
4f63f2bb1a
|
@ -20,4 +20,5 @@ pub mod unpackers {
|
|||
pub mod utils {
|
||||
pub mod bin;
|
||||
pub mod fs;
|
||||
pub mod str;
|
||||
}
|
||||
|
|
|
@ -23,6 +23,7 @@ impl ParamdefHeader {
|
|||
pub fn use_be(&self) -> bool { use_be(self.endianness) }
|
||||
pub fn has_ofs_fields(&self) -> bool { has_ofs_fields(self.format_version) }
|
||||
pub fn has_64b_ofs_desc(&self) -> bool { self.format_version >= 201 }
|
||||
pub fn can_have_bit_size(&self) -> bool { self.format_version >= 102 }
|
||||
}
|
||||
|
||||
fn use_be(endianness: u8) -> bool { endianness == 0xFF }
|
||||
|
@ -80,7 +81,25 @@ pub struct ParamdefField {
|
|||
pub description: Option<String>,
|
||||
}
|
||||
|
||||
pub union ParamdefEntryDescOffset {
|
||||
impl ParamdefField {
|
||||
/// Return the bit size for this field, or 0 if unknown.
|
||||
///
|
||||
/// It is contained in the internal name, unsure if there is a
|
||||
/// better way to get it.
|
||||
pub fn bit_size(&self) -> usize {
|
||||
if let Some(name) = &self.internal_name {
|
||||
if !name.contains(":") {
|
||||
return 0
|
||||
}
|
||||
if let Some(bit_size_str) = name.split(":").last().and_then(|s| Some(s.trim())) {
|
||||
return bit_size_str.parse::<usize>().unwrap_or(0)
|
||||
}
|
||||
}
|
||||
0
|
||||
}
|
||||
}
|
||||
|
||||
pub union ParamdefFieldDescOffset {
|
||||
ofs32: u32,
|
||||
ofs64: u64,
|
||||
}
|
||||
|
@ -166,5 +185,5 @@ pub fn parse(i: &[u8]) -> IResult<&[u8], Paramdef> {
|
|||
field.description = Some(sjis_to_string_lossy(sjis_desc));
|
||||
}
|
||||
|
||||
Ok((i, Paramdef { header, fields: fields }))
|
||||
Ok((i, Paramdef { header, fields }))
|
||||
}
|
||||
|
|
|
@ -5,6 +5,7 @@ use nom::Err::{Error as NomError, Failure as NomFailure};
|
|||
use crate::parsers::paramdef;
|
||||
use crate::unpackers::errors::UnpackError;
|
||||
use crate::utils::fs as utils_fs;
|
||||
use crate::utils::str as utils_str;
|
||||
|
||||
pub fn load_paramdef_file(paramdef_path: &str) -> Result<paramdef::Paramdef, UnpackError> {
|
||||
let paramdef_data = utils_fs::open_file_to_vec(path::Path::new(paramdef_path))?;
|
||||
|
@ -25,16 +26,35 @@ pub fn print_paramdef(paramdef: ¶mdef::Paramdef) {
|
|||
paramdef.header.data_version, paramdef.header.format_version,
|
||||
paramdef.header.num_fields);
|
||||
|
||||
let mut row_size = 0;
|
||||
let mut bit_count = 0;
|
||||
for field in ¶mdef.fields {
|
||||
println!(" - [{}] {} ({}) {} ({}, {} bytes)",
|
||||
let bit_size = field.bit_size();
|
||||
let size_str = match bit_size {
|
||||
0 => utils_str::n_plural(field.byte_count as i32, "byte", "bytes"),
|
||||
x => utils_str::n_plural(x as i32, "bit", "bits")
|
||||
};
|
||||
|
||||
println!(" - [{}] {} ({}) {} ({}, {})",
|
||||
field.sort_id, field.display_name,
|
||||
field.internal_name.as_ref().unwrap_or(&String::from("<noname>")),
|
||||
field.display_type, field.internal_type, field.byte_count);
|
||||
field.display_type, field.internal_type, size_str);
|
||||
println!(" Values: default {}, range [{}, {}], inc {}",
|
||||
field.default_value, field.min_value, field.max_value, field.increment);
|
||||
if let Some(desc) = &field.description {
|
||||
println!(" Description: {}", desc);
|
||||
}
|
||||
println!(" Edit flags: {:X}", field.edit_flags);
|
||||
|
||||
if bit_size != 0 {
|
||||
bit_count += bit_size;
|
||||
while bit_count >= 8 {
|
||||
bit_count -= 8;
|
||||
row_size += 1;
|
||||
}
|
||||
} else {
|
||||
row_size += field.byte_count;
|
||||
}
|
||||
}
|
||||
|
||||
println!("Size per row: {}", utils_str::n_plural(row_size as i32, "byte", "bytes"));
|
||||
}
|
||||
|
|
10
src/utils/str.rs
Normal file
10
src/utils/str.rs
Normal file
|
@ -0,0 +1,10 @@
|
|||
pub fn plural<'a>(num: i32, singular_name: &'a str, plural_name: &'a str) -> &'a str {
|
||||
match num {
|
||||
1 => singular_name,
|
||||
_ => plural_name,
|
||||
}
|
||||
}
|
||||
|
||||
pub fn n_plural<'a>(num: i32, singular_name: &'a str, plural_name: &'a str) -> String {
|
||||
format!("{} {}", num, plural(num, singular_name, plural_name))
|
||||
}
|
Reference in a new issue