From 932e96a19b4bae9768d100352a31e32e38aa6eb8 Mon Sep 17 00:00:00 2001 From: PaDarochek <69221349+PaDarochek@users.noreply.github.com> Date: Sun, 10 Mar 2024 13:25:00 +0300 Subject: [PATCH] Fix empty filename case (#204) --- casr/src/bin/casr-cli.rs | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/casr/src/bin/casr-cli.rs b/casr/src/bin/casr-cli.rs index 79573598..f5aa0e5d 100644 --- a/casr/src/bin/casr-cli.rs +++ b/casr/src/bin/casr-cli.rs @@ -824,12 +824,23 @@ fn print_summary(dir: &Path, unique_crash_line: bool) { .map(|res| res.unwrap().path()) .any(|e| e.extension().is_some() && e.extension().unwrap() == "casrep") { - clusters.push((dir.to_path_buf(), 0)); + // Try to canonocalize directory path to avoid paths with empty file_name. + if let Ok(canon_dir) = dir.canonicalize() { + clusters.push((canon_dir.to_path_buf(), 0)); + } else { + clusters.push((dir.to_path_buf(), 0)); + } } for (clpath, _) in clusters { let cluster = clpath.as_path(); - let filename = cluster.file_name().unwrap().to_str().unwrap(); + // file_name may be empty if path ends with '.', '..', or '/'. + // Take the whole path as filename then. + let filename = if let Some(cl_filename) = cluster.file_name() { + cl_filename.to_str().unwrap() + } else { + cluster.to_str().unwrap() + }; // Ubsan indicator for minimize logging let mut ubsan = true;