Refactor setup script to be re-runnable
This commit is contained in:
parent
11bdbd022d
commit
8944bc3c30
113
setup.sh
Normal file → Executable file
113
setup.sh
Normal file → Executable file
@ -5,7 +5,7 @@ DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null 2>&1 && pwd )"
|
|||||||
APT=`command -v apt`
|
APT=`command -v apt`
|
||||||
DNF=`command -v dnf`
|
DNF=`command -v dnf`
|
||||||
|
|
||||||
function check_or_install {
|
function check_or_install() {
|
||||||
CMD=`command -v $1`
|
CMD=`command -v $1`
|
||||||
PKG=$2
|
PKG=$2
|
||||||
if [[ -z "$CMD" ]]; then
|
if [[ -z "$CMD" ]]; then
|
||||||
@ -18,46 +18,73 @@ function check_or_install {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function setup_neovim() {
|
||||||
|
# Set up Neovim
|
||||||
|
if [[ -d "$HOME/.config/nvim" ]]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
echo "Setting up neovim..."
|
||||||
|
check_or_install nvim "neovim python3-neovim"
|
||||||
|
cd $HOME/.config
|
||||||
|
ln -s $DIR/nvim
|
||||||
|
curl -fLo "${XDG_DATA_HOME:-$HOME/.local/share}"/nvim/site/autoload/plug.vim --create-dirs \
|
||||||
|
https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim
|
||||||
|
}
|
||||||
|
|
||||||
|
function setup_git() {
|
||||||
|
# Set up Git
|
||||||
|
echo "Setting up git..."
|
||||||
|
check_or_install git git
|
||||||
|
git config --global alias.co checkout
|
||||||
|
git config --global alias.ci "commit -a"
|
||||||
|
git config --global alias.st status
|
||||||
|
git config --global alias.br "checkout -b"
|
||||||
|
git config --global alias.rv "reset --hard HEAD"
|
||||||
|
git config --global alias.pum "pull upstream master"
|
||||||
|
git config --global alias.pom "push origin master"
|
||||||
|
git config --global alias.rbm "rebase master"
|
||||||
|
git config --global alias.last "log -1 HEAD"
|
||||||
|
git config --global alias.unstage "reset HEAD --"
|
||||||
|
git config --global alias.uncommit "reset --soft HEAD^"
|
||||||
|
git config --global alias.changelog "!_() { t=\$(git describe --abbrev=0 --tags); git log \${t}..HEAD --no-merges --pretty=format:'* %s'; }; _"
|
||||||
|
git config --global pull.rebase false
|
||||||
|
}
|
||||||
|
|
||||||
|
function setup_zsh() {
|
||||||
|
# Set up ZSH
|
||||||
|
if [[ -d "$HOME/.oh-my-zsh" ]]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
echo "Setting up zsh..."
|
||||||
|
check_or_install zsh zsh
|
||||||
|
sh -c "$(wget https://raw.github.com/ohmyzsh/ohmyzsh/master/tools/install.sh -O -)"
|
||||||
|
cd $HOME/.oh-my-zsh/custom
|
||||||
|
ln -s $DIR/zsh/themes
|
||||||
|
sed -i 's/ZSH_THEME="robbyrussell"/ZSH_THEME="raoul"/' $HOME/.zshrc
|
||||||
|
}
|
||||||
|
|
||||||
|
function setup_topydo() {
|
||||||
|
# Set up topydo
|
||||||
|
if [[ -d "$HOME/.topydo" ]]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
echo "Set up topydo (as 'todo')..."
|
||||||
|
check_or_install virtualenv python3-virtualenv
|
||||||
|
cd $HOME/.config
|
||||||
|
ln -s $DIR/topydo
|
||||||
|
virtualenv -p python3 $HOME/.topydo
|
||||||
|
$HOME/.topydo/bin/pip install topydo
|
||||||
|
$HOME/.topydo/bin/pip install 'topydo[prompt]'
|
||||||
|
$HOME/.topydo/bin/pip install 'topydo[columns]'
|
||||||
|
cd $HOME/bin
|
||||||
|
ln -s $HOME/.topydo/bin/topydo
|
||||||
|
ln -s $HOME/.topydo/bin/topydo todo
|
||||||
|
}
|
||||||
|
|
||||||
# Set up a generic bin directory for scripts and tools
|
# Set up a generic bin directory for scripts and tools
|
||||||
mkdir -p ~/bin
|
mkdir -p $HOME/bin
|
||||||
|
mkdir -p $HOME/.config
|
||||||
# Set up Neovim
|
setup_neovim
|
||||||
check_or_install nvim "neovim python3-neovim"
|
setup_git
|
||||||
mkdir -p ~/.config
|
setup_zsh
|
||||||
cd ~/.config
|
setup_topydo
|
||||||
ln -s $DIR/nvim
|
|
||||||
curl -fLo "${XDG_DATA_HOME:-$HOME/.local/share}"/nvim/site/autoload/plug.vim --create-dirs \
|
|
||||||
https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim
|
|
||||||
|
|
||||||
# Set up Git
|
|
||||||
check_or_install git git
|
|
||||||
git config --global alias.co checkout
|
|
||||||
git config --global alias.ci "commit -a"
|
|
||||||
git config --global alias.st status
|
|
||||||
git config --global alias.br "checkout -b"
|
|
||||||
git config --global alias.rv "reset --hard HEAD"
|
|
||||||
git config --global alias.pum "pull upstream master"
|
|
||||||
git config --global alias.pom "push origin master"
|
|
||||||
git config --global alias.rbm "rebase master"
|
|
||||||
git config --global alias.last "log -1 HEAD"
|
|
||||||
git config --global alias.unstage "reset HEAD --"
|
|
||||||
git config --global alias.uncommit "reset --soft HEAD^"
|
|
||||||
git config --global alias.changelog "!_() { t=$(git describe --abbrev=0 --tags); git log ${t}..HEAD --no-merges --pretty=format:'* %s'; }; _"
|
|
||||||
git config --global pull.rebase false
|
|
||||||
|
|
||||||
# Set up ZSH
|
|
||||||
check_or_install zsh zsh
|
|
||||||
sh -c "$(wget https://raw.github.com/ohmyzsh/ohmyzsh/master/tools/install.sh -O -)"
|
|
||||||
cd ~/.oh-my-zsh/custom
|
|
||||||
ln -s $DIR/zsh/themes
|
|
||||||
sed -i 's/ZSH_THEME="robbyrussell"/ZSH_THEME="raoul"/' ~/.zshrc
|
|
||||||
|
|
||||||
# Set up topydo
|
|
||||||
check_or_install virtualenv python3-virtualenv
|
|
||||||
cd ~/.config
|
|
||||||
ln -s $DIR/topydo
|
|
||||||
virtualenv -p python3 ~/.config/topydo/venv
|
|
||||||
~/.config/topydo/venv/bin/pip install topydo
|
|
||||||
cd ~/bin
|
|
||||||
ln -s $HOME/.config/topydo/venv/bin/topydo
|
|
||||||
ln -s $HOME/.config/topydo/venv/bin/topydo todo
|
|
||||||
|
Loading…
Reference in New Issue
Block a user