Move vim upgrade to its module

This commit is contained in:
Roey Darwish Dror
2018-07-14 22:19:03 +03:00
parent 103c5a19c9
commit dccf508044
3 changed files with 28 additions and 26 deletions

View File

@@ -191,7 +191,7 @@ fn run() -> Result<(), Error> {
if let Some(vimrc) = vim::vimrc(&base_dirs) { if let Some(vimrc) = vim::vimrc(&base_dirs) {
if let Some(plugin_framework) = vim::PluginFramework::detect(&vimrc) { if let Some(plugin_framework) = vim::PluginFramework::detect(&vimrc) {
terminal.print_separator(&format!("Vim ({:?})", plugin_framework)); terminal.print_separator(&format!("Vim ({:?})", plugin_framework));
run_vim(&vim, &vimrc, plugin_framework.upgrade_command()).report("Vim", &mut reports); vim::upgrade(&vim, &vimrc, &plugin_framework).report("Vim", &mut reports);
} }
} }
} }
@@ -200,7 +200,7 @@ fn run() -> Result<(), Error> {
if let Some(nvimrc) = vim::nvimrc(&base_dirs) { if let Some(nvimrc) = vim::nvimrc(&base_dirs) {
if let Some(plugin_framework) = vim::PluginFramework::detect(&nvimrc) { if let Some(plugin_framework) = vim::PluginFramework::detect(&nvimrc) {
terminal.print_separator(&format!("Neovim ({:?})", plugin_framework)); terminal.print_separator(&format!("Neovim ({:?})", plugin_framework));
run_vim(&nvim, &nvimrc, plugin_framework.upgrade_command()).report("Neovim", &mut reports); vim::upgrade(&nvim, &nvimrc, &plugin_framework).report("Neovim", &mut reports);
} }
} }
} }

View File

@@ -26,29 +26,6 @@ pub fn run_emacs(emacs: &PathBuf, init: &PathBuf) -> Result<(), failure::Error>
Ok(()) Ok(())
} }
pub fn run_vim(vim: &PathBuf, vimrc: &PathBuf, upgrade_command: &str) -> Result<(), failure::Error> {
Command::new(&vim)
.args(&[
"-N",
"-u",
vimrc.to_str().unwrap(),
"-c",
upgrade_command,
"-c",
"quitall",
"-e",
"-s",
"-V1",
])
.spawn()?
.wait()?
.check()?;
println!();
Ok(())
}
pub fn run_apm(apm: &PathBuf) -> Result<(), failure::Error> { pub fn run_apm(apm: &PathBuf) -> Result<(), failure::Error> {
Command::new(&apm) Command::new(&apm)
.args(&["upgrade", "--confirm=false"]) .args(&["upgrade", "--confirm=false"])

View File

@@ -1,7 +1,9 @@
use super::utils::PathExt; use super::utils::{Check, PathExt};
use directories::BaseDirs; use directories::BaseDirs;
use failure;
use std::fs; use std::fs;
use std::path::PathBuf; use std::path::PathBuf;
use std::process::Command;
#[derive(Debug, Clone, Copy)] #[derive(Debug, Clone, Copy)]
pub enum PluginFramework { pub enum PluginFramework {
@@ -49,3 +51,26 @@ pub fn nvimrc(base_dirs: &BaseDirs) -> Option<PathBuf> {
#[cfg(windows)] #[cfg(windows)]
return base_dirs.cache_dir().join("nvim/init.vim").if_exists(); return base_dirs.cache_dir().join("nvim/init.vim").if_exists();
} }
pub fn upgrade(vim: &PathBuf, vimrc: &PathBuf, plugin_framework: &PluginFramework) -> Result<(), failure::Error> {
Command::new(&vim)
.args(&[
"-N",
"-u",
vimrc.to_str().unwrap(),
"-c",
plugin_framework.upgrade_command(),
"-c",
"quitall",
"-e",
"-s",
"-V1",
])
.spawn()?
.wait()?
.check()?;
println!();
Ok(())
}