diff --git a/crates/nu-command/src/filesystem/ls.rs b/crates/nu-command/src/filesystem/ls.rs index 1e9e66c96b..ef16199958 100644 --- a/crates/nu-command/src/filesystem/ls.rs +++ b/crates/nu-command/src/filesystem/ls.rs @@ -8,13 +8,12 @@ use nu_path::{expand_path_with, expand_to_real_path}; use nu_protocol::{DataSource, NuGlob, PipelineMetadata, Signals}; use pathdiff::diff_paths; use rayon::prelude::*; - #[cfg(unix)] use std::os::unix::fs::PermissionsExt; use std::{ + cmp::Ordering, path::PathBuf, - sync::mpsc, - sync::{Arc, Mutex}, + sync::{mpsc, Arc, Mutex}, time::{SystemTime, UNIX_EPOCH}, }; @@ -970,10 +969,11 @@ fn read_dir( }); if !use_threads { let mut collected = items.collect::>(); - collected.sort_by(|a, b| { - let a = a.as_ref().expect("path should be valid"); - let b = b.as_ref().expect("path should be valid"); - a.cmp(b) + collected.sort_by(|a, b| match (a, b) { + (Ok(a), Ok(b)) => a.cmp(b), + (Ok(_), Err(_)) => Ordering::Greater, + (Err(_), Ok(_)) => Ordering::Less, + (Err(_), Err(_)) => Ordering::Equal, }); return Ok(Box::new(collected.into_iter())); }