479 lines
15 KiB
Bash
479 lines
15 KiB
Bash
#zmodload zsh/zprof
|
|
echo -ne '[ ]\r'
|
|
for config (~/.zsh/*.zsh) source $config
|
|
autoload -U compinit
|
|
compinit
|
|
setopt always_to_end # When completing from the middle of a word, move the cursor to the end of the word
|
|
setopt complete_in_word # Allow completion from within a word/phrase
|
|
setopt INTERACTIVECOMMENTS
|
|
setopt EXTENDED_GLOB
|
|
setopt HIST_EXPIRE_DUPS_FIRST
|
|
export HIST_STAMPS="dd.mm.yyyy"
|
|
export HISTSIZE=12000
|
|
export SAVEHIST=10000000
|
|
export HISTFILE=$HOME/.zsh_history
|
|
setopt APPEND_HISTORY
|
|
setopt EXTENDED_HISTORY
|
|
setopt APPEND_HISTORY SHARE_HISTORY HISTIGNOREALLDUPS
|
|
export DISABLE_AUTO_TITLE=true
|
|
export EDITOR='vim'
|
|
export FZF_COMPLETION_OPTS='--no-mouse -m -1 -x'
|
|
# For pasting in commands that start with $
|
|
$ () {
|
|
$*
|
|
}
|
|
# A service implementation
|
|
sv () {
|
|
command="${@: -1}"
|
|
while (( $# > 1 )); do
|
|
if [[ "$command" == "r" ]]; then
|
|
echo "Restarting $1"
|
|
sudo service "$1" restart
|
|
elif [[ "$command" == "s" ]]; then
|
|
echo "Starting $1"
|
|
sudo service "$1" start
|
|
elif [[ "$command" == "x" ]]; then
|
|
echo "Stopping $1"
|
|
sudo service "$1" stop
|
|
elif [[ "$command" == "i" ]]; then
|
|
echo "Status of $1"
|
|
service "$1" status
|
|
else
|
|
sudo service "$1" "$command"
|
|
fi
|
|
shift
|
|
done
|
|
}
|
|
compdef _services sv
|
|
# Run gui application as root by copying xauth credentials
|
|
asroot(){
|
|
# Use temporary file for added security
|
|
TEMPFILE=$(tempfile)
|
|
xauth extract $TEMPFILE $DISPLAY
|
|
sudo zsh -c "xauth merge $TEMPFILE;(srm $TEMPFILE||rm $TEMPFILE)&'$@';"
|
|
}
|
|
# De-symlink
|
|
dsl() {
|
|
while (( $# > 0 )); do
|
|
readlink $1 2>&1 >/dev/null && mv $(readlink $1) $1
|
|
shift
|
|
done
|
|
}
|
|
# Remove directory by removing subdirectories up a level
|
|
dedir(){
|
|
# Try removing the directory if it's empty, fail silently if you can't
|
|
=rmdir "$1" 2>/dev/null && return
|
|
# Make a uuid to avoid name conflicts
|
|
# Ex: dediring sage when sage/sage fails because sage/sage is moved to .
|
|
# but since sage/ exists, it can't be moved
|
|
name=$(uuidgen)
|
|
# Move the directory to the uuid
|
|
=mv -n "$1" "$name" || return 1
|
|
# Move all files, use (N) in case there is no * or .* matches
|
|
=mv -n "$name"/{.,}*(N) . || return 2
|
|
=rmdir "$name" || return 3
|
|
}
|
|
smt(){
|
|
sudo multitail "/var/log/$1"
|
|
}
|
|
run(){
|
|
test -f "${1:r}" && rm "${1:r}"
|
|
echo "Building..." >&2
|
|
gcc -Wall -std=c99 "${1:r}.c" -o "${1:r}" && (echo "Running..." >&2;./"${1:r}")
|
|
}
|
|
alias mt='multitail'
|
|
alias tg='telegram-cli -N -W'
|
|
alias perm='stat -c "%a %n"'
|
|
alias afci='git x ./autoformat.sh;git add --all;git commit -m "Autoformatted"'
|
|
alias eix="eix -F"
|
|
alias mouse1="xmodmap <(echo pointer = 1 2 3)"
|
|
alias mouse2="xmodmap <(echo pointer = 3 2 1)"
|
|
alias ocp="ocp -vs0 -dcurses"
|
|
alias con='git x php app/console'
|
|
alias srm='shred -uzv'
|
|
alias disphost='export DISPLAY=:0.0'
|
|
alias ll='ls -AlhF'
|
|
alias la='ls -A'
|
|
alias l='ls -CF'
|
|
alias logout='sudo pkill -u $USER'
|
|
alias tmux='tmux -2'
|
|
alias less='less -R'
|
|
alias tree='tree -C'
|
|
alias skim="(head -5; tail -5) <"
|
|
alias cp='rsync --partial -ha --info=progress2 "$@"'
|
|
alias resource='. ~/.zshrc'
|
|
if [ "$(uname)" != "Darwin" ]; then
|
|
# Not Mac
|
|
export PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:$(readlink -e ~/bin)"
|
|
alias ls='ls --color=always -F'
|
|
alias matlab='matlab -glnx86'
|
|
alias where="readlink -m"
|
|
else
|
|
# It is a mac
|
|
export PATH="/opt/local/sbin:/opt/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:~/bin"
|
|
alias where="echo Can't find mac readlink!"
|
|
fi
|
|
if test -f /etc/gentoo-release; then
|
|
# Gentoo
|
|
alias etup='sudo etc-update'
|
|
ins(){
|
|
# Sudo echo so we have immediate results on weather sudo worked
|
|
sudo echo "Args: $*"
|
|
# Beep, verbose, ask
|
|
sudo zsh -c "emerge --autounmask-write -Ava $*"
|
|
echo "\a"
|
|
}
|
|
upgrade(){
|
|
# Sudo echo so we have immediate results on weather sudo worked
|
|
sudo echo "Args: $*"
|
|
sudo emerge --update --newuse --with-bdeps=y --deep --verbose --tree --keep-going=y --verbose-conflicts --alert --ask $* @world
|
|
echo "\\a"
|
|
}
|
|
# For emerging with absolute paths
|
|
em(){
|
|
# Beep, verbose, ask
|
|
EMERGE_ARGS="-Ava"
|
|
X=""
|
|
for var in "$@"
|
|
do
|
|
if [[ "$var" =~ ^- ]]; then
|
|
EMERGE_ARGS="$EMERGE_ARGS $var"
|
|
else
|
|
X="$X =$var"
|
|
fi
|
|
done
|
|
echo sudo emerge "$EMERGE_ARGS""$X"
|
|
sudo emerge "$EMERGE_ARGS""$X"
|
|
echo "\a"
|
|
}
|
|
update(){
|
|
# If this is a server computer
|
|
if [ "$(hostname|cut -b1)" = "S" ] ; then
|
|
echo "You're a server. Exiting"
|
|
return
|
|
fi
|
|
sudo zsh -c "git -C /usr/portage pull&&echo Done pulling&&eix-update&&echo Done with eix"
|
|
echo '\a'
|
|
}
|
|
elif test -f /etc/lsb-release; then
|
|
# Ubuntu
|
|
alias install='sudo apt-get --show-progress install'
|
|
alias remove='sudo apt-get --show-progress remove'
|
|
alias update='sudo apt-get update'
|
|
alias upgrade='sudo apt-get --show-progress upgrade'
|
|
alias autoremove='sudo apt-get --show-progress autoremove'
|
|
alias updateall='sudo sh -c "apt-get update;apt-get upgrade -y;apt-get dist-upgrade -y;apt-get autoremove -y"'
|
|
alias search='apt-cache search'
|
|
fi
|
|
alias ..='k ..'
|
|
alias ...='k ../..'
|
|
alias ....='k ../../..'
|
|
alias .....='k ../../../..'
|
|
alias ......='k ../../../../..'
|
|
alias .......='k ../../../../../..'
|
|
alias ........='k ../../../../../../..'
|
|
alias .........='k ../../../../../../../..'
|
|
alias ..........='k ../../../../../../../../..'
|
|
alias ...........='k ../../../../../../../../../..'
|
|
alias ............='k ../../../../../../../../../../..'
|
|
alias .............='k ../../../../../../../../../../../..'
|
|
alias ..............='k ../../../../../../../../../../../../..'
|
|
alias ...............='k ../../../../../../../../../../../../../..'
|
|
alias ytdl="youtube-dl $@ -x --audio-format mp3 --audio-quality 0 -c -o '%(title)s.%(ext)s'"
|
|
alias tux="wemux"
|
|
alias g="git"
|
|
alias stdns="sudo sh -c 'echo nameserver 8.8.8.8 > /etc/resolv.conf'"
|
|
alias fvim="vim -u NONE +\"so ~/.vim/plugged/flappyvird-vim/plugin/flappyvird.vim\" +\"so ~/.vim/plugged/flappyvird-vim/autoload/flappyvird.vim\" +\":FlappyVird\" +\":q\""
|
|
alias fk='k `fzf --no-mouse -m -1 -x`'
|
|
alias susp="sudo true&&(slock&echo mem | sudo tee /sys/power/state >/dev/null)"
|
|
alias -g PA='2>&1 | paste'
|
|
alias s='sudo -Hu'
|
|
alias -g c='rsync --partial -ha --info=progress2 "$@"'
|
|
alias -g cfat='rsync --partial -hrlc --info=progress2 "$@"'
|
|
alias -g nify=" > /dev/null 2>&1 &"
|
|
alias -g nifyd=" > /dev/null 2>&1 & disown"
|
|
alias -g L="2>&1|less"
|
|
alias -g G='|& ag'
|
|
alias -g GA='|& ag --pager less'
|
|
fixsh(){
|
|
sed -i -e $1"d" ~/.ssh/known_hosts
|
|
}
|
|
mv() { /bin/mv -v "$@" }
|
|
m() { mv "$@" }
|
|
compdef _cp c cfat m mv cp
|
|
paste() {
|
|
NAME="-d title=Command run at $(date '+%d/%h/%y %H:%M:%S') on $(hostname)"
|
|
if [[ ! -z "$1" ]]; then
|
|
NAME="-d title=$1"
|
|
fi
|
|
sed -r "s/\x1B\[([0-9]{1,2}(;[0-9]{1,2})?)?[mGK]//g" | curl --data-urlencode text@- $NAME -d name=$USER -d expire="40320" https://austenwares.com/paste/api/create
|
|
}
|
|
grename() {
|
|
echo incomplete
|
|
return
|
|
FILES=($*)
|
|
REGEX='s///'
|
|
echo -n "Command (frneVVVq): "
|
|
while read input; do
|
|
case $input in
|
|
f)
|
|
echo "File list:"
|
|
printf '%s\n' $FILES
|
|
;;
|
|
r)
|
|
echo "Regex:"
|
|
echo "$REGEX"
|
|
;;
|
|
n)
|
|
echo "Simulated replacement:"
|
|
perl-rename -n "$REGEX" $FILES
|
|
;;
|
|
e)
|
|
echo "Editing regex..."
|
|
TEMPFILE=$(tempfile)
|
|
(cat <(printf '%s\n' $FILES);echo;echo "$REGEX") > $TEMPFILE
|
|
vim $TEMPFILE +'normal G$h'
|
|
REGEX=$(tac $TEMPFILE|grep -m1 '.')
|
|
rm $TEMPFILE
|
|
;;
|
|
VVV)
|
|
echo "Actual results:"
|
|
perl-rename -v $REGEX $FILES
|
|
return
|
|
;;
|
|
q)
|
|
return
|
|
;;
|
|
esac
|
|
echo -n "Command (frneVVVq): "
|
|
done
|
|
}
|
|
bp(){
|
|
echo '\a'
|
|
}
|
|
apush(){
|
|
adb push $* & pv -d $!
|
|
}
|
|
ltar(){
|
|
tar -cf - $@|pv -WcN tar|xz|pv -WcN lzma
|
|
#tar -cf - $@|pv -WcN tar -s $(echo $(du -sb $@|awk '{print $1}'|tr '\n' '+')0|bc)|gzip|pv -WcN dest
|
|
#tar -cf - $@|pv -WcN tar -s $(echo $(du -sb $@|awk '{print $1}'|tr '\n' '+')0|bc)|gzip|pv -WcN dest
|
|
}
|
|
ctar(){
|
|
tar -cf - $@|pv -WcN tar|gzip|pv -WcN gzip
|
|
}
|
|
offline(){
|
|
if [ ! -z "$@" ] ; then
|
|
sudo unshare -n -- sudo -u $USER zsh -c "$@"
|
|
else
|
|
sudo unshare -n -- sudo -u $USER LP_MARK_PREFIX=" $(tput setaf 1)(offline)$(tput sgr0) " zsh
|
|
fi
|
|
}
|
|
dnstest(){
|
|
echo "resolv.conf:"
|
|
cat /etc/resolv.conf
|
|
echo "Testing DNS:"
|
|
dig google.com
|
|
echo "Testing ping:"
|
|
ping -c 2 8.8.8.8
|
|
echo "Testing IP curl:"
|
|
curl -k http://98.26.78.121/b/
|
|
echo
|
|
echo "Testing DNS"
|
|
curl ifconfig.me
|
|
}
|
|
tsh(){
|
|
ssh -X $*
|
|
if which ponysay >/dev/null; then
|
|
ponysay "Connection closed!"
|
|
else
|
|
echo "\n\n\n\n\n\n\n\n\n\nSESSION CLOSED\n\n\n\n\n\n\n\n\n\n"
|
|
fi
|
|
}
|
|
compdefas () {
|
|
local a
|
|
a="$1"
|
|
shift
|
|
compdef "$_comps[$a]" "${(@)*}=$a"
|
|
}
|
|
compdefas ssh tsh
|
|
compdefas mv m mv
|
|
mcl(){
|
|
mkdir -p $1
|
|
cd $1
|
|
}
|
|
create-repo(){
|
|
PRIVATE="true"
|
|
while getopts ":p" opt; do
|
|
case $opt in
|
|
p)
|
|
echo "-p was used, making public"
|
|
PRIVATE="false"
|
|
shift
|
|
;;
|
|
\?)
|
|
echo "Usage: create-repo [-p] name" >&2
|
|
return 1
|
|
;;
|
|
esac
|
|
done
|
|
if [ -z "$1" ]; then
|
|
echo "No repo name" >&2
|
|
return 2
|
|
fi
|
|
echo -n "Username: "
|
|
read username
|
|
echo -n "Password: "
|
|
read -s password
|
|
curl --user "$username:$password" -d name="$1" -d private="$PRIVATE" https://austenwares.com/gogs/api/v1/user/repos
|
|
}
|
|
hsh(){
|
|
FILE="$1"
|
|
ARGS=""
|
|
while (( $# > 0 )); do
|
|
if [[ "md5" = "$1" ]] || [[ "md5sum" = "$1" ]] || [[ "m" = "$1" ]]; then
|
|
ARGS="$ARGS "md5sum
|
|
elif [[ "sha1" = "$1" ]] || [[ "sha1sum" = "$1" ]] || [[ "s" = "$1" ]]; then
|
|
ARGS="$ARGS "sha1sum
|
|
elif [[ "sha2" = "$1" ]] || [[ "sha256sum" = "$1" ]]; then
|
|
ARGS="$ARGS "sha256sum
|
|
elif [[ "sha512" = "$1" ]] || [[ "sha512sum" = "$1" ]]; then
|
|
ARGS="$ARGS "sha512sum
|
|
fi
|
|
shift
|
|
done
|
|
ARGS=$(echo "$ARGS"|xargs)
|
|
echo "Calculating ($ARGS) of \"$FILE\""
|
|
echo pv "$FILE" \| pee $ARGS
|
|
pv "$FILE" | pee $(echo $ARGS)
|
|
}
|
|
rc(){
|
|
case $1 in
|
|
z) vim ~/.zshrc;;
|
|
v) vim ~/.vimrc;;
|
|
i) vim ~/.i3/config;;
|
|
use) sudo vim /etc/portage/package.use/package.use;;
|
|
make) sudo vim /etc/portage/make.conf;;
|
|
unmask) sudo vim /etc/portage/package.unmask/package.unmask;;
|
|
mask) sudo vim /etc/portage/package.mask/package.mask;;
|
|
accept_keywords) sudo vim /etc/portage/package.accept_keywords/package.accept_keywords;;
|
|
license) sudo vim /etc/portage/package.license/package.license;;
|
|
*) echo "Opts:\nz v i\nuse make unmask mask accept_keywords license"
|
|
esac
|
|
}
|
|
pub-git-init(){
|
|
# Get the project name
|
|
branch=$(git remote -v | ag '^origin\s+' | sed -e 's/^origin\s*//' | cut -d\ -f1 | sed -r -e 's/^.+\///' -e 's/#.+$//' -e 's/\.git$//' | head -n1)
|
|
echo "Branch: $branch"
|
|
# Get the hashed project name
|
|
enc_branch=$(echo "$branch" | sha512sum | cut -d\ -f1)
|
|
git remote add local "gcrypt::git@localhost:stonewareslord/79a79b1a6e37813d9226872c6428aca29eec9f6111558109861cb0dcd2f0ffc8198deea4e361f84e170989212452fdfb21e0ef690da2ad399c03ce308d79dcfe#$enc_branch"
|
|
git remote add ncsu "gcrypt::git@github.ncsu.edu:agadler/a86a0f8757772be2ec617b395a0716679bfce51c1bfdeb8da6127feebd84facde645e9e30188318344eb458f5834e3d86800.git#$enc_branch"
|
|
git remote add gitlab "gcrypt::git@gitlab.com:stonewareslord/e6e03ea006d55de0970a28bcb7fcf65f4c66f98f50830bd69b50c5dc502bdf1a4e4172187cfb5fcef8c32bd7fb316bdc67d7d86713ebfe232f97eb303ac316ae.git#$enc_branch"
|
|
git remote add aws "gcrypt::git@aws:stonewareslord/5e0701d5b5b2118127d378c084be9a1dfb33d185d3e2c5da30a3984f5118e3d5136f3f3b038462bccd538e93f9e32cb06136.git#$enc_branch"
|
|
git config remote.ncsu.gcrypt-participants "CCDFE3F1"
|
|
git config remote.gitlab.gcrypt-participants "CCDFE3F1"
|
|
}
|
|
pub-git-rm(){
|
|
if (( $# == 0 )) ; then
|
|
git remote rm local
|
|
git remote rm ncsu
|
|
git remote rm gitlab
|
|
git remote rm aws
|
|
fi
|
|
while (( $# > 0 )) ; do
|
|
git remote rm "$1"
|
|
shift
|
|
done
|
|
}
|
|
pub-git-push(){
|
|
if (( $# == 0 )) ; then
|
|
git push local --all && git push local --tags
|
|
git push ncsu --all && git push ncsu --tags
|
|
git push gitlab --all && git push gitlab --tags
|
|
git push aws --all && git push aws --tags
|
|
fi
|
|
while (( $# > 0 )) ; do
|
|
git push "$1" --all && git push "$1" --tags
|
|
shift
|
|
done
|
|
}
|
|
pub-git-clone(){
|
|
case $1 in
|
|
ncsu) remote="gcrypt::git@github.ncsu.edu:agadler/a86a0f8757772be2ec617b395a0716679bfce51c1bfdeb8da6127feebd84facde645e9e30188318344eb458f5834e3d86800.git#" ;;
|
|
gitlab) remote="gcrypt::git@gitlab.com:stonewareslord/e6e03ea006d55de0970a28bcb7fcf65f4c66f98f50830bd69b50c5dc502bdf1a4e4172187cfb5fcef8c32bd7fb316bdc67d7d86713ebfe232f97eb303ac316ae.git#" ;;
|
|
local) remote="gcrypt::git@localhost:stonewareslord/79a79b1a6e37813d9226872c6428aca29eec9f6111558109861cb0dcd2f0ffc8198deea4e361f84e170989212452fdfb21e0ef690da2ad399c03ce308d79dcfe#" ;;
|
|
aws) remote="gcrypt::git@aws:stonewareslord/5e0701d5b5b2118127d378c084be9a1dfb33d185d3e2c5da30a3984f5118e3d5136f3f3b038462bccd538e93f9e32cb06136.git#" ;;
|
|
*) echo "Opts: local ncsu gitlab" ; return 1
|
|
esac
|
|
shift
|
|
if [ -z "$1" ] ; then
|
|
echo "No arg2"
|
|
return 2
|
|
fi
|
|
branch=$(echo $1 | sha512sum | cut -d\ -f1)
|
|
git clone "$remote$branch" $1
|
|
}
|
|
k(){
|
|
#More than 1 arguement
|
|
if [[ $# > 1 ]] ; then
|
|
vim $@
|
|
elif [ -d "$@" ] ; then
|
|
#cd then ls
|
|
cd "$@" && ls
|
|
elif [[ "$@" == "-" ]] ; then
|
|
#Because if this isn't here, k - won't work
|
|
cd - && ls
|
|
elif [ -f "$@" ] ; then
|
|
#Extract if it's extractable
|
|
case $1 in
|
|
*.tar.xz) pv $1|tar -xJf - ;;
|
|
*.txz) pv $1|tar -xJf - ;;
|
|
*.tar.bz2) pv $1|tar -xjf - ;;
|
|
*.tar.gz) pv $1|tar -xzf - ;;
|
|
*.tar) pv $1|tar -xf - ;;
|
|
*.tbz2) pv $1|tar -xjf - ;;
|
|
*.tgz) pv $1|tar -xzf - ;;
|
|
*.lzma) pv $1|tar --lzma -xf - ;;
|
|
*.xz) pv $1|tar -xJf - ;;
|
|
*.bz2) bunzip2 $1 ;;
|
|
*.rar) unrar x $1 ;;
|
|
*.gz) gunzip $1 ;;
|
|
*.zip) unzip $1 ;;
|
|
*.Z) uncompress $1 ;;
|
|
*.7z) 7z x $1 ;;
|
|
*.lrz) lrzuntar $1 ;;
|
|
*) vim $1
|
|
esac
|
|
else
|
|
#Edit with vim
|
|
echo -n "vim? "
|
|
read a
|
|
vim "$@"
|
|
fi
|
|
}
|
|
(( $+TMUX )) && unset zle_bracketed_paste
|
|
|
|
[ -f ~/.fzf.zsh ] && source ~/.fzf.zsh
|
|
if command -v fasd 2>&1 >/dev/null; then
|
|
eval "$(fasd --init auto)"
|
|
fi
|
|
|
|
#Old config options that are no longer in use
|
|
#alias pg="pcregrep -M"
|
|
#if command -v greadlink 2>&1 >/dev/null; then
|
|
# alias readlink='greadlink'
|
|
#fi
|
|
#alias steamo='sudo kill -9 `pidof steam`;sudo unshare -n -- sh -c "ifconfig lo up;sudo -u $USER steam" > /dev/null 2>&1 & disown'
|
|
#alias bat='upower -i /org/freedesktop/UPower/devices/battery_BAT0| grep -E "state|to\ full|percentage"'
|
|
#alias aoeu='setxkbmap -layout us -option "'
|
|
#alias asdf='setxkbmap -layout dvorak -option ""'
|
|
#alias sudo='sudo -H'
|
|
echo -ne '[# ]\r'
|
|
source ~/.zsh-git/lpr/liquidprompt
|
|
source ~/.zsh-git/omg/base.sh
|
|
source ~/.zsh-git/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh
|
|
source ~/.zsh-git/oh-my-git-themes/af-magic.zsh-theme
|
|
echo -e '[##]'
|
|
#zprof
|