mirror of
https://github.com/pesde-pkg/pesde.git
synced 2025-04-04 19:00:56 +01:00
perf: use or_else variants for expensive errors
This commit changes the error construction in multiple places from the `*_or` to the `*_or_else` variants. This is done to avoid the heap allocation (for example, `to_string`) when there is no need to.
This commit is contained in:
parent
5ea86e632e
commit
d6e2f611d8
8 changed files with 20 additions and 21 deletions
|
@ -176,7 +176,10 @@ pub async fn publish_package(
|
|||
})?;
|
||||
|
||||
set.insert(DocEntry {
|
||||
label: info.label.or(h1).unwrap_or(file_name.to_case(Case::Title)),
|
||||
label: info
|
||||
.label
|
||||
.or(h1)
|
||||
.unwrap_or_else(|| file_name.to_case(Case::Title)),
|
||||
position: info.sidebar_position,
|
||||
kind: DocEntryKind::Page {
|
||||
name: entry
|
||||
|
|
|
@ -63,7 +63,7 @@ macro_rules! benv {
|
|||
std::env::var($name)
|
||||
};
|
||||
($name:expr => $default:expr) => {
|
||||
benv!($name).unwrap_or($default.to_string())
|
||||
benv!($name).unwrap_or_else(|_| $default.to_string())
|
||||
};
|
||||
(required $name:expr) => {
|
||||
benv!($name).expect(concat!("Environment variable `", $name, "` must be set"))
|
||||
|
|
|
@ -187,7 +187,7 @@ impl AddCommand {
|
|||
.split('/')
|
||||
.next_back()
|
||||
.map(|s| s.to_string())
|
||||
.unwrap_or(url.path.to_string()),
|
||||
.unwrap_or_else(|| url.path.to_string()),
|
||||
AnyPackageIdentifier::Workspace(versioned) => versioned.0.name().to_string(),
|
||||
AnyPackageIdentifier::Path(path) => path
|
||||
.file_name()
|
||||
|
|
|
@ -543,7 +543,7 @@ info: otherwise, the file was deemed unnecessary, if you don't understand why, p
|
|||
manifest
|
||||
.target
|
||||
.lib_path()
|
||||
.map_or("(none)".to_string(), |p| p.to_string())
|
||||
.map_or_else(|| "(none)".to_string(), |p| p.to_string())
|
||||
);
|
||||
|
||||
if roblox_target {
|
||||
|
@ -554,7 +554,7 @@ info: otherwise, the file was deemed unnecessary, if you don't understand why, p
|
|||
manifest
|
||||
.target
|
||||
.bin_path()
|
||||
.map_or("(none)".to_string(), |p| p.to_string())
|
||||
.map_or_else(|| "(none)".to_string(), |p| p.to_string())
|
||||
);
|
||||
println!(
|
||||
"\tscripts: {}",
|
||||
|
@ -562,9 +562,10 @@ info: otherwise, the file was deemed unnecessary, if you don't understand why, p
|
|||
.target
|
||||
.scripts()
|
||||
.filter(|s| !s.is_empty())
|
||||
.map_or("(none)".to_string(), |s| {
|
||||
s.keys().cloned().collect::<Vec<_>>().join(", ")
|
||||
})
|
||||
.map_or_else(
|
||||
|| "(none)".to_string(),
|
||||
|s| { s.keys().cloned().collect::<Vec<_>>().join(", ") }
|
||||
)
|
||||
);
|
||||
}
|
||||
|
||||
|
|
|
@ -232,7 +232,7 @@ async fn run() -> anyhow::Result<()> {
|
|||
project_root_dir.display(),
|
||||
project_workspace_dir
|
||||
.as_ref()
|
||||
.map_or("none".to_string(), |p| p.display().to_string())
|
||||
.map_or_else(|| "none".to_string(), |p| p.display().to_string())
|
||||
);
|
||||
|
||||
let home_dir = home_dir()?;
|
||||
|
|
|
@ -31,7 +31,7 @@ impl FromStr for PackageName {
|
|||
fn from_str(s: &str) -> Result<Self, Self::Err> {
|
||||
let (scope, name) = s
|
||||
.split_once('/')
|
||||
.ok_or(Self::Err::InvalidFormat(s.to_string()))?;
|
||||
.ok_or_else(|| Self::Err::InvalidFormat(s.to_string()))?;
|
||||
|
||||
for (reason, part) in [(ErrorReason::Scope, scope), (ErrorReason::Name, name)] {
|
||||
let min_len = match reason {
|
||||
|
@ -218,7 +218,7 @@ pub mod wally {
|
|||
.strip_prefix("wally#")
|
||||
.unwrap_or(s)
|
||||
.split_once('/')
|
||||
.ok_or(Self::Err::InvalidFormat(s.to_string()))?;
|
||||
.ok_or_else(|| Self::Err::InvalidFormat(s.to_string()))?;
|
||||
|
||||
for (reason, part) in [(ErrorReason::Scope, scope), (ErrorReason::Name, name)] {
|
||||
if part.is_empty() || part.len() > 64 {
|
||||
|
|
|
@ -182,7 +182,7 @@ impl Project {
|
|||
manifest
|
||||
.indices
|
||||
.get(&specifier.index)
|
||||
.ok_or(errors::DependencyGraphError::IndexNotFound(
|
||||
.ok_or_else(|| errors::DependencyGraphError::IndexNotFound(
|
||||
specifier.index.to_string(),
|
||||
))?
|
||||
.clone()
|
||||
|
@ -202,7 +202,7 @@ impl Project {
|
|||
manifest
|
||||
.wally_indices
|
||||
.get(&specifier.index)
|
||||
.ok_or(errors::DependencyGraphError::WallyIndexNotFound(
|
||||
.ok_or_else(|| errors::DependencyGraphError::WallyIndexNotFound(
|
||||
specifier.index.to_string(),
|
||||
))?
|
||||
.clone()
|
||||
|
|
|
@ -178,14 +178,9 @@ async fn package_fs_copy(
|
|||
let path = entry.path();
|
||||
let relative_path = path.strip_prefix(src).unwrap();
|
||||
let dest_path = destination.join(relative_path);
|
||||
let file_name = relative_path
|
||||
.file_name()
|
||||
.unwrap()
|
||||
.to_str()
|
||||
.ok_or(std::io::Error::new(
|
||||
std::io::ErrorKind::InvalidData,
|
||||
"invalid file name",
|
||||
))?;
|
||||
let file_name = relative_path.file_name().unwrap().to_str().ok_or_else(|| {
|
||||
std::io::Error::new(std::io::ErrorKind::InvalidData, "invalid file name")
|
||||
})?;
|
||||
|
||||
if entry.file_type().await?.is_dir() {
|
||||
if IGNORED_DIRS.contains(&file_name) {
|
||||
|
|
Loading…
Add table
Reference in a new issue