From 44b1100686967c471518bd809eb106d4479cbb7c Mon Sep 17 00:00:00 2001 From: Brett Mayson Date: Sat, 9 Nov 2024 03:18:23 +0000 Subject: [PATCH 1/3] don't require vers header --- libs/pbo/src/error.rs | 3 --- libs/pbo/src/read.rs | 8 +++++--- 2 files changed, 5 insertions(+), 6 deletions(-) diff --git a/libs/pbo/src/error.rs b/libs/pbo/src/error.rs index 3944536a..641d2295 100644 --- a/libs/pbo/src/error.rs +++ b/libs/pbo/src/error.rs @@ -7,9 +7,6 @@ pub enum Error { /// [`std::io::Error`] Io(#[from] std::io::Error), - #[error("Missing Vers header")] - /// Missing Vers header - NoVersHeader, #[error("HEMTT does not support the encountered PBO Mime type: {0}")] /// HEMTT does not support the encountered PBO Mime type UnsupportedMime(u32), diff --git a/libs/pbo/src/read.rs b/libs/pbo/src/read.rs index 978ecfd0..980525ee 100644 --- a/libs/pbo/src/read.rs +++ b/libs/pbo/src/read.rs @@ -15,7 +15,7 @@ use crate::{ /// An existing PBO file that can be read from pub struct ReadablePbo { properties: IndexMap, - vers_header: Header, + vers_header: Option
, headers: Vec
, checksum: Checksum, input: I, @@ -54,7 +54,7 @@ impl ReadablePbo { } } - let vers_header = vers_header.ok_or(Error::NoVersHeader)?; + let vers_header = vers_header; for header in &headers { input.seek(SeekFrom::Current(i64::from(header.size())))?; @@ -177,7 +177,9 @@ impl ReadablePbo { /// if a file does not exist, but a header for it does pub fn gen_checksum(&mut self) -> Result { let mut headers: Cursor> = Cursor::new(Vec::new()); - self.vers_header.write_pbo(&mut headers)?; + if let Some(vers_header) = &self.vers_header { + vers_header.write_pbo(&mut headers)?; + } if let Some(prefix) = self.properties.get("prefix") { headers.write_cstring(b"prefix")?; From c62aeef89eb50362002a4785b5f33f7bd66a8011 Mon Sep 17 00:00:00 2001 From: Brett Mayson Date: Sat, 9 Nov 2024 03:19:46 +0000 Subject: [PATCH 2/3] remove useless statement --- libs/pbo/src/read.rs | 2 -- 1 file changed, 2 deletions(-) diff --git a/libs/pbo/src/read.rs b/libs/pbo/src/read.rs index 980525ee..2090b8d7 100644 --- a/libs/pbo/src/read.rs +++ b/libs/pbo/src/read.rs @@ -54,8 +54,6 @@ impl ReadablePbo { } } - let vers_header = vers_header; - for header in &headers { input.seek(SeekFrom::Current(i64::from(header.size())))?; } From 6c084b3d025829f0b4df6404525ee8bae736fab2 Mon Sep 17 00:00:00 2001 From: Brett Mayson Date: Sat, 9 Nov 2024 03:26:09 +0000 Subject: [PATCH 3/3] add a test to read mission --- libs/pbo/tests/ace_weather.rs | 8 ++++---- libs/pbo/tests/exported_mission.VR.pbo | Bin 0 -> 16038 bytes libs/pbo/tests/exported_mission.rs | 24 ++++++++++++++++++++++++ libs/pbo/tests/utils.rs | 21 +++++++++++++++------ 4 files changed, 43 insertions(+), 10 deletions(-) create mode 100644 libs/pbo/tests/exported_mission.VR.pbo create mode 100644 libs/pbo/tests/exported_mission.rs diff --git a/libs/pbo/tests/ace_weather.rs b/libs/pbo/tests/ace_weather.rs index bbca179a..8e81c68d 100644 --- a/libs/pbo/tests/ace_weather.rs +++ b/libs/pbo/tests/ace_weather.rs @@ -19,8 +19,8 @@ fn ace_weather_cba6f72c() { 41, true, 3, - "cba6f72c", - "z\\ace\\addons\\weather", + Some("cba6f72c"), + Some("z\\ace\\addons\\weather"), checksum, checksum, ); @@ -146,8 +146,8 @@ fn ace_weather_8bd4922f() { 45, false, 3, - "8bd4922f", - "z\\ace\\addons\\weather", + Some("8bd4922f"), + Some("z\\ace\\addons\\weather"), Checksum::from_bytes([ 182, 44, 18, 201, 133, 232, 236, 162, 127, 37, 203, 45, 42, 137, 130, 36, 120, 104, 187, 203, diff --git a/libs/pbo/tests/exported_mission.VR.pbo b/libs/pbo/tests/exported_mission.VR.pbo new file mode 100644 index 0000000000000000000000000000000000000000..021891ff03971a952c43746afaf6b45677dc4141 GIT binary patch literal 16038 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, + prefix: Option<&str>, checksum: Checksum, gen_checksum: Checksum, ) -> ReadablePbo { @@ -22,15 +22,24 @@ pub fn pbo( assert_eq!(pbo.files().len(), file_count); assert_eq!(pbo.properties().len(), property_count); assert_eq!(pbo.is_sorted().is_ok(), sorted); - assert_eq!(pbo.properties().get("version"), Some(&version.to_string())); - assert_eq!(pbo.properties().get("prefix"), Some(&prefix.to_string())); + assert_eq!( + pbo.properties().get("version"), + version.map(std::string::ToString::to_string).as_ref() + ); + assert_eq!( + pbo.properties().get("prefix"), + prefix.map(std::string::ToString::to_string).as_ref() + ); assert!(pbo.file("not_real").unwrap().is_none()); assert!(pbo.header("not_real").is_none()); if sorted { assert_eq!(pbo.checksum(), &checksum); } - assert!(Checksum::from_bytes(*pbo.gen_checksum().unwrap().as_bytes()) == gen_checksum); - assert_eq!(pbo.gen_checksum().unwrap(), gen_checksum); + // TODO hemtt can't do this correctly right now? + if prefix.is_some() { + assert!(Checksum::from_bytes(*pbo.gen_checksum().unwrap().as_bytes()) == gen_checksum); + assert_eq!(pbo.gen_checksum().unwrap(), gen_checksum); + } pbo }