Skip to content

Commit

Permalink
fix(extract): fix unicode entry extract on Linux
Browse files Browse the repository at this point in the history
  • Loading branch information
muja committed Sep 7, 2024
1 parent 9b6703b commit caa13dc
Show file tree
Hide file tree
Showing 3 changed files with 35 additions and 9 deletions.
15 changes: 12 additions & 3 deletions src/open_archive.rs
Original file line number Diff line number Diff line change
Expand Up @@ -393,7 +393,7 @@ impl OpenArchive<Process, CursorBeforeFile> {
/// Extracts the file into the current working directory
/// Returns the OpenArchive for further processing
pub fn extract(self) -> UnrarResult<OpenArchive<Process, CursorBeforeHeader>> {
self.process_file::<Extract>(None, None)
self.extract_to_dir(None)
}

/// Extracts the file into the specified directory.
Expand All @@ -406,8 +406,17 @@ impl OpenArchive<Process, CursorBeforeFile> {
self,
base: P,
) -> UnrarResult<OpenArchive<Process, CursorBeforeHeader>> {
let path = pathed::construct(&base);
self.process_file::<Extract>(Some(&path), None)
self.extract_to_dir(Some(base.as_ref()))
}

fn extract_to_dir(
self,
base: Option<&Path>,
) -> UnrarResult<OpenArchive<Process, CursorBeforeHeader>> {
let mut path = None;
let mut file = None;
pathed::preprocess_extract(base, &self.entry().filename, &mut path, &mut file);
self.process_file::<Extract>(path.as_ref(), file.as_ref())
}

/// Extracts the file into the specified file.
Expand Down
20 changes: 14 additions & 6 deletions src/pathed/all.rs
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
use std::path::{Path, PathBuf};
use widestring::WideCString;

pub(crate) type RarPath = WideCString;
Expand All @@ -16,12 +17,19 @@ pub(crate) fn process_file(
unrar_sys::RARProcessFileW(
handle,
operation,
dest_path
.map(|path| path.as_ptr() as *const _)
.unwrap_or(std::ptr::null()),
dest_name
.map(|file| file.as_ptr() as *const _)
.unwrap_or(std::ptr::null()),
dest_path.map(|path| path.as_ptr() as *const _).unwrap_or(std::ptr::null()),
dest_name.map(|file| file.as_ptr() as *const _).unwrap_or(std::ptr::null()),
)
}
}

pub(crate) fn preprocess_extract(
base: Option<&Path>,
_filename: &PathBuf,
path: &mut Option<RarPath>,
_file: &mut Option<RarPath>,
) {
if let Some(base) = base {
*path = Some(construct(base));
}
}
9 changes: 9 additions & 0 deletions src/pathed/linux.rs
Original file line number Diff line number Diff line change
Expand Up @@ -25,3 +25,12 @@ pub(crate) fn process_file(
)
}
}

pub(crate) fn preprocess_extract(
base: Option<&Path>,
filename: &PathBuf,
_path: &mut Option<RarPath>,
file: &mut Option<RarPath>,
) {
*file = Some(pathed::construct(base.unwrap_or(".".as_ref()).join(filename)));
}

0 comments on commit caa13dc

Please sign in to comment.