diff --git a/src/types.rs b/src/types.rs index c6b518d5..914494ea 100644 --- a/src/types.rs +++ b/src/types.rs @@ -63,12 +63,23 @@ pub struct ZipFileData impl ZipFileData { pub fn file_name_sanitized(&self) -> ::std::path::PathBuf { - let no_null_filename = match self.file_name.find('\0') { + let no_null_filename: String = match self.file_name.find('\0') { Some(index) => &self.file_name[0..index], None => &self.file_name, - }; + }.to_string(); - ::std::path::Path::new(no_null_filename) + // zip files can contain both / and \ as separators regardless of the OS + // and as we want to return a sanitized PathBuf that only supports the + // OS separator let's convert incompatible separators to compatible ones + let separator = ::std::path::MAIN_SEPARATOR; + let opposite_separator = match separator { + '/' => '\\', + '\\' | _ => '/', + }; + let filename = + no_null_filename.replace(&opposite_separator.to_string(), &separator.to_string()); + + ::std::path::Path::new(&filename) .components() .filter(|component| match *component { ::std::path::Component::Normal(..) => true,