Allow --strip-prefix to be specified for list command

This commit is contained in:
Truman Kilen 2023-08-06 14:15:07 -05:00
parent 13d9098b51
commit 86e5dd502d

View file

@ -21,6 +21,10 @@ struct ActionList {
/// Input .pak path /// Input .pak path
#[arg(index = 1)] #[arg(index = 1)]
input: String, input: String,
/// Prefix to strip from entry path
#[arg(short, long, default_value = "../../../")]
strip_prefix: String,
} }
#[derive(Parser, Debug)] #[derive(Parser, Debug)]
@ -101,7 +105,7 @@ enum Action {
/// Print .pak info /// Print .pak info
Info(ActionInfo), Info(ActionInfo),
/// List .pak files /// List .pak files
List(ActionInfo), List(ActionList),
/// Unpack .pak file /// Unpack .pak file
Unpack(ActionUnpack), Unpack(ActionUnpack),
/// Pack directory into .pak file /// Pack directory into .pak file
@ -164,11 +168,32 @@ fn info(aes_key: Option<aes::Aes256>, action: ActionInfo) -> Result<(), repak::E
Ok(()) Ok(())
} }
fn list(aes_key: Option<aes::Aes256>, action: ActionInfo) -> Result<(), repak::Error> { fn list(aes_key: Option<aes::Aes256>, action: ActionList) -> Result<(), repak::Error> {
let pak = repak::PakReader::new_any(BufReader::new(File::open(action.input)?), aes_key)?; let pak = repak::PakReader::new_any(BufReader::new(File::open(action.input)?), aes_key)?;
for f in pak.files() {
println!("{f}"); let mount_point = PathBuf::from(pak.mount_point());
let prefix = Path::new(&action.strip_prefix);
let full_paths = pak
.files()
.into_iter()
.map(|f| mount_point.join(f))
.collect::<Vec<_>>();
let stripped = full_paths
.iter()
.map(|f| {
f.strip_prefix(prefix)
.map_err(|_| repak::Error::PrefixMismatch {
path: f.to_string_lossy().to_string(),
prefix: prefix.to_string_lossy().to_string(),
})
})
.collect::<Result<Vec<_>, _>>()?;
for f in stripped {
println!("{}", f.display());
} }
Ok(()) Ok(())
} }