3 7b4d8efb 2022-02-04 op OpenBSD ksh (sometimes called opdksh or oksh) is the default shell on
4 7b4d8efb 2022-02-04 op OpenBSD, and is generally my go-to choince on other systems too. It has
5 7b4d8efb 2022-02-04 op a good ratio of features and simplicity
7 7b4d8efb 2022-02-04 op if [ "$TERM" = dumb ]; then
12 7b4d8efb 2022-02-04 op Enable emacs-like command editing regardless of $EDITOR and csh-like
13 7b4d8efb 2022-02-04 op history expansion with !
16 7b4d8efb 2022-02-04 op set -o csh-history
18 7b4d8efb 2022-02-04 op Talking about history, by default ksh won't store any, which is
19 7b4d8efb 2022-02-04 op unfortunate. I can't live without my C-r working!
21 7b4d8efb 2022-02-04 op HISTCONTROL=ignoredups:ignorespace
22 7b4d8efb 2022-02-04 op HISTFILE=$HOME/.history
23 7b4d8efb 2022-02-04 op HISTSIZE=10000
25 7b4d8efb 2022-02-04 op OpenBSD ksh has a limited support for programmed completions through
26 7b4d8efb 2022-02-04 op static lists. The completions are provided via an array called
27 7b4d8efb 2022-02-04 op complete_$progname; or complete_$progname_$nth for the nth argument.
29 7b4d8efb 2022-02-04 op Here's the completions for ssh and scp:
31 7b4d8efb 2022-02-04 op HOST_LIST=$(awk '/Host / {print $2}' ~/.ssh/config | xargs echo)
33 7b4d8efb 2022-02-04 op set -A complete_ssh -- $HOST_LIST
34 7b4d8efb 2022-02-04 op set -A complete_scp -- $HOST_LIST
36 7b4d8efb 2022-02-04 op and for kill(1) and pkill(1)
38 7b4d8efb 2022-02-04 op set -A complete_kill_1 -- -9 -HUP -INFO -KILL -TERM
39 7b4d8efb 2022-02-04 op set -A complete_pkill_2 -- -SIGHUP -SIGUSR1 -SIGUSR2 -SIGTERM -SIGKILL
41 7b4d8efb 2022-02-04 op and for vmd(8) if available
43 7b4d8efb 2022-02-04 op if pgrep -fq /usr/sbin/vmd; then
44 7b4d8efb 2022-02-04 op set -A complete_vmctl_1 -- console load reload start stop \
45 7b4d8efb 2022-02-04 op reset status send receive
46 7b4d8efb 2022-02-04 op set -A complete_vmctl -- \
47 7b4d8efb 2022-02-04 op $(vmctl status | awk '!/NAME/{printf "%s ", $NF}')
50 7b4d8efb 2022-02-04 op and for ifconfig(8)
52 7b4d8efb 2022-02-04 op set -A complete_ifconfig_1 -- $(ifconfig | grep ^[a-z] | cut -d: -f1)
54 7b4d8efb 2022-02-04 op and for got(1)
56 b142858f 2022-07-29 op command -v got >/dev/null && \
57 b142858f 2022-07-29 op set -A complete_got_1 -- $(got -h 2>&1 | sed -n s/commands://p)
59 7b4d8efb 2022-02-04 op Tweak the output of ls
61 7b4d8efb 2022-02-04 op alias ls='ls -F'
63 29db7106 2022-09-15 op Provide an easiest access to amused
65 29db7106 2022-09-15 op alias a=amused
67 7b4d8efb 2022-02-04 op reset(1) doesn't work as expected inside tmux: the old output can still
68 7b4d8efb 2022-02-04 op be consulted when scrolling. If I, lazy as I am, bother to type "reset"
69 7b4d8efb 2022-02-04 op I want to be sure that the history was cleared!
71 7b4d8efb 2022-02-04 op if [ -n "$TMUX" ]; then
72 7b4d8efb 2022-02-04 op alias reset='reset && tmux clear-history'
75 7b4d8efb 2022-02-04 op CDPATH is super useful! I even wrote a post about it:
76 7b4d8efb 2022-02-04 op https://www.omarpolo.com/post/enjoying-cdpath.html
78 7b4d8efb 2022-02-04 op export CDPATH=".:$HOME/w:/usr/ports:/usr/ports/mystuff:$HOME/quicklisp/local-projects"
80 7b4d8efb 2022-02-04 op I love to hate gpg! It needs some special treatments to work and this
81 7b4d8efb 2022-02-04 op should also (finger crossed!) fix pinentry over ssh. I'm not sure it
82 7b4d8efb 2022-02-04 op works though, it's been a while since I've connected remotely to my
85 7b4d8efb 2022-02-04 op export GPG_TTY=$(tty)
86 7b4d8efb 2022-02-04 op if [ -n "$SSH_CONNECTION" ]; then
87 7b4d8efb 2022-02-04 op export PINENTRY_USER_DATA="USE_CURSES=1"
90 7b4d8efb 2022-02-04 op The BSDs have this incredibly useful signal available, it's a shame not
93 7b4d8efb 2022-02-04 op stty status ^T
95 7b4d8efb 2022-02-04 op I really like my prompt to be as minimal as possible. For some time
96 7b4d8efb 2022-02-04 op I've used a single colon `;' as prompt, it's really nice! At the moment
97 7b4d8efb 2022-02-04 op thought I'm usign a more plan9-esque percent sign:
101 7b4d8efb 2022-02-04 op I got tired of trying to remember the set of flags for nc to walk to
102 7b4d8efb 2022-02-04 op Gemini servers, so here we are:
104 7b4d8efb 2022-02-04 op # "post" stdin to the gemini server
105 7b4d8efb 2022-02-04 op # usage: gem host [port]
108 7b4d8efb 2022-02-04 op host="${1:?missing host}"
109 7b4d8efb 2022-02-04 op port="${2:-1965}"
110 7b4d8efb 2022-02-04 op nc -c -Tnoverify "${host}" "${port}"
113 7b4d8efb 2022-02-04 op I think I've stolen these from someone. It makes a copy of the file and
114 7b4d8efb 2022-02-04 op launch an editor on the original file, incledibly useful when working
115 7b4d8efb 2022-02-04 op with ports (that's why doas!)
119 7b4d8efb 2022-02-04 op if [ -z "$1" ]; then
120 7b4d8efb 2022-02-04 op printf "%s\n" "USAGE: mgdiff file" >&2
123 7b4d8efb 2022-02-04 op doas cp -p "$1" "$1.orig"
127 7b4d8efb 2022-02-04 op hist is a quick wrapper around history and grep to quickly search for a
128 7b4d8efb 2022-02-04 op previous command:
132 7b4d8efb 2022-02-04 op if [ -z "$1" ]; then
133 7b4d8efb 2022-02-04 op printf "%s\n" "USAGE: hist pattern" >&2
136 7b4d8efb 2022-02-04 op history 0 | grep "$1"
139 04b39415 2022-02-04 op clbin (the site) is a web pastebin that's easy to use from the command
140 04b39415 2022-02-04 op line with curl. clbin (the function) is an easy way to share something,
141 04b39415 2022-02-04 op just pipe it to clbin and it returns an url.
145 04b39415 2022-02-04 op curl -F 'clbin=<-' https://clbin.com
148 7b4d8efb 2022-02-04 op Some aliases I use when working with the OpenBSD port tree:
150 7b4d8efb 2022-02-04 op alias m="make"
151 7b4d8efb 2022-02-04 op alias mup="make update-patches"
152 7b4d8efb 2022-02-04 op alias mupl="make update-plist"
153 0d484cb2 2022-02-17 op alias mpldc="make port-lib-depends-check"
154 76902419 2022-03-30 op alias pbuild="env MAKE_JOBS=5 time make"
155 76902419 2022-03-30 op alias build="pbuild 2>&1 | tee build"
156 8a8ff32c 2022-02-05 op alias pclean='make clean="package plist"'
158 afa6a1ba 2022-05-23 op This one is pretty sophisticated, I've stolen it from jca@
160 afa6a1ba 2022-05-23 op # check shared libs version
165 afa6a1ba 2022-05-23 op for f in $(make show=SHARED_LIBS); do
166 afa6a1ba 2022-05-23 op [ "$((cnt++ % 2))" -eq 1 ] && continue
167 afa6a1ba 2022-05-23 op echo '===>' $f
168 afa6a1ba 2022-05-23 op /usr/src/lib/check_sym /usr/local/lib/lib$f.so* \
169 afa6a1ba 2022-05-23 op $(make show=WRKINST)/usr/local/lib/lib$f.so*
173 b73f39e1 2022-03-02 op And even more aliases:
175 db6a58c2 2022-08-05 op alias mopnew="mdirs ~/Maildir/op | grep -v emacs | mlist -st | mthread -r | mseq -S; mscan"
177 b73f39e1 2022-03-02 op for c in com rep fwd bnc; do
178 e7f82226 2022-08-05 op local _mvisual='mg -f auto-fill-mode'
179 e7f82226 2022-08-05 op if [ -n "$DISPLAY" ]; then
180 e7f82226 2022-08-05 op _mvisual='emacsclient -c'
183 e7f82226 2022-08-05 op alias m$c="VISUAL='$_mvisual' m$c"
184 b73f39e1 2022-03-02 op alias o$c="m$c -from 'Omar Polo <op@openbsd.org>'"
187 76902419 2022-03-30 op And finally some aliases for mq
189 76902419 2022-03-30 op alias pnq="NQDIR=/tmp/ports/ nq "
190 76902419 2022-03-30 op alias pfq="NQDIR=/tmp/ports/ fq "
192 76902419 2022-03-30 op Stuff to use my own purritobin instance
194 76902419 2022-03-30 op : ${P_SERVER=paste.omarpolo.com}
195 76902419 2022-03-30 op : ${P_PORT=42069}
196 76902419 2022-03-30 op : ${P_TIME=week}
197 76902419 2022-03-30 op : ${P_MAXTIME=30}
199 76902419 2022-03-30 op shell client to upload a plaintext message
202 76902419 2022-03-30 op curl --silent --max-time "${P_MAXTIME}" \
203 76902419 2022-03-30 op --data-binary "@${1:-/dev/stdin}" \
204 76902419 2022-03-30 op "${P_SERVER}:${P_PORT}/${P_TIME}"
207 76902419 2022-03-30 op shell client to upload an encrypted message
210 76902419 2022-03-30 op key="$(openssl rand -hex 32)"
211 76902419 2022-03-30 op iv="$(openssl rand -hex 16)"
212 76902419 2022-03-30 op url="$(openssl enc -aes-256-cbc -K ${key} -iv ${iv} -e -base64 -A < ${1:-/dev/stdin} | purr)"
213 76902419 2022-03-30 op printf "%s\n" "${url%\/*}/paste.html#${url##*\/}_${key}_${iv}"
214 76902419 2022-03-30 op unset key iv url
217 76902419 2022-03-30 op ...and to decrypt it
221 76902419 2022-03-30 op baseurl="${url%\/*}"
222 76902419 2022-03-30 op vals="${url##*\#}"
223 76902419 2022-03-30 op paste=$(printf '%s\n' "${vals}" | cut -d_ -f1)
224 76902419 2022-03-30 op key=$(printf '%s\n' "${vals}" | cut -d _ -f2)
225 76902419 2022-03-30 op iv=$(printf '%s\n' "${vals}" | cut -d _ -f3)
226 76902419 2022-03-30 op curl --max-time "${P_MAXTIME}" --write-out "\n" --silent \
227 76902419 2022-03-30 op "${baseurl}/${paste}" | openssl enc -aes-256-cbc \
228 76902419 2022-03-30 op -base64 -d -K ${key} -iv ${iv}
229 76902419 2022-03-30 op unset url baseurl vals paste key iv
232 8695a5d9 2022-06-09 op a little awk oneliner to show the stats of a unified diff
236 8695a5d9 2022-06-09 op /^\+/ { a++; next }
237 8695a5d9 2022-06-09 op /^\-/ { m++; next }
238 8695a5d9 2022-06-09 op END { printf("additions:\t%d\nremoval:\t%d\n", a, m) }
242 7b4d8efb 2022-02-04 op find(1) is an invaluable tool and I use it all the time. walk is an
243 7b4d8efb 2022-02-04 op attempt to build a wrapper around some common usages of find that is a
244 7b4d8efb 2022-02-04 op little bit less verbose to use. The name is stolen from 9front, but the
245 7b4d8efb 2022-02-04 op implementation is completely different.
247 7b4d8efb 2022-02-04 op # usage: walk [dir] [type] [name regexp] [! command to execute]
250 7b4d8efb 2022-02-04 op if [ $# -eq 0 ]; then
257 7b4d8efb 2022-02-04 op local name=\*
259 7b4d8efb 2022-02-04 op if [ -n "$1" -a -d "$1" ]; then
265 7b4d8efb 2022-02-04 op b|c|d|f|l|p|s)
266 7b4d8efb 2022-02-04 op type="-type $1"
270 7b4d8efb 2022-02-04 op if [ -n "$1" -a "x$1" != "x!" ]; then
275 7b4d8efb 2022-02-04 op if [ "x$1" = x! ]; then
279 7b4d8efb 2022-02-04 op if [ $# -eq 0 ]; then
280 7b4d8efb 2022-02-04 op find "$dir" $type -iname "$name"
282 7b4d8efb 2022-02-04 op find "$dir" $type -iname "$name" -exec "$@" {} +