mirror of
https://github.com/xavo95/repak.git
synced 2025-01-18 19:04:07 +00:00
Allow --strip-prefix to be specified for list command
This commit is contained in:
parent
13d9098b51
commit
86e5dd502d
1 changed files with 29 additions and 4 deletions
|
@ -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(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue