export BC_LINE_LENGTH=0
+export PROFILE_TASKS_TASK_OUTPUT_LIMIT=100
# note, if I use a machine I dont want files readable by all users, set
# umask 077 # If fewer than 4 digits are entered, leading zeros are assumed
# https://superuser.com/questions/366930/how-do-i-get-the-git-pager-to-clean-up-screen-output-after-exit
# and reading the man
export LESS=RXi
+export SYSTEMD_LESS=$LESS
# * include files
for _x in /a/bin/distro-functions/src/* /a/bin/!(githtml)/*-function?(s); do
fi
path_add /a/exe
-# end just because it seems safer
-path_add --end node_modules/.bin
+# add this with absolute paths as needed for better security
+#path_add --end /path/to/node_modules/.bin
+
# pip3 --user things go here:
path_add --end ~/.local/bin
path_add --ifexists --end /a/work/libremanage
}
a() {
- local x=$(readlink -nf "$@")
+ local x=$(readlink -nf "${1:-$PWD}")
# yes, its kinda dumb that xclip/xsel cant do this in one invocation
echo -n "$x" | xclip -selection clipboard
echo -n "$x" | xclip
fi
}
+ap() {
+ # pushd in case current directory has an ansible.cfg file
+ pushd /a/xans >/dev/null
+ ansible-playbook -v -l ${1:- $(hostname -f)} site.yml
+ popd >/dev/null
+}
+aw() {
+ pushd /a/work/ansible-configs >/dev/null
+ time ansible-playbook -v -i inventory adhoc.yml "$@"
+ popd >/dev/null
+}
+ad() {
+ pushd /a/bin/distro-setup/a >/dev/null
+ ansible-playbook site.yml
+ popd >/dev/null
+}
+
astudio() {
# googling android emulator libGL error: failed to load driver: r600
# lead to http://stackoverflow.com/a/36625175/14456
}
bbk() {
+ c /
+ local active=true
+ if systemctl is-active btrbk.service; then
+ echo "cron btrbk is already running"
+ return 1
+ fi
+ systemctl is-active btrbk.timer || active=false
+ if $active; then
+ ser disable btrbk.timer
+ fi
# run latest
install-my-scripts
- btrbk-run "$@"
+ if ! btrbk-run "$@" && $active; then
+ ser enable btrbk.timer
+ fi
}
bfg() { java -jar /a/opt/bfg-1.12.14.jar "$@"; }
xclock -digital -update 1 -face 'arial black-80:bold'
}
-bpush() {
- case $HOSTNAME in
- tp) target=x2 ;;
- x2) target=tp ;;
- esac
- btrbk-run -t $target && switch-mail-host $HOSTNAME $target
-}
bpull() {
- case $HOSTNAME in
- tp) source=x2 ;;
- x2) source=tp ;;
- esac
- btrbk-run -s $source && switch-mail-host $source $HOSTNAME
+ [[ $1 ]] || return 1
+ c /
+ # run latest
+ install-my-scripts
+ switch-mail-host $1 $HOSTNAME
}
+bpush() {
+ [[ $1 ]] || return 1
+ c /
+ # run latest
+ install-my-scripts
+ switch-mail-host $HOSTNAME $1
+}
+
btc() {
local f=/etc/bitcoin/bitcoin.conf
# mail related
etail() {
- sudo tail -f /var/log/exim4/mainlog
+ sudo tail -F /var/log/exim4/mainlog -n 50
}
f() {
}
faf() { # find all files
- find -L $1 -not \( -name .svn -prune -o -name .git -prune \
+ find -L $1 -type f -not \( -name .svn -prune -o -name .git -prune \
-o -name .hg -prune -o -name .editor-backups -prune \
-o -name .undo-tree-history -prune \) 2>/dev/null
}
}
gse() {
- git send-email --notes '--envelope-sender=<ian@iankelling.org>' \
+ local email=ian@iankelling.org
+ if readlink ~/.mu | grep fsf &>/dev/null; then
+ email=iank@fsf.org
+ fi
+ git send-email --notes "--envelope-sender=<$email>" \
--suppress-cc=self "$@"
}
s iptables -A INPUT -s $1 -j DROP
}
-net-dev-info() {
- e "lspci -nnk|gr -iA2 net"
- lspci -nnk|gr -iA2 net
- hr
- e "s lshw -C network"
- hr
- s lshw -C network
-
-}
istext() {
grep -Il "" "$@" &>/dev/null
}
+jfilter() {
+ grep -Evi -e "^(\S+\s+){4}(sudo|sshd|cron)\[\S*:" \
+ -e "^(\S+\s+){4}systemd\[\S*: (starting|started) (btrfsmaintstop|dynamicipupdate|spamd dns bug fix cronjob|rss2email)\.*$"
+}
jtail() {
- journalctl -n 10000 -f "$@" | grep -Evi "^(\S+\s+){4}(sudo|sshd|cron)"
+ journalctl -n 10000 -f "$@" | jfilter
}
+jr() { journalctl "$@" | jfilter | less ; }
+jrf() { journalctl -f "$@" | jfilter; }
kff() { # keyboardio firmware flash
pushd /a/bin/distro-setup/Arduino/Model01-Firmware
mo() { xset dpms force off; } # monitor off
+net-dev-info() {
+ e "lspci -nnk|gr -iA2 net"
+ lspci -nnk|gr -iA2 net
+ hr
+ e "s lshw -C network"
+ hr
+ s lshw -C network
+
+}
nopanic() {
sudo tee -a /var/log/exim4/paniclog-archive </var/log/exim4/paniclog; sudo truncate -s0 /var/log/exim4/paniclog
find "${pathArray[@]}" -iname "*$1*"
}
+pkx() { # package extract
+ c `mktemp -d`
+ pkg=$1
+ cached=$(ls -t /var/cache/apt/archives/$pkg* | tail -n1)
+ if [[ $cached ]]; then
+ cp $cached .
+ else
+ aptitude download $pkg
+ fi
+ f=(*)
+ ex $f
+ rm -f $f
+}
+
pk1() {
local pid
pid=($(pgrep -f "$*"))
rbpipe() { rbt post -o --diff-filename=- "$@"; }
rbp() { rbt post -o "$@"; }
+resolvcat() {
+ local f
+ f=/etc/resolv.conf
+ echo $f:; ccat $f
+ hr; echo dnsmasq is $(systemctl is-active dnsmasq)
+ f=/var/run/dnsmasq/resolv.conf
+ hr; echo $f:; ccat $f
+ f=/etc/dnsmasq-servers.conf
+ hr; echo $f:; ccat $f
+}
+
rl() {
# rsync, root is required to keep permissions right.
# rsync --archive --human-readable --verbose --itemize-changes --checksum \(-ahvic\) \
}
ser() {
- local s; [[ $EUID != 0 ]] && s=sudo
+ local s; [[ $EUID != 0 ]] && s=s
if type -p systemctl &>/dev/null; then
$s systemctl $1 $2
else
systemctl restart $service
fi
}
-serstopnm() {
+stopnm() {
ser stop NetworkManager
ser stop dnsmasq
s resolvconf -d NetworkManager
ser start dnsmasq
}
+startnm() {
+ ser start NetworkManager
+ s nmtui-connect
+}
setini() { # set a value in a .ini style file
key="$1" value="$2" section="$3" file="$4"
scriptreplay "$1.t" "$1.s"
}
-smeld() { # usage host1 host2 file
+smeld() { # ssh meld usage host1 host2 file
meld <(ssh $1 cat $3) <(ssh $2 cat $3)
}
xscreensaver-command -activate
}
+xevkb() { xev -event keyboard; }
+
# * misc stuff
# from curl cheat.sh/:bash_completion
bind -m vi-command W:shell-forward-word
fi
- if [[ $SSH_CLIENT ]]; then
+ if [[ $SSH_CLIENT || $SUDO_USER ]]; then
PS1="\h $PS1"
fi
-
-
-
prompt-command() {
local return=$? # this MUST COME FIRST
local psc pst ps_char ps_color stale_subvol
if [[ -e /nocow/btrfs-stale ]] && ((`command ls -AUq /nocow/btrfs-stale|wc -l`)); then
ps_char="! $ps_char"
fi
+ if [[ ! $SSH_CLIENT && $MAIL_HOST != $HOSTNAME ]]; then
+ ps_char="@ $ps_char"
+ fi
PS1="${PS1%"${PS1#*[wW]}"} \[$ps_color\]$ps_char\[$(get_term_color nocolor)\] "
# emacs completion doesnt like the git prompt atm, so disabling it.
#PS1="${PS1%"${PS1#*[wW]}"}$(__git_ps1 ' (%s)') \[$ps_color\]$ps_char\[$(get_term_color nocolor)\] "
# xscreensaver-command -demo
# then finding the corresponding option in .xscreensaver
# spash, i happened to notice in .xscreensaver
+ #
+ # dpmsOff, monitor doesnt come back on using old free software supported nvidia card
cat > /home/iank/.xscreensaver <<'EOF'
mode: blank
dpmsEnabled: True
dpmsStandby: 0:02:00
-dpmsSuspend: 0:02:00
-dpmsOff: 0:03:00
+dpmsSuspend: 0:03:00
+dpmsOff: 0:00:00
timeout: 0:02:00
lock: True
lockTimeout: 0:03:00
path_add $GOPATH/bin
path_add /usr/local/go/bin
-export ARDUINO_PATH=/a/opt/Arduino/build/linux/work
+# I have the git repo and a release. either one should work.
+# I have both because I was trying to solve an issue that
+# turned out to be unrelated.
+# ARDUINO_PATH=/a/opt/Arduino/build/linux/work
+export ARDUINO_PATH=/a/opt/arduino-1.8.9
path_add --end ~/.npm-global