242 lines
5.8 KiB
Bash
Executable File
242 lines
5.8 KiB
Bash
Executable File
#!/bin/sh
|
|
|
|
# Copyright (c) 2017 rehashedsalt/vintagesalt
|
|
# Licensed under the terms of the MIT license
|
|
|
|
## POSIX NOTICE
|
|
# This script, or at least the parts expected to be run by a standard sh
|
|
# implementation, should be fully POSIX-compliant. If it is not, open a bug
|
|
# report at gitlab.com/rehashedsalt/home and I'll take care of it.
|
|
|
|
## SHELLCHECK
|
|
# Not finding these sources is none of my concern; they're out of scope
|
|
# shellcheck disable=1091
|
|
# shellcheck disable=1090
|
|
# I'm well aware of when functions are defined vs used
|
|
# Those choices are deliberate
|
|
# shellcheck disable=2139
|
|
# shellcheck disable=2016
|
|
# Some variables will not be used here, but in the shell
|
|
# shellcheck disable=2034
|
|
# Quit being pedantic
|
|
# shellcheck disable=1117
|
|
|
|
# Environment variables
|
|
_baseshell="$(basename -- "$0")"
|
|
|
|
# Patch PATH
|
|
desiredpath="/usr/local/bin:/usr/local/sbin:/usr/bin:/usr/sbin:/bin:/sbin:/usr/local/games:/usr/games:$HOME/.bin:$HOME/.local/bin"
|
|
IFS=":"
|
|
for path in $desiredpath; do
|
|
PATH="${PATH#*$path}"
|
|
done
|
|
unset IFS
|
|
while [ "${PATH#:}" != "$PATH" ]; do
|
|
PATH="${PATH#:}"
|
|
done
|
|
PATH="$desiredpath:$PATH"
|
|
|
|
# Grab bash_completion, if it exists
|
|
[ -f "/etc/profile.d/bash_completion.sh" ] && . "/etc/profile.d/bash_completion.sh"
|
|
|
|
# Source ~/.functions, if it exists
|
|
[ -r "$HOME/.functions" ] \
|
|
&& [ "$_baseshell" != "sh" ] \
|
|
&& [ "$_baseshell" != "dash" ] \
|
|
&& . "$HOME/.functions"
|
|
|
|
# Define a require function
|
|
has() {
|
|
[ -z "$1" ] && return 1
|
|
command -v "$1" > /dev/null 2>&1
|
|
}
|
|
|
|
# Grab pip completion, if it exists
|
|
if has pip; then
|
|
case "$_baseshell" in
|
|
*bash)
|
|
if ! [ -f "$HOME/.pip-completion-bash" ]; then
|
|
pip completion --bash > "$HOME/.pip-completion-bash"
|
|
echo ".profile: Created pip completion for bash"
|
|
fi
|
|
. "$HOME/.pip-completion-bash"
|
|
;;
|
|
zsh)
|
|
if ! [ -f "$HOME/.pip-completion-zsh" ]; then
|
|
pip completion --zsh > "$HOME/.pip-completion-zsh"
|
|
echo ".profile: Created pip completion for zsh"
|
|
fi
|
|
. "$HOME/.pip-completion-zsh"
|
|
;;
|
|
*)
|
|
;;
|
|
esac
|
|
fi
|
|
|
|
# Set up go, if we have it
|
|
if has go; then
|
|
export GOPATH="$HOME/.local/go"
|
|
[ "${PATH#*$GOPATH}" = "$PATH" ] && export PATH="$PATH:$GOPATH/bin"
|
|
fi
|
|
|
|
# Grab dircolors, if it exists
|
|
if has dircolors; then
|
|
dircolorsfile="$HOME/.config/dircolors"
|
|
if [ -r "$dircolorsfile" ]; then
|
|
eval "$(dircolors "$dircolorsfile")"
|
|
else
|
|
eval "$(dircolors -b)"
|
|
fi
|
|
fi
|
|
|
|
# Set up our text editor
|
|
for editor in vim vi nano; do
|
|
if has "$editor"; then
|
|
export EDITOR="$editor"
|
|
break
|
|
fi
|
|
done
|
|
alias e='$EDITOR'
|
|
|
|
# Now for a shitton of aliases
|
|
if ! has define; then
|
|
if has mate-dictionary; then
|
|
alias define='mate-dictionary -n --look-up'
|
|
fi
|
|
fi
|
|
if has emerge; then
|
|
alias e-depclean='sudo emerge -a --depclean'
|
|
alias e-inst='sudo emerge -a --jobs --tree --quiet-build y'
|
|
alias e-upgrade='sudo emerge -DNUua --jobs --tree --quiet-build y --with-bdeps=y --keep-going --backtrack=1000 @world'
|
|
alias e-newuse='sudo emerge -Uva --jobs --tree --quiet-build y @world'
|
|
alias e-search='emerge -s'
|
|
alias e-sync='sudo emerge --sync'
|
|
if has eclean; then
|
|
alias e-cleanup='sudo eclean -d distfiles && sudo eclean -d packages'
|
|
fi
|
|
fi
|
|
if has instantmusic; then
|
|
alias song='instantmusic -p -s'
|
|
alias songp='instantmusic -s'
|
|
fi
|
|
if has sudo; then
|
|
case $_baseshell in
|
|
*bash|*zsh)
|
|
export SUDO_PROMPT=$'[\e[34msudo\e[0m as %U]: Password for %p: '
|
|
;;
|
|
*)
|
|
export SUDO_PROMPT='[sudo as %U]: Password for %p: '
|
|
esac
|
|
fi
|
|
|
|
# Dotfile management aliases
|
|
if [ -d "$HOME/.dotfiles" ]; then
|
|
dotcmd='git --git-dir=$HOME/.dotfiles/ --work-tree=$HOME'
|
|
alias dot="$dotcmd"
|
|
alias dotupdate="\
|
|
printf 'Pulling...\n'; \
|
|
$dotcmd pull
|
|
printf 'Updating submodules...\n'; \
|
|
$dotcmd submodule update --init; \
|
|
printf 'Checking out masters...\n'; \
|
|
$dotcmd submodule -q foreach --recursive 'git checkout -q master && git pull' && \
|
|
$dotcmd status"
|
|
unset dotcmd
|
|
fi
|
|
|
|
# Aliases for common utilities
|
|
if [ "$(uname)" = "Linux" ]; then
|
|
# Assume we have GNU coreutils
|
|
lsarguments='--color=auto --group-directories-first'
|
|
alias l="ls -CF --file-type $lsarguments"
|
|
alias la="ls -AF --file-type $lsarguments"
|
|
alias ls="ls -F $lsarguments"
|
|
alias ll="ls -AhlF --file-type $lsarguments"
|
|
unset lsarguments
|
|
|
|
alias rm='rm -I'
|
|
else
|
|
# Else only assume POSIX/BSD
|
|
lsarguments='-F'
|
|
alias l="ls -$lsarguments"
|
|
alias la="ls -A $lsarguments"
|
|
alias ls="ls $lsarguments"
|
|
alias ll="ls -Ahl $lsarguments"
|
|
fi
|
|
alias cp='cp -i'
|
|
alias d='du -hs'
|
|
alias todo='$EDITOR "$HOME/Documents/todo"'
|
|
|
|
# Set up a default PS1
|
|
# This *should* work for all terminals. I know it works on ksh
|
|
_ps1() {
|
|
exitcode="$?"
|
|
r="\e[0m"
|
|
fg_blue="\e[34m"
|
|
fg_red="\e[31m"
|
|
fg_green="\e[32m"
|
|
fg_yellow="\e[33m"
|
|
fg_grey="\e[37m"
|
|
fg_bold="\e[1m"
|
|
|
|
# Add hostname prefix in SSH sessions
|
|
# Yes, shellcheck. I get it. That's what the or is for
|
|
#shellcheck disable=2039
|
|
if [ "$HOSTNAME" = "phys-saltshaker" ] || [ "$(hostname)" = "phys-saltshaker" ]; then
|
|
prefix="${fg_bold}${fg_grey}ss${r}${fg_grey}:${r}"
|
|
fi
|
|
if [ "$SSH_CLIENT" ]; then
|
|
prefix="${fg_bold}${fg_red}$(hostname)${r}${fg_red}:${r}${prefix}"
|
|
fi
|
|
# Append "vim" in Vim
|
|
if [ -n "$VIM_TERMINAL" ]; then
|
|
prefix="${fg_bold}${fg_green}*${r}"
|
|
fi
|
|
# Change PWD color depending on the shell
|
|
case $0 in
|
|
*bash)
|
|
prefix="${prefix}${fg_blue}"
|
|
;;
|
|
/bin/ksh)
|
|
prefix="${prefix}${fg_green}"
|
|
;;
|
|
/bin/sh)
|
|
prefix="${prefix}${fg_grey}"
|
|
;;
|
|
*)
|
|
;;
|
|
esac
|
|
# Show the tilde instead of $HOME
|
|
if [ "${PWD#$HOME}" != "$PWD" ]; then
|
|
cpwd="~${PWD#$HOME}"
|
|
else
|
|
cpwd="$PWD"
|
|
fi
|
|
# Alert us if the last command failed
|
|
fail=""
|
|
if ! [ "$exitcode" = "0" ]; then
|
|
fail="${fg_bold}${fg_red}?"
|
|
fi
|
|
# shellcheck disable=2059
|
|
printf "[${prefix}${cpwd}${r}]${fail}${r}${fg_green}\$${r} "
|
|
}
|
|
|
|
# And export our PS1
|
|
case "$_baseshell" in
|
|
zsh)
|
|
# Don't do this on ZSH
|
|
# I have a custom theme for that
|
|
;;
|
|
sh|dash)
|
|
export PS1='\$ '
|
|
;;
|
|
*)
|
|
export PS1='$(_ps1)'
|
|
;;
|
|
esac
|
|
|
|
# Clean up
|
|
unset -v _baseshell
|
|
unset -f has
|
|
|