Fix potential panic in ls (#14655)

# Description

Fixes a potential panic in `ls`.

# User-Facing Changes

Entries in the same directory are sorted first based on whether or not
they errored. Errors will be listed first, potentially stopping the
pipeline short.
This commit is contained in:
Ian Manske 2024-12-21 15:09:46 -08:00 committed by GitHub
parent 5139054325
commit a8890d5cca
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

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