2019-06-05 11:44:28 +03:00
|
|
|
#![allow(clippy::cognitive_complexity)]
|
2018-06-28 12:16:54 +03:00
|
|
|
mod config;
|
2018-10-17 14:07:58 +03:00
|
|
|
mod ctrlc;
|
2018-12-11 16:43:26 +02:00
|
|
|
mod error;
|
2020-02-08 22:13:56 +02:00
|
|
|
mod execution_context;
|
2018-08-26 16:12:59 +03:00
|
|
|
mod executor;
|
2018-06-03 18:04:58 +03:00
|
|
|
mod report;
|
2020-02-09 13:41:55 +02:00
|
|
|
mod runner;
|
2018-11-26 14:27:19 +02:00
|
|
|
#[cfg(feature = "self-update")]
|
|
|
|
|
mod self_update;
|
2018-12-15 21:52:21 +02:00
|
|
|
mod steps;
|
2018-05-31 16:00:01 +03:00
|
|
|
mod terminal;
|
2018-06-17 11:43:25 +03:00
|
|
|
mod utils;
|
2018-05-30 07:53:19 +03:00
|
|
|
|
2019-11-04 22:55:06 +02:00
|
|
|
use self::config::{CommandLineArgs, Config, Step};
|
2020-02-09 13:41:55 +02:00
|
|
|
use self::error::StepFailed;
|
2019-12-11 23:05:38 +02:00
|
|
|
#[cfg(all(windows, feature = "self-update"))]
|
|
|
|
|
use self::error::Upgraded;
|
2020-02-09 13:41:55 +02:00
|
|
|
|
2018-12-15 21:52:21 +02:00
|
|
|
use self::steps::*;
|
2018-12-09 10:30:41 +02:00
|
|
|
use self::terminal::*;
|
2019-12-11 23:05:38 +02:00
|
|
|
use anyhow::{anyhow, Result};
|
2020-02-26 15:33:06 +02:00
|
|
|
use log::debug;
|
2018-06-20 21:05:49 +03:00
|
|
|
use std::env;
|
2018-12-11 16:43:26 +02:00
|
|
|
use std::io;
|
2018-06-17 11:43:25 +03:00
|
|
|
use std::process::exit;
|
2020-02-26 12:27:58 +02:00
|
|
|
use structopt::clap::crate_version;
|
2019-11-04 22:55:06 +02:00
|
|
|
use structopt::StructOpt;
|
2018-05-29 23:48:30 +03:00
|
|
|
|
2019-12-11 23:05:38 +02:00
|
|
|
fn run() -> Result<()> {
|
2018-10-17 14:07:58 +03:00
|
|
|
ctrlc::set_handler();
|
|
|
|
|
|
2019-12-11 23:05:38 +02:00
|
|
|
let base_dirs = directories::BaseDirs::new().ok_or_else(|| anyhow!("No base directories"))?;
|
2018-09-06 14:42:56 +03:00
|
|
|
|
2019-11-04 22:55:06 +02:00
|
|
|
let opt = CommandLineArgs::from_args();
|
|
|
|
|
if opt.edit_config() {
|
2019-08-22 22:29:31 +03:00
|
|
|
Config::edit(&base_dirs)?;
|
|
|
|
|
return Ok(());
|
|
|
|
|
};
|
|
|
|
|
|
2019-11-04 22:55:06 +02:00
|
|
|
let config = Config::load(&base_dirs, opt)?;
|
|
|
|
|
terminal::set_title(config.set_title());
|
2020-02-27 13:30:55 +02:00
|
|
|
terminal::set_desktop_notifications(config.notify_each_step());
|
2019-11-04 22:55:06 +02:00
|
|
|
|
2020-02-26 12:27:58 +02:00
|
|
|
debug!("Version: {}", crate_version!());
|
|
|
|
|
debug!("OS: {}", env!("TARGET"));
|
|
|
|
|
debug!("{:?}", std::env::args());
|
|
|
|
|
debug!("Binary path: {:?}", std::env::current_exe());
|
|
|
|
|
debug!("Self Update: {:?}", cfg!(feature = "self-update"));
|
|
|
|
|
|
2019-06-13 09:21:39 +03:00
|
|
|
if config.run_in_tmux() && env::var("TOPGRADE_INSIDE_TMUX").is_err() {
|
2018-06-27 23:04:39 +03:00
|
|
|
#[cfg(unix)]
|
|
|
|
|
{
|
2019-11-06 07:27:01 +02:00
|
|
|
tmux::run_in_tmux(config.tmux_arguments());
|
2018-06-20 21:05:49 +03:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2018-12-15 21:52:21 +02:00
|
|
|
let git = git::Git::new();
|
|
|
|
|
let mut git_repos = git::Repositories::new(&git);
|
2018-11-07 14:31:44 +02:00
|
|
|
|
2019-12-12 20:24:22 +02:00
|
|
|
#[cfg(unix)]
|
2019-08-20 14:02:13 +02:00
|
|
|
let sudo = utils::sudo();
|
2019-01-22 22:37:32 +02:00
|
|
|
let run_type = executor::RunType::new(config.dry_run());
|
2018-06-11 08:29:40 +03:00
|
|
|
|
2020-02-08 22:13:56 +02:00
|
|
|
#[cfg(unix)]
|
2020-03-08 21:38:49 +02:00
|
|
|
let ctx = execution_context::ExecutionContext::new(run_type, &sudo, &git, &config, &base_dirs);
|
2020-02-08 22:13:56 +02:00
|
|
|
|
|
|
|
|
#[cfg(not(unix))]
|
2020-03-08 21:38:49 +02:00
|
|
|
let ctx = execution_context::ExecutionContext::new(run_type, &git, &config, &base_dirs);
|
2020-02-08 22:13:56 +02:00
|
|
|
|
2020-02-09 13:41:55 +02:00
|
|
|
let mut runner = runner::Runner::new(&ctx);
|
|
|
|
|
|
2018-11-12 21:27:49 +02:00
|
|
|
#[cfg(feature = "self-update")]
|
|
|
|
|
{
|
2018-12-31 14:05:15 +02:00
|
|
|
if !run_type.dry() && env::var("TOPGRADE_NO_SELF_UPGRADE").is_err() {
|
2019-06-03 09:41:25 +03:00
|
|
|
let result = self_update::self_update();
|
|
|
|
|
|
2019-12-11 23:05:38 +02:00
|
|
|
if let Err(e) = &result {
|
|
|
|
|
#[cfg(windows)]
|
|
|
|
|
{
|
|
|
|
|
if e.downcast_ref::<Upgraded>().is_some() {
|
|
|
|
|
return result;
|
|
|
|
|
}
|
2019-06-03 09:41:25 +03:00
|
|
|
}
|
2018-12-05 11:34:08 +02:00
|
|
|
print_warning(format!("Self update error: {}", e));
|
2018-11-12 21:27:49 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2018-11-07 14:31:44 +02:00
|
|
|
|
2018-06-20 20:26:08 +03:00
|
|
|
if let Some(commands) = config.pre_commands() {
|
|
|
|
|
for (name, command) in commands {
|
2020-02-08 22:13:56 +02:00
|
|
|
generic::run_custom_command(&name, &command, &ctx)?;
|
2018-06-20 20:26:08 +03:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-08-14 21:36:57 +03:00
|
|
|
let powershell = powershell::Powershell::new();
|
2019-09-05 20:43:18 +03:00
|
|
|
let should_run_powershell = powershell.profile().is_some() && config.should_run(Step::Shell);
|
2019-02-27 09:47:20 +02:00
|
|
|
|
2019-06-04 09:35:29 +03:00
|
|
|
#[cfg(windows)]
|
2020-04-23 11:23:15 +02:00
|
|
|
{
|
|
|
|
|
if config.should_run(Step::Wsl) {
|
|
|
|
|
runner.execute("WSL", || windows::run_wsl_topgrade(run_type))?;
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-06-04 09:35:29 +03:00
|
|
|
|
2019-06-05 14:15:45 +03:00
|
|
|
if let Some(topgrades) = config.remote_topgrades() {
|
2019-07-01 08:53:53 +03:00
|
|
|
if config.should_run(Step::Remotes) {
|
|
|
|
|
for remote_topgrade in topgrades {
|
2020-02-11 07:56:02 +02:00
|
|
|
runner.execute(remote_topgrade, || generic::run_remote_topgrade(&ctx, remote_topgrade))?;
|
2019-07-01 08:53:53 +03:00
|
|
|
}
|
2019-06-05 14:15:45 +03:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2018-10-02 10:46:38 +03:00
|
|
|
#[cfg(target_os = "linux")]
|
|
|
|
|
let distribution = linux::Distribution::detect();
|
|
|
|
|
|
2018-08-22 22:18:48 +03:00
|
|
|
#[cfg(target_os = "linux")]
|
|
|
|
|
{
|
2019-01-22 22:37:32 +02:00
|
|
|
if config.should_run(Step::System) {
|
2018-10-02 11:36:10 +03:00
|
|
|
match &distribution {
|
2018-10-02 10:46:38 +03:00
|
|
|
Ok(distribution) => {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("System update", || distribution.upgrade(&sudo, run_type, &config))?;
|
2018-10-02 10:46:38 +03:00
|
|
|
}
|
|
|
|
|
Err(e) => {
|
|
|
|
|
println!("Error detecting current distribution: {}", e);
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("etc-update", || linux::run_etc_update(sudo.as_ref(), run_type))?;
|
2018-08-22 22:18:48 +03:00
|
|
|
}
|
2018-06-28 07:47:51 +03:00
|
|
|
}
|
|
|
|
|
|
2018-08-22 22:18:48 +03:00
|
|
|
#[cfg(windows)]
|
2019-09-28 14:49:24 +03:00
|
|
|
{
|
|
|
|
|
if config.should_run(Step::PackageManagers) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("Chocolatey", || windows::run_chocolatey(run_type))?;
|
2018-08-22 22:18:48 +03:00
|
|
|
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("Scoop", || windows::run_scoop(config.cleanup(), run_type))?;
|
2019-09-28 14:49:24 +03:00
|
|
|
}
|
|
|
|
|
}
|
2018-10-17 13:57:30 +03:00
|
|
|
|
2018-08-19 14:45:23 +03:00
|
|
|
#[cfg(unix)]
|
2019-09-28 14:49:24 +03:00
|
|
|
{
|
|
|
|
|
if config.should_run(Step::PackageManagers) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("brew", || unix::run_homebrew(config.cleanup(), run_type))?;
|
2020-02-27 20:28:50 +02:00
|
|
|
#[cfg(target_os = "macos")]
|
|
|
|
|
runner.execute("MacPorts", || macos::run_macports(&ctx))?;
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("nix", || unix::run_nix(&ctx))?;
|
|
|
|
|
runner.execute("home-manager", || unix::run_home_manager(run_type))?;
|
2020-02-29 09:07:03 +02:00
|
|
|
runner.execute("asdf", || unix::run_asdf(run_type))?;
|
2019-11-04 23:04:35 +02:00
|
|
|
}
|
2019-09-28 14:49:24 +03:00
|
|
|
}
|
|
|
|
|
|
2019-06-25 22:47:36 -07:00
|
|
|
#[cfg(target_os = "dragonfly")]
|
2019-09-28 14:49:24 +03:00
|
|
|
{
|
|
|
|
|
if config.should_run(Step::PackageManagers) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("DragonFly BSD Packages", || {
|
|
|
|
|
dragonfly::upgrade_packages(sudo.as_ref(), run_type)
|
|
|
|
|
})?;
|
2019-09-28 14:49:24 +03:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2018-11-12 11:13:43 +02:00
|
|
|
#[cfg(target_os = "freebsd")]
|
2019-09-28 14:49:24 +03:00
|
|
|
{
|
|
|
|
|
if config.should_run(Step::PackageManagers) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("FreeBSD Packages", || {
|
|
|
|
|
freebsd::upgrade_packages(sudo.as_ref(), run_type)
|
|
|
|
|
})?;
|
2019-09-28 14:49:24 +03:00
|
|
|
}
|
|
|
|
|
}
|
2018-08-19 14:45:23 +03:00
|
|
|
|
2019-03-12 08:54:19 +02:00
|
|
|
let emacs = emacs::Emacs::new(&base_dirs);
|
2020-01-28 21:06:33 +02:00
|
|
|
if config.use_predefined_git_repos() {
|
2020-01-28 21:04:59 +02:00
|
|
|
if config.should_run(Step::Emacs) {
|
2020-01-29 21:31:14 +02:00
|
|
|
if !emacs.is_doom() {
|
|
|
|
|
if let Some(directory) = emacs.directory() {
|
2020-03-04 10:32:58 +02:00
|
|
|
git_repos.insert_if_repo(directory);
|
2020-01-29 21:31:14 +02:00
|
|
|
}
|
2020-01-28 21:04:59 +02:00
|
|
|
}
|
2020-03-04 10:32:58 +02:00
|
|
|
git_repos.insert_if_repo(base_dirs.home_dir().join(".doom.d"));
|
2019-01-27 20:04:46 +02:00
|
|
|
}
|
2018-09-05 11:17:15 +03:00
|
|
|
|
2020-01-28 21:04:59 +02:00
|
|
|
if config.should_run(Step::Vim) {
|
2020-03-04 10:32:58 +02:00
|
|
|
git_repos.insert_if_repo(base_dirs.home_dir().join(".vim"));
|
|
|
|
|
git_repos.insert_if_repo(base_dirs.home_dir().join(".config/nvim"));
|
2020-01-28 21:04:59 +02:00
|
|
|
}
|
2018-05-30 07:53:19 +03:00
|
|
|
|
2020-01-28 21:04:59 +02:00
|
|
|
#[cfg(unix)]
|
|
|
|
|
{
|
2020-03-04 10:32:58 +02:00
|
|
|
git_repos.insert_if_repo(zsh::zshrc(&base_dirs));
|
2020-05-12 08:51:42 +03:00
|
|
|
if config.should_run(Step::Tmux) {
|
|
|
|
|
git_repos.insert_if_repo(base_dirs.home_dir().join(".tmux"));
|
|
|
|
|
}
|
2020-03-04 10:32:58 +02:00
|
|
|
git_repos.insert_if_repo(base_dirs.home_dir().join(".config/fish"));
|
|
|
|
|
git_repos.insert_if_repo(base_dirs.config_dir().join("openbox"));
|
|
|
|
|
git_repos.insert_if_repo(base_dirs.config_dir().join("bspwm"));
|
|
|
|
|
git_repos.insert_if_repo(base_dirs.config_dir().join("i3"));
|
|
|
|
|
git_repos.insert_if_repo(base_dirs.config_dir().join("sway"));
|
2020-01-28 21:04:59 +02:00
|
|
|
}
|
2018-05-30 07:53:19 +03:00
|
|
|
|
2020-01-28 21:04:59 +02:00
|
|
|
#[cfg(windows)]
|
2020-03-04 10:32:58 +02:00
|
|
|
git_repos.insert_if_repo(
|
2020-01-28 21:04:59 +02:00
|
|
|
base_dirs
|
|
|
|
|
.data_local_dir()
|
|
|
|
|
.join("Packages/Microsoft.WindowsTerminal_8wekyb3d8bbwe/LocalState"),
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
if let Some(profile) = powershell.profile() {
|
2020-03-04 10:32:58 +02:00
|
|
|
git_repos.insert_if_repo(profile);
|
2020-01-28 21:04:59 +02:00
|
|
|
}
|
2018-08-23 22:08:04 +03:00
|
|
|
}
|
|
|
|
|
|
2019-01-22 22:37:32 +02:00
|
|
|
if config.should_run(Step::GitRepos) {
|
2018-09-03 11:51:09 -04:00
|
|
|
if let Some(custom_git_repos) = config.git_repos() {
|
|
|
|
|
for git_repo in custom_git_repos {
|
2019-08-11 12:41:09 +03:00
|
|
|
git_repos.glob_insert(git_repo);
|
2018-09-03 11:51:09 -04:00
|
|
|
}
|
2018-05-30 07:53:19 +03:00
|
|
|
}
|
2020-03-08 21:38:49 +02:00
|
|
|
runner.execute("Git repositories", || git.multi_pull_step(&git_repos, &ctx))?;
|
2018-05-30 07:53:19 +03:00
|
|
|
}
|
2018-05-31 15:59:45 +03:00
|
|
|
|
2019-08-14 21:36:57 +03:00
|
|
|
if should_run_powershell {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("Powershell Modules Update", || powershell.update_modules(run_type))?;
|
2019-03-11 10:30:44 +02:00
|
|
|
}
|
|
|
|
|
|
2018-06-27 23:04:39 +03:00
|
|
|
#[cfg(unix)]
|
|
|
|
|
{
|
2019-09-05 13:38:45 -04:00
|
|
|
if config.should_run(Step::Shell) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("zr", || zsh::run_zr(&base_dirs, run_type))?;
|
2020-02-11 06:57:30 +01:00
|
|
|
runner.execute("antibody", || zsh::run_antibody(run_type))?;
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("antigen", || zsh::run_antigen(&base_dirs, run_type))?;
|
|
|
|
|
runner.execute("zplug", || zsh::run_zplug(&base_dirs, run_type))?;
|
2020-02-12 23:59:28 -06:00
|
|
|
runner.execute("zinit", || zsh::run_zinit(&base_dirs, run_type))?;
|
2020-03-08 21:38:49 +02:00
|
|
|
runner.execute("oh-my-zsh", || zsh::run_oh_my_zsh(&ctx))?;
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("fisher", || unix::run_fisher(&base_dirs, run_type))?;
|
2020-05-12 08:51:42 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if config.should_run(Step::Tmux) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("tmux", || tmux::run_tpm(&base_dirs, run_type))?;
|
2019-09-05 13:38:45 -04:00
|
|
|
}
|
2020-01-05 22:56:18 +02:00
|
|
|
|
|
|
|
|
if config.should_run(Step::Tldr) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("TLDR", || unix::run_tldr(run_type))?;
|
2020-01-05 22:56:18 +02:00
|
|
|
}
|
2018-05-31 16:17:22 +03:00
|
|
|
}
|
|
|
|
|
|
2019-08-19 20:15:01 +03:00
|
|
|
if config.should_run(Step::Rustup) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("rustup", || generic::run_rustup(&base_dirs, run_type))?;
|
2019-08-19 20:15:01 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if config.should_run(Step::Cargo) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("cargo", || generic::run_cargo_update(run_type))?;
|
2019-08-19 20:15:01 +03:00
|
|
|
}
|
2018-09-05 11:17:15 +03:00
|
|
|
|
2019-11-20 13:35:41 +02:00
|
|
|
if config.should_run(Step::Flutter) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("Flutter", || generic::run_flutter_upgrade(run_type))?;
|
2019-11-20 13:35:41 +02:00
|
|
|
}
|
|
|
|
|
|
2019-11-20 14:41:05 +02:00
|
|
|
if config.should_run(Step::Go) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("Go", || generic::run_go(&base_dirs, run_type))?;
|
2019-11-20 14:41:05 +02:00
|
|
|
}
|
|
|
|
|
|
2019-01-22 22:37:32 +02:00
|
|
|
if config.should_run(Step::Emacs) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("Emacs", || emacs.upgrade(run_type))?;
|
2018-09-05 11:17:15 +03:00
|
|
|
}
|
|
|
|
|
|
2019-11-04 23:04:35 +02:00
|
|
|
if config.should_run(Step::Opam) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("opam", || generic::run_opam_update(run_type))?;
|
2019-11-04 23:04:35 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if config.should_run(Step::Vcpkg) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("vcpkg", || generic::run_vcpkg_update(run_type))?;
|
2019-11-04 23:04:35 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if config.should_run(Step::Pipx) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("pipx", || generic::run_pipx_update(run_type))?;
|
2019-11-04 23:04:35 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if config.should_run(Step::Stack) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("stack", || generic::run_stack_update(run_type))?;
|
2019-11-04 23:04:35 +02:00
|
|
|
}
|
|
|
|
|
|
2019-12-12 20:24:22 +02:00
|
|
|
if config.should_run(Step::Tlmgr) {
|
2020-04-03 12:19:55 +03:00
|
|
|
#[cfg(not(target_os = "linux"))]
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("tlmgr", || {
|
|
|
|
|
generic::run_tlmgr_update(
|
|
|
|
|
#[cfg(unix)]
|
|
|
|
|
&sudo,
|
|
|
|
|
#[cfg(windows)]
|
|
|
|
|
&None,
|
|
|
|
|
run_type,
|
|
|
|
|
)
|
|
|
|
|
})?;
|
2019-12-12 20:24:22 +02:00
|
|
|
}
|
|
|
|
|
|
2019-11-04 23:04:35 +02:00
|
|
|
if config.should_run(Step::Myrepos) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("myrepos", || generic::run_myrepos_update(&base_dirs, run_type))?;
|
2019-11-04 23:04:35 +02:00
|
|
|
}
|
|
|
|
|
|
2019-02-19 08:47:01 +02:00
|
|
|
#[cfg(unix)]
|
2019-11-04 23:04:35 +02:00
|
|
|
{
|
|
|
|
|
if config.should_run(Step::Pearl) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("pearl", || unix::run_pearl(run_type))?;
|
2019-11-04 23:04:35 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if config.should_run(Step::Jetpack) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("jetpak", || generic::run_jetpack(run_type))?;
|
2019-11-04 23:04:35 +02:00
|
|
|
}
|
2019-01-22 22:37:32 +02:00
|
|
|
|
|
|
|
|
if config.should_run(Step::Vim) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("vim", || vim::upgrade_vim(&base_dirs, run_type, config.cleanup()))?;
|
|
|
|
|
runner.execute("Neovim", || vim::upgrade_neovim(&base_dirs, run_type, config.cleanup()))?;
|
|
|
|
|
runner.execute("voom", || vim::run_voom(&base_dirs, run_type))?;
|
2018-12-09 16:58:13 +09:00
|
|
|
}
|
|
|
|
|
|
2019-09-04 12:57:22 +02:00
|
|
|
if config.should_run(Step::Node) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("NPM", || node::run_npm_upgrade(&base_dirs, run_type))?;
|
|
|
|
|
runner.execute("yarn", || node::yarn_global_update(run_type))?;
|
2019-09-04 12:57:22 +02:00
|
|
|
}
|
2020-02-10 22:10:27 +02:00
|
|
|
|
2020-02-10 21:10:06 +01:00
|
|
|
if config.should_run(Step::Composer) {
|
2020-03-08 21:38:25 +02:00
|
|
|
runner.execute("composer", || generic::run_composer_update(&ctx))?;
|
2020-02-10 21:10:06 +01:00
|
|
|
}
|
2018-10-04 11:26:51 +03:00
|
|
|
|
2018-10-29 14:32:33 +02:00
|
|
|
#[cfg(not(any(
|
|
|
|
|
target_os = "freebsd",
|
|
|
|
|
target_os = "openbsd",
|
|
|
|
|
target_os = "netbsd",
|
|
|
|
|
target_os = "dragonfly"
|
|
|
|
|
)))]
|
2019-11-04 23:04:35 +02:00
|
|
|
{
|
|
|
|
|
if config.should_run(Step::Atom) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("apm", || generic::run_apm(run_type))?;
|
2019-11-04 23:04:35 +02:00
|
|
|
}
|
|
|
|
|
}
|
2019-01-13 14:10:23 +00:00
|
|
|
|
2019-01-22 22:37:32 +02:00
|
|
|
if config.should_run(Step::Gem) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("gem", || generic::run_gem(&base_dirs, run_type))?;
|
2019-01-13 14:10:23 +00:00
|
|
|
}
|
2018-06-06 11:27:43 +03:00
|
|
|
|
2018-06-27 23:04:39 +03:00
|
|
|
#[cfg(target_os = "linux")]
|
|
|
|
|
{
|
2019-09-28 14:49:24 +03:00
|
|
|
if config.should_run(Step::PackageManagers) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("Flatpak", || linux::flatpak_update(run_type))?;
|
|
|
|
|
runner.execute("snap", || linux::run_snap(sudo.as_ref(), run_type))?;
|
2019-09-05 02:32:30 -04:00
|
|
|
}
|
2018-06-14 13:24:52 +03:00
|
|
|
}
|
|
|
|
|
|
2018-06-11 08:38:29 +03:00
|
|
|
if let Some(commands) = config.commands() {
|
|
|
|
|
for (name, command) in commands {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute(name, || generic::run_custom_command(&name, &command, &ctx))?;
|
2018-06-11 08:38:29 +03:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2018-06-27 23:04:39 +03:00
|
|
|
#[cfg(target_os = "linux")]
|
|
|
|
|
{
|
2019-11-04 23:04:35 +02:00
|
|
|
if config.should_run(Step::System) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("pihole", || linux::run_pihole_update(sudo.as_ref(), run_type))?;
|
2019-11-04 23:04:35 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if config.should_run(Step::Firmware) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("Firmware upgrades", || linux::run_fwupdmgr(run_type))?;
|
2019-11-04 23:04:35 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if config.should_run(Step::Restarts) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("Restarts", || linux::run_needrestart(sudo.as_ref(), run_type))?;
|
2019-11-04 23:04:35 +02:00
|
|
|
}
|
2018-05-31 09:19:27 +03:00
|
|
|
}
|
|
|
|
|
|
2018-06-27 23:04:39 +03:00
|
|
|
#[cfg(target_os = "macos")]
|
|
|
|
|
{
|
2019-01-22 22:37:32 +02:00
|
|
|
if config.should_run(Step::System) {
|
2020-02-27 15:32:13 +02:00
|
|
|
runner.execute("Microsoft AutoUpdate", || macos::run_msupdate(&ctx))?;
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("App Store", || macos::run_mas(run_type))?;
|
|
|
|
|
runner.execute("System upgrade", || macos::upgrade_macos(run_type))?;
|
2018-08-13 14:39:29 +03:00
|
|
|
}
|
2018-06-03 18:04:58 +03:00
|
|
|
}
|
|
|
|
|
|
2018-11-12 11:13:43 +02:00
|
|
|
#[cfg(target_os = "freebsd")]
|
|
|
|
|
{
|
2019-01-22 22:37:32 +02:00
|
|
|
if config.should_run(Step::System) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("FreeBSD Upgrade", || freebsd::upgrade_freebsd(sudo.as_ref(), run_type))?;
|
2018-11-12 11:13:43 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2018-08-22 22:18:48 +03:00
|
|
|
#[cfg(windows)]
|
|
|
|
|
{
|
2019-01-22 22:37:32 +02:00
|
|
|
if config.should_run(Step::System) {
|
2020-02-27 22:06:14 +02:00
|
|
|
runner.execute("Windows update", || windows::windows_update(&ctx))?;
|
2018-08-22 22:18:48 +03:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-13 12:19:47 +02:00
|
|
|
#[cfg(unix)]
|
|
|
|
|
{
|
|
|
|
|
if config.should_run(Step::Sdkman) {
|
2020-02-09 13:41:55 +02:00
|
|
|
runner.execute("SDKMAN!", || unix::run_sdkman(&base_dirs, config.cleanup(), run_type))?;
|
2019-06-13 12:19:47 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-02-09 13:41:55 +02:00
|
|
|
if !runner.report().data().is_empty() {
|
2018-12-05 11:34:08 +02:00
|
|
|
print_separator("Summary");
|
2018-06-03 18:04:58 +03:00
|
|
|
|
2020-02-09 13:41:55 +02:00
|
|
|
for (key, succeeded) in runner.report().data() {
|
2018-12-05 11:34:08 +02:00
|
|
|
print_result(key, *succeeded);
|
2018-06-03 18:04:58 +03:00
|
|
|
}
|
2018-10-02 11:36:10 +03:00
|
|
|
|
|
|
|
|
#[cfg(target_os = "linux")]
|
|
|
|
|
{
|
|
|
|
|
if let Ok(distribution) = &distribution {
|
|
|
|
|
distribution.show_summary();
|
|
|
|
|
}
|
|
|
|
|
}
|
2018-11-15 11:37:08 +02:00
|
|
|
|
|
|
|
|
#[cfg(target_os = "freebsd")]
|
2018-11-15 15:54:24 +02:00
|
|
|
freebsd::audit_packages(&sudo).ok();
|
2019-06-25 22:47:36 -07:00
|
|
|
|
|
|
|
|
#[cfg(target_os = "dragonfly")]
|
|
|
|
|
dragonfly::audit_packages(&sudo).ok();
|
2018-05-29 23:48:30 +03:00
|
|
|
}
|
|
|
|
|
|
2019-06-16 09:09:05 +03:00
|
|
|
if config.keep_at_end() {
|
2019-08-04 09:25:35 +03:00
|
|
|
print_info("\n(R)eboot\n(S)hell\n(Q)uit");
|
|
|
|
|
loop {
|
|
|
|
|
match get_char() {
|
|
|
|
|
's' | 'S' => {
|
|
|
|
|
run_shell();
|
|
|
|
|
}
|
|
|
|
|
'r' | 'R' => {
|
|
|
|
|
reboot();
|
|
|
|
|
}
|
|
|
|
|
'q' | 'Q' => (),
|
|
|
|
|
_ => {
|
|
|
|
|
continue;
|
|
|
|
|
}
|
2019-06-13 22:05:18 +03:00
|
|
|
}
|
2019-08-04 09:25:35 +03:00
|
|
|
break;
|
2019-06-13 22:05:18 +03:00
|
|
|
}
|
2019-06-13 09:21:39 +03:00
|
|
|
}
|
|
|
|
|
|
2020-02-09 13:41:55 +02:00
|
|
|
if runner.report().data().iter().all(|(_, succeeded)| *succeeded) {
|
2018-06-11 08:57:55 +03:00
|
|
|
Ok(())
|
|
|
|
|
} else {
|
2019-12-11 23:05:38 +02:00
|
|
|
Err(StepFailed.into())
|
2018-06-11 08:57:55 +03:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
|
match run() {
|
|
|
|
|
Ok(()) => {
|
|
|
|
|
exit(0);
|
|
|
|
|
}
|
|
|
|
|
Err(error) => {
|
2019-06-03 09:41:25 +03:00
|
|
|
#[cfg(all(windows, feature = "self-update"))]
|
|
|
|
|
{
|
2019-12-11 23:05:38 +02:00
|
|
|
if let Some(Upgraded(status)) = error.downcast_ref::<Upgraded>() {
|
2019-06-03 09:41:25 +03:00
|
|
|
exit(status.code().unwrap());
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-12-11 23:05:38 +02:00
|
|
|
let skip_print = (error.downcast_ref::<StepFailed>().is_some())
|
|
|
|
|
|| (error
|
|
|
|
|
.downcast_ref::<io::Error>()
|
2018-12-11 16:43:26 +02:00
|
|
|
.filter(|io_error| io_error.kind() == io::ErrorKind::Interrupted)
|
2019-12-11 23:05:38 +02:00
|
|
|
.is_some());
|
2018-12-11 16:43:26 +02:00
|
|
|
|
2019-12-11 23:05:38 +02:00
|
|
|
if !skip_print {
|
2018-12-11 16:43:26 +02:00
|
|
|
println!("Error: {}", error);
|
2018-10-17 14:07:58 +03:00
|
|
|
}
|
2018-06-11 08:57:55 +03:00
|
|
|
exit(1);
|
|
|
|
|
}
|
|
|
|
|
}
|
2018-05-29 23:48:30 +03:00
|
|
|
}
|