From 5c3bd25ac264d0e1fdff36f878e5280a1b77f725 Mon Sep 17 00:00:00 2001 From: Ivan Nejgebauer Date: Wed, 20 Jul 2016 22:28:55 +0200 Subject: [PATCH] Add "no-self-update" feature Intended for distro-packaged builds of rustup. The feature disables "self update" and "self uninstall" commands, erroring out if any of them is invoked explicitly, and silently skipping self-update for "update" even if "--no-self-update" is not specified. --- Cargo.toml | 3 +++ src/rustup-cli/rustup_mode.rs | 2 +- src/rustup-cli/self_update.rs | 16 +++++++++++++++- 3 files changed, 19 insertions(+), 2 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 813185f345..9ab462b878 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -25,6 +25,9 @@ curl-backend = ["download/curl-backend"] hyper-backend = ["download/hyper-backend"] rustls-backend = ["download/rustls-backend"] +# Include in the default set to disable self-update and uninstall. +no-self-update = [] + [dependencies] rustup-dist = { path = "src/rustup-dist", version = "0.3.0" } rustup-utils = { path = "src/rustup-utils", version = "0.3.0" } diff --git a/src/rustup-cli/rustup_mode.rs b/src/rustup-cli/rustup_mode.rs index 2c475bcb6c..994e8757f1 100644 --- a/src/rustup-cli/rustup_mode.rs +++ b/src/rustup-cli/rustup_mode.rs @@ -400,7 +400,7 @@ fn update(cfg: &Cfg, m: &ArgMatches) -> Result<()> { try!(common::show_channel_update(cfg, toolchain.name(), Ok(status))); } } else { - try!(common::update_all_channels(cfg, !m.is_present("no-self-update"))); + try!(common::update_all_channels(cfg, !m.is_present("no-self-update") && !self_update::NEVER_SELF_UPDATE)); } Ok(()) diff --git a/src/rustup-cli/self_update.rs b/src/rustup-cli/self_update.rs index 23b423f353..fae63ba700 100644 --- a/src/rustup-cli/self_update.rs +++ b/src/rustup-cli/self_update.rs @@ -50,6 +50,11 @@ pub struct InstallOpts { pub no_modify_path: bool, } +#[cfg(feature = "no-self-update")] +pub const NEVER_SELF_UPDATE: bool = true; +#[cfg(not(feature = "no-self-update"))] +pub const NEVER_SELF_UPDATE: bool = false; + // The big installation messages. These are macros because the first // argument of format! needs to be a literal. @@ -503,6 +508,11 @@ fn maybe_install_rust(toolchain_str: &str, default_host_triple: &str, verbose: b } pub fn uninstall(no_prompt: bool) -> Result<()> { + if NEVER_SELF_UPDATE { + err!("self-uninstall is disabled for this build of rustup"); + err!("you should probably use your system package manager to uninstall rustup"); + process::exit(1); + } let ref cargo_home = try!(utils::cargo_home()); if !cargo_home.join(&format!("bin/multirust{}", EXE_SUFFIX)).exists() { @@ -1051,7 +1061,11 @@ fn do_remove_from_path(methods: &[PathUpdateMethod]) -> Result<()> { /// multirust-setup is stored in CARGO_HOME/bin, and then deleted next /// time multirust runs. pub fn update() -> Result<()> { - + if NEVER_SELF_UPDATE { + err!("self-update is disabled for this build of rustup"); + err!("you should probably use your system package manager to update rustup"); + process::exit(1); + } let setup_path = try!(prepare_update()); if let Some(ref p) = setup_path { info!("rustup updated successfully");