-a() {
- beet "${@}"
-}
-
-ack() { ack-grep "$@"; }
-
-bashrcpush () {
- local startdir="$PWD"
- cd ~
- for x in "$@"; do
- ssh $x mkdir -p bin/distro-functions/src
- tar cz bin/semi-private bin/distro-functions/src | ssh $x tar xz
- done
- cd $(mktemp -d)
- command cp /a/c/repos/bash/!(.git) ~/.gitconfig .
- for x in "$@"; do
- tar cz * | ssh $x tar xz
- done
- cd "$startdir"
-}
-
-caa() { git commit --amend --no-edit -a; }
-
-calc() { echo "scale=3; $*" | bc -l; }
-# no having to type quotes, but also no command history:
-clc() {
- local x
- read -r x
- echo "scale=3; $x" | bc -l
-}
-
-cam() {
- git commit -am "$*"
-}
-
-ccat () { # config cat. see a config without extra lines.
- grep '^\s*[^[:space:]#]' "$@"
-}
-
-cdiff() {
- # diff config files,
- # setup for format of postfix, eg:
- # option = stuff[,]
- # [more stuff]
- local pastline
- local unified="$(mktemp)"
- local f1="$(mktemp)"
- local f2="$(mktemp)"
- _cdiff-prep "$1" "$f1"
- _cdiff-prep "$2" "$f2"
- cat "$f1" "$f2" | grep -Po '^[^=]+=' | sort | uniq > "$unified"
- while IFS= read -r line; do
- # the default bright red / blue doesn't work in emacs shell
- dwdiff -cblue,red -A best -d " ," <(grep "^$line" "$f1" || echo ) <(grep "^$line" "$f2" || echo ) | colordiff
- done < "$unified"
-}
-
-cgpl()
-{
- if (($#)); then
- cp /a/bin/data/COPYING "$@"
- else
- cp /a/bin/data/COPYING .
- fi
-}
-capache()
-{
- if (($#)); then
- cp /a/bin/data/LICENSE "$@"
- else
- cp /a/bin/data/LICENSE .
- fi
-}
-chown() {
- # makes it so chown -R symlink affects the symlink and its target.
- if [[ $1 == -R ]]; then
- shift
- command chown -h "$@"
- command chown -R "$@"
- else
- command chown "$@"
- fi
-}
-
-cim() {
- git commit -m "$*"
-}
-
-d() { builtin bg; }
-complete -A stopped -P '"%' -S '"' d
-
-dat() { # do all tee, for more complex scripts
- tee >(ssh frodo bash -l) >(bash -l) >(ssh x2 bash -l) >(ssh tp bash -l)
-}
-da() { # do all
- local host
- "$@"
- for host in x2 tp treetowl; do
- ssh $host "$@"
- done
-}
-
-dc() {
- diff --strip-trailing-cr -w "$@" # diff content
-}
-
-debian_pick_mirror () {
- # netselect-apt finds a fast mirror.
- # but we need to replace the mirrors ourselves,
- # because it doesn't do that. best it can do is
- # output a basic sources file
- # here we get the server it found, get the main server we use
- # then substitute all instances of one for the other in the sources file
- # and backup original to /etc/apt/sources.list-original.
- # this is idempotent. the only way to identify debian sources is to
- # note the original server, so we put it in a comment so we can
- # identify it later.
- local file=$(mktemp -d)/f # safe way to get file name without creating one
- sudo netselect-apt -o "$file" || return 1
- url=$(grep ^\\w $file | head -n1 | awk '{print $2}')
- sudo cp -f /etc/apt/sources.list /etc/apt/sources.list-original
- sudo sed -ri "/http.us.debian.org/ s@( *[^ #]+ +)[^ ]+([^#]+).*@\1$url\2# http.us.debian.org@" /etc/apt/sources.list
- sudo apt-get update
-}
-
-despace() {
- local x y
- for x in "$@"; do
- y="${x// /_}"
- safe_rename "$x" "$y"
- done
-}
-
-dt() {
- date "+%A, %B %d, %r" "$@"
-}
-
-dus() {
- du -sh ${@:-*} | sort -h
-}
-
-
-
-e() { echo "$@"; }
-
-
-ediff() {
- [[ ${#@} == 2 ]] || { echo "error: ediff requires 2 arguments"; return 1; }
- emacs --eval "(ediff-files \"$1\" \"$2\")"
-}
-
-
-envload() { # load environment from a previous: export > file
- local file=${1:-$HOME/.${USER}_env}
- eval "$(export | sed 's/^declare -x/export -n/')"
- while IFS= read -r line; do
- # declare -x makes variables local to a function
- eval ${line/#declare -x/export}
- done < "$file"
-}
-
-
-fa() {
- # find array. make an array of file names found by find into $x
- # argument: find arguments
- # return: find results in an array $x
- while read -rd ''; do
- x+=("$REPLY");
- done < <(find "$@" -print0);
-}
-
-
-ff() {
- if type -P firefox &>/dev/null; then
- firefox "$@"
- else
- iceweasel "$@"
- fi
-}
-
-
-
-fn() {
- firefox -P alt "$@" >/dev/null 2>&1
-}
-
-
-fsdiff () {
- local missing=false
- local dname="${PWD##*/}"
- local m="/a/tmp/$dname-missing"
- local d="/a/tmp/$dname-diff"
- [[ -e $d ]] && rm "$d"
- [[ -e $m ]] && rm "$m"
- local msize=0
- local fsfile
- while read -r line; do
- fsfile="$1${line#.}"
- if [[ -e "$fsfile" ]]; then
- md5diff "$line" "$fsfile" && tee -a "/a/tmp/$dname-diff" <<< "$fsfile $line"
- else
- missing=true
- echo "$line" >> "$m"
- msize=$((msize + 1))
- fi
- done < <(find -type f )
- if $missing; then
- echo "$m"
- (( msize <= 100 )) && cat $m
- fi
-}
-fsdiff-test() {
- # expected output, with different tmp dirs
- # /tmp/tmp.HDPbwMqdC9/c/d ./c/d
- # /a/tmp/tmp.qLDkYxBYPM-missing
- # ./b
- cd $(mktemp -d)
- echo ok > a
- echo nok > b
- mkdir c
- echo ok > c/d
- local x=$(mktemp -d)
- mkdir $x/c
- echo different > $x/c/d
- echo ok > $x/a
- fsdiff $x
-}
-rename-test() {
- # test whether missing files were renamed, generally for use with fsdiff
- # $1 = fsdiff output file, $2 = directory to compare to. pwd = fsdiff dir
- # echos non-renamed files
- local x y found
- unset sums
- for x in "$2"/*; do
- { sums+=( "$(md5sum < "$x")" ) ; } 2>/dev/null
- done
- while read -r line; do
- { missing_sum=$(md5sum < "$line") ; } 2>/dev/null
- renamed=false
- for x in "${sums[@]}"; do
- if [[ $missing_sum == "$x" ]]; then
- renamed=true
- break
- fi
- done
- $renamed || echo "$line"
- done < "$1"
- return 0
-}
-
-feh() {
- command feh -FzZ "$@"
-}
-
-funce() {
- # like -e for functions. returns on error.
- # at the end of the function, disable with:
- # trap ERR
- trap 'echo "${BASH_COMMAND:+BASH_COMMAND=\"$BASH_COMMAND\" }
-${FUNCNAME:+FUNCNAME=\"$FUNCNAME\" }${LINENO:+LINENO=\"$LINENO\" }\$?=$?"
-trap ERR
-return' ERR
-}
-
-
-fw() {
- firefox -P default "$@" >/dev/null 2>&1
-}
-
-getdir () {
- local help="Usage: getdir [--help] PATH
-Output the directory of PATH, or just PATH if it is a directory."
- if [[ $1 == --help ]]; then
- echo "$help"
- return 0
- fi
- if [[ $# -ne 1 ]]; then
- echo "getdir error: expected 1 argument, got $#"
- return 1
- fi
- if [[ -d $1 ]]; then
- echo "$1"
- else
- local dir="$(dirname "$1")"
- if [[ -d $dir ]]; then
- echo "$dir"
- else
- echo "getdir error: directory does not exist"
- return 1
- fi
- fi
-}
-
-git_empty_branch() { # start an empty git branch. carefull, it deletes untracked files.
- [[ $# == 1 ]] || { echo 'need a branch name!'; return 1;}
- local gitroot
- gitroot || return 1 # function to set gitroot
- builtin cd "$gitroot"
- git symbolic-ref HEAD refs/heads/$1
- rm .git/index
- git clean -fdx
-}
-
-gitroot() {
- local help="Usage: gitroot [--help]
-Print the full path to the root of the current git repo
-
-Handles being within a .git directory, unlike git rev-parse --show-toplevel,
-and works in older versions of git which did not have that."
- if [[ $1 == --help ]]; then
- echo "$help"
- return
- fi
- local p=$(git rev-parse --git-dir) || { echo "error: not in a git repo" ; return 1; }
- [[ $p != /* ]] && p=$PWD
- echo "${p%%/.git}"
-}
-
-gr() {
- grep -iIP --color=auto "$@"
-}
-
-grr() {
- if [[ ${#@} == 1 ]]; then
- grep -riIP --color=auto "$@" .
- else
- grep -riIP --color=auto "$@"
- fi
-}
-
-hl() { # history limit. Write extra history to archive file.
- # todo: this is not working or not used currently
- local max_lines linecount tempfile prune_lines x
- local harchive="${HISTFILE}_archive"
- for x in "$HISTFILE" "$harchive"; do
- [[ -e $x ]] || { touch "$x" && echo "notice from hl(): creating $x"; }
- if [[ ! $x || ! -e $x || ! -w $x || $(stat -c "%u" "$x") != $EUID ]]; then
- echo "error in hl: history file \$x:$x no good"
- return 1
- fi
- done
- history -a # save history
- max_lines=$HISTFILELINES
- [[ $max_lines =~ ^[0-9]+$ ]] || { echo "error in hl: failed to get max line count"; return 1; }
- linecount=$(wc -l < $HISTFILE) # pipe so it doesn't output a filename
- [[ $linecount =~ ^[0-9]+$ ]] || { echo "error in hl: wc failed"; return 1; }
- if (($linecount > $max_lines)); then
- prune_lines=$(($linecount - $max_lines))
- head -n $prune_lines "$HISTFILE" >> "$harchive" \
- && sed --follow-symlinks -ie "1,${prune_lines}d" $HISTFILE
- fi
-}
-
-hr() { # horizontal row. used to break up output
- printf "$(tput setaf 5)â–ˆ$(tput sgr0)%.0s" $(seq $COLUMNS)
- echo
-}
-
-
-i() { git "$@"; }
-# modified from ~/local/bin/git-completion.bash
-# other completion commands are mostly taken from bash_completion package
-complete -o bashdefault -o default -o nospace -F _git i 2>/dev/null \
- || complete -o default -o nospace -F _git i
-
-if ! type service &>/dev/null; then
- service() {
- echo actually running: systemctl $2 $1
- systemctl $2 $1
- }
-fi
-
-ic() {
- # fast commit all
- git commit -am "$*"
-}
-
-
-ifn () {
- # insensitive find
- find -L . -iname "*$**" 2>/dev/null
-}
-
-
-if [[ $OS == Windows_NT ]]; then
- # cygstart wrapper
- cs() {
- cygstart "$@" &
- }
- xp() {
- explorer.exe .
- }
- # launch
- o() {
- local x=(*$1*)
- (( ${#x[#]} > 1 )) && { echo "warning ${#x[#]} matches found"; sleep 1; }
- cygstart *$1* &
- }