mirror of
https://github.com/denoland/deno.git
synced 2024-11-22 04:51:22 +00:00
fix(cli): Overwrite existing bin entries in node_modules
(#24123)
Previously we warned on unix and didn't touch them on windows, now we unconditionally overwrite them. This matches what npm does.
This commit is contained in:
parent
0648f6d70d
commit
47d19461a5
@ -226,15 +226,6 @@ fn set_up_bin_shim(
|
||||
|
||||
cmd_shim.set_extension("cmd");
|
||||
let shim = format!("@deno run -A npm:{}/{bin_name} %*", package.id.nv);
|
||||
if cmd_shim.exists() {
|
||||
if let Ok(contents) = fs::read_to_string(cmd_shim) {
|
||||
if contents == shim {
|
||||
// up to date
|
||||
return Ok(());
|
||||
}
|
||||
}
|
||||
return Ok(());
|
||||
}
|
||||
fs::write(&cmd_shim, shim).with_context(|| {
|
||||
format!("Can't set up '{}' bin at {}", bin_name, cmd_shim.display())
|
||||
})?;
|
||||
@ -287,19 +278,21 @@ fn symlink_bin_entry(
|
||||
|
||||
if let Err(err) = symlink(&original_relative, &link) {
|
||||
if err.kind() == io::ErrorKind::AlreadyExists {
|
||||
let resolved = std::fs::read_link(&link).ok();
|
||||
if let Some(resolved) = resolved {
|
||||
if resolved != original_relative {
|
||||
log::warn!(
|
||||
"{} Trying to set up '{}' bin for \"{}\", but an entry pointing to \"{}\" already exists. Skipping...",
|
||||
deno_terminal::colors::yellow("Warning"),
|
||||
bin_name,
|
||||
resolved.display(),
|
||||
original_relative.display()
|
||||
);
|
||||
}
|
||||
return Ok(());
|
||||
}
|
||||
// remove and retry
|
||||
std::fs::remove_file(&link).with_context(|| {
|
||||
format!(
|
||||
"Failed to remove existing bin symlink at {}",
|
||||
link.display()
|
||||
)
|
||||
})?;
|
||||
symlink(&original_relative, &link).with_context(|| {
|
||||
format!(
|
||||
"Can't set up '{}' bin at {}",
|
||||
bin_name,
|
||||
original_relative.display()
|
||||
)
|
||||
})?;
|
||||
return Ok(());
|
||||
}
|
||||
return Err(err).with_context(|| {
|
||||
format!(
|
||||
|
@ -27,17 +27,16 @@
|
||||
}
|
||||
]
|
||||
},
|
||||
"warns_if_already_setup": {
|
||||
"clobbers_if_already_setup": {
|
||||
"tempDir": true,
|
||||
"steps": [{
|
||||
"if": "unix",
|
||||
"commandName": "npm",
|
||||
"args": "install",
|
||||
"output": "\nadded 1 package in [WILDCARD]\n"
|
||||
}, {
|
||||
"if": "unix",
|
||||
"args": "task sayhi",
|
||||
"output": "already-set-up.out"
|
||||
"output": "task.out"
|
||||
}]
|
||||
}
|
||||
}
|
||||
|
@ -1,9 +0,0 @@
|
||||
Download http://localhost:4260/@denotest/bin
|
||||
Download http://localhost:4260/@denotest/bin/1.0.0.tgz
|
||||
Initialize @denotest/bin@1.0.0
|
||||
Warning Trying to set up [WILDCARD] bin for [WILDCARD], but an entry pointing to [WILDCARD] already exists. Skipping...
|
||||
Warning Trying to set up [WILDCARD] bin for [WILDCARD] but an entry pointing to [WILDCARD] already exists. Skipping...
|
||||
Warning Trying to set up [WILDCARD] bin for [WILDCARD], but an entry pointing to [WILDCARD] already exists. Skipping...
|
||||
Task sayhi cli-esm hi hello
|
||||
hi
|
||||
hello
|
Loading…
Reference in New Issue
Block a user