Skip to content

Commit

Permalink
fix: upgrade --bump with non-semver versions (jdx#2809)
Browse files Browse the repository at this point in the history
Fixes jdx#2704
  • Loading branch information
jdx authored Oct 25, 2024
1 parent e859b41 commit 0b2c2aa
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 5 deletions.
8 changes: 7 additions & 1 deletion src/file.rs
Original file line number Diff line number Diff line change
Expand Up @@ -522,7 +522,13 @@ pub fn split_file_name(path: &Path) -> (String, String) {

pub fn same_file(a: &Path, b: &Path) -> bool {
let canonicalize = |p: &Path| p.canonicalize().unwrap_or_else(|_| p.to_path_buf());
canonicalize(a) == canonicalize(b)
if canonicalize(a) == canonicalize(b) {
return true;
}
if let (Ok(a), Ok(b)) = (fs::read_link(a), fs::read_link(b)) {
return canonicalize(&a) == canonicalize(&b);
}
false
}

#[cfg(test)]
Expand Down
15 changes: 11 additions & 4 deletions src/toolset/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -662,16 +662,19 @@ pub fn is_outdated_version(current: &str, latest: &str) -> bool {
/// used with `mise outdated --bump` to determine what new semver range to use
/// given old: "20" and new: "21.2.3", return Some("21")
fn check_semver_bump(old: &str, new: &str) -> Option<String> {
let old = Versioning::new(old);
let new = Versioning::new(new);
if !old.contains('.') && !new.contains('.') {
return Some(new.to_string());
}
let old_v = Versioning::new(old);
let new_v = Versioning::new(new);
let chunkify = |v: &Versioning| {
let mut chunks = vec![];
while let Some(chunk) = v.nth(chunks.len()) {
chunks.push(chunk);
}
chunks
};
if let (Some(old), Some(new)) = (old, new) {
if let (Some(old), Some(new)) = (old_v, new_v) {
let old = chunkify(&old);
let new = chunkify(&new);
if old.len() > new.len() {
Expand Down Expand Up @@ -702,7 +705,7 @@ fn check_semver_bump(old: &str, new: &str) -> Option<String> {
)
}
} else {
None
Some(new.to_string())
}
}

Expand Down Expand Up @@ -814,6 +817,10 @@ mod tests {
check_semver_bump("20.0.0", "20.0.1"),
Some("20.0.1".to_string())
);
std::assert_eq!(
check_semver_bump("2024-09-16", "2024-10-21"),
Some("2024-10-21".to_string())
);
}

#[test]
Expand Down

0 comments on commit 0b2c2aa

Please sign in to comment.