2013-06-28 05:51:52 -07:00
|
|
|
## obligatory personal dotfiles repository
|
2013-06-28 05:22:14 -07:00
|
|
|
|
|
|
|
_(plus some little shell scripts)_
|
|
|
|
|
2019-06-03 09:33:02 -07:00
|
|
|
quick install for random boxes:
|
|
|
|
|
|
|
|
```
|
|
|
|
cd && curl -L https://github.com/notwa/rc/archive/master.tar.gz | tar zx && mv rc-master rc && rc/install
|
|
|
|
```
|
|
|
|
|
2021-08-01 00:35:56 -07:00
|
|
|
**NOTE:** everything below this line is overwritten and automatically [regenerated.](/regenerate)
|
2016-06-27 06:02:53 -07:00
|
|
|
|
2021-07-30 16:35:00 -07:00
|
|
|
<!-- DOCUMENT -->
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
## shell functions
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [argc](/sh/argc#L7)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
validate the number of arguments in a function.
|
2021-08-01 00:38:05 -07:00
|
|
|
```sh
|
2021-08-01 09:27:25 -07:00
|
|
|
# usage: myfunc() { argc -(eq|le|ge) [0-9] "$0" "$@" || return; }
|
2021-08-01 00:38:05 -07:00
|
|
|
|
|
|
|
myfunc() {
|
2021-08-01 02:14:30 -07:00
|
|
|
# use one of the following:
|
|
|
|
argc -eq N "$0" "$@" || return
|
|
|
|
argc -le N "$0" "$@" || return
|
|
|
|
argc -ge N "$0" "$@" || return
|
|
|
|
# where N is an integer between 0 and 9.
|
2021-08-01 00:38:05 -07:00
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [arith](/sh/arith#L9)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
perform arithmetic using the shell and display the result.
|
2021-08-01 09:27:25 -07:00
|
|
|
see also [`hex`](#hex) and [`bin`](#bin).
|
2021-08-01 09:46:52 -07:00
|
|
|
this example requires zsh:
|
2021-08-01 09:27:25 -07:00
|
|
|
|
|
|
|
```
|
|
|
|
% db=6
|
|
|
|
% noglob arith 10**(db/20.)
|
|
|
|
1.9952623149688795
|
|
|
|
```
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [aur](/sh/aur#L7)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
download, edit, make, and install packages from the
|
|
|
|
[AUR.](https://aur.archlinux.org/)
|
|
|
|
it's a little broken.
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
```
|
|
|
|
$ aur -eyoI cmdpack-uips applyppf
|
|
|
|
```
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [autosync](/sh/autosync#L8)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
combine `inotifywait` and `rsync`.
|
|
|
|
this is sometimes nicer than `ssh`-ing into a server and running `vim` remotely.
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [bak](/sh/bak#L6)
|
|
|
|
|
2021-08-01 09:46:52 -07:00
|
|
|
backup files by creating copies and appending ".bak" to their names.
|
2021-08-01 09:27:25 -07:00
|
|
|
this calls itself recursively to avoid clobbering existing backups.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ touch -d '2001-12-25 16:30:00' butts
|
|
|
|
$ bak butts
|
|
|
|
$ touch butts
|
|
|
|
$ bak butts
|
|
|
|
$ ls -l
|
|
|
|
total 0
|
|
|
|
-rw-r--r-- 1 notwa None 0 Aug 1 08:02 butts
|
|
|
|
-rw-r--r-- 1 notwa None 0 Aug 1 08:02 butts.bak
|
|
|
|
-rw-r--r-- 1 notwa None 0 Dec 25 2001 butts.bak.bak
|
|
|
|
```
|
2021-08-01 00:38:05 -07:00
|
|
|
|
|
|
|
### [baknow](/sh/baknow#L4)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
backup a single file by appending its timestamp given by [`now`.](#now)
|
|
|
|
|
|
|
|
```
|
|
|
|
$ touch -d '2001-12-25 16:30:00' butts
|
|
|
|
$ baknow butts
|
|
|
|
$ baknow butts
|
|
|
|
cp: overwrite 'butts.2001-12-26_01800000.bak'? n
|
|
|
|
$ ls -l
|
|
|
|
total 0
|
|
|
|
-rw-r--r-- 1 notwa None 0 Dec 25 2001 butts
|
|
|
|
-rw-r--r-- 1 notwa None 0 Dec 25 2001 butts.2001-12-26_01800000.bak
|
|
|
|
```
|
|
|
|
|
|
|
|
**TODO:** support multiple files at once.
|
2021-08-01 00:38:05 -07:00
|
|
|
|
|
|
|
### [baks](/sh/baks#L11)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
backup files by copying each and appending *the current* date-time,
|
|
|
|
irrespective of when the files were modified or created.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ touch -d '2001-12-25 16:30:00' butts
|
|
|
|
$ baks butts
|
|
|
|
$ baks butts
|
|
|
|
$ ls -l
|
|
|
|
total 0
|
|
|
|
-rw-r--r-- 1 notwa None 0 Dec 25 2001 butts
|
|
|
|
-rw-r--r-- 1 notwa None 0 Dec 25 2001 butts.21-08-01_14-54-07.bak
|
|
|
|
-rw-r--r-- 1 notwa None 0 Dec 25 2001 butts.21-08-01_14-54-09.bak
|
|
|
|
```
|
|
|
|
|
|
|
|
### [bin](/sh/bin#L9)
|
2021-08-01 00:38:05 -07:00
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
perform arithmetic using the shell and display the result as
|
|
|
|
an unsigned 8-bit integer in binary.
|
|
|
|
see also [`arith`](#arith) and [`hex`](#hex).
|
2021-08-01 00:38:05 -07:00
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
```
|
|
|
|
$ bin 123
|
|
|
|
01111011
|
|
|
|
```
|
2021-08-01 00:38:05 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [cdbusiest](/sh/cdbusiest#L4)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
cd to the directory with the most files in it, counted recursively.
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
```
|
|
|
|
$ cd
|
|
|
|
$ cdbusiest
|
|
|
|
152364 src
|
|
|
|
$ pwd
|
|
|
|
/home/notwa/src
|
|
|
|
```
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [colors](/sh/colors#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
display all combinations of foreground and background terminal colors.
|
|
|
|
this only includes the basic 16-color palette.
|
2021-07-30 17:59:30 -07:00
|
|
|
excluding boilerplate, this script is a mere a 76-characters long!
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
![terminal colors](https://eaguru.guru/t/terminal-colors.png)
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [compandy](/sh/compandy#L5)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
generate compand arguments for ffmpeg audio filters.
|
|
|
|
this is kinda pointless now that acompressor is wildly supported.
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
### [setup_clang_ubuntu (sh/compile)](/sh/compile#L6)
|
|
|
|
|
|
|
|
print (but don't execute) the commands necessary to install
|
|
|
|
a fairly recent version of clang on ubuntu-based distros.
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
```sh
|
|
|
|
$ setup_clang_ubuntu bionic
|
|
|
|
wget -O - http://apt.llvm.org/llvm-snapshot.gpg.key | apt-key add -
|
|
|
|
echo -n "deb http://apt.llvm.org/bionic/ llvm-toolchain-bionic main
|
|
|
|
# deb-src http://apt.llvm.org/bionic/ llvm-toolchain-bionic main
|
|
|
|
# 12
|
|
|
|
deb http://apt.llvm.org/bionic/ llvm-toolchain-bionic-12 main
|
|
|
|
# deb-src http://apt.llvm.org/bionic/ llvm-toolchain-bionic-12 main
|
|
|
|
" > /etc/apt/sources.list.d/llvm-toolchain-bionic.list
|
|
|
|
apt-get update
|
|
|
|
apt-get install clang-12
|
|
|
|
apt-get install lld-12
|
|
|
|
update-alternatives --install /usr/bin/clang clang /usr/bin/clang-12 1200
|
|
|
|
update-alternatives --install /usr/bin/clang++ clang++ /usr/bin/clang++-12 1200
|
|
|
|
update-alternatives --install /usr/bin/llvm-symbolizer llvm-symbolizer /usr/bin/llvm-symbolizer-12 1200
|
|
|
|
```
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
### [compile](/sh/compile#L49)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
compile single-file C and C++ programs, messily.
|
|
|
|
|
|
|
|
supports gcc and clang on \*nix, and mingw64 gcc, msvc clang,
|
|
|
|
and regular msvc on Windows. tested on x86\_64 and on ARMv7 as well.
|
|
|
|
does not support MacOS, maybe someday…
|
|
|
|
|
|
|
|
defaults to gnu11 and gnu++1z as C and C++ standards respectively.
|
|
|
|
defaults to clang, gcc, and msvc in that order.
|
|
|
|
|
|
|
|
`compile` attempts to guess the most sane switches for any program, so that compilation may reduce to:
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
```sh
|
|
|
|
# debug build
|
|
|
|
compile rd.c
|
|
|
|
compile debug rd.c
|
|
|
|
# debug build with warning/error flags defined in .-shrc
|
|
|
|
# (requires .zshrc for global alias expansion)
|
|
|
|
compile WHOA rd.c
|
|
|
|
# likewise for C++
|
|
|
|
compile WHOA WELP rd.cc
|
|
|
|
compile WHOA WELP rd.cpp
|
|
|
|
# "derelease" build (release build with debug information)
|
|
|
|
compile derelease WHOA rd.c
|
|
|
|
# release build (with symbols stripped)
|
|
|
|
compile release WHOA rd.c
|
|
|
|
# hardened build (only useful on *nix)
|
|
|
|
compile hardened WHOA rd.c
|
|
|
|
# specifying compiler
|
|
|
|
compile gcc WHOA rd.c
|
|
|
|
compile msvc WHOA rd.c
|
|
|
|
compile release clang WHOA rd.c
|
|
|
|
# compile and execute (FIXME: writing to /tmp is a security concern)
|
|
|
|
compile derelease rd.c && /tmp/rd
|
|
|
|
```
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [confirm](/sh/confirm#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
display a simple yes-or-no prompt and return 0-or-1 respectively.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ confirm && echo yay || echo nay
|
|
|
|
Continue? [y/N] y
|
|
|
|
yay
|
|
|
|
$ confirm && echo yay || echo nay
|
|
|
|
Continue? [y/N] n
|
|
|
|
nay
|
|
|
|
```
|
|
|
|
|
2021-08-01 09:46:52 -07:00
|
|
|
a real world example:
|
|
|
|
|
|
|
|
```
|
|
|
|
% g1 && confirm && git commit -a --amend --no-edit
|
|
|
|
daf84e3 document a ton of stuff
|
|
|
|
Continue? [y/N] y
|
|
|
|
[master 92bdf76] document a ton of stuff
|
|
|
|
Date: Sun Aug 1 09:27:25 2021 -0700
|
|
|
|
20 files changed, 406 insertions(+), 29 deletions(-)
|
|
|
|
```
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [countdiff](/sh/countdiff#L6)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
count the number of lines changed between two files.
|
|
|
|
|
|
|
|
**TODO:** don't use git for this. also, use patience algorithm.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ countdiff README-old.md README.md
|
|
|
|
739
|
|
|
|
```
|
2021-08-01 00:38:05 -07:00
|
|
|
|
|
|
|
### [cutv](/sh/cutv#L6)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
(WIP) create a short clip of a long video file.
|
2021-08-01 00:38:05 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [days](/sh/days#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
compute the number of days since a given date.
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
```
|
|
|
|
$ days 'January 1 1970'
|
|
|
|
18838
|
|
|
|
```
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [dbusiest](/sh/dbusiest#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
list directories ordered descending by the number of files in them,
|
|
|
|
counted recursively. see also [`cdbusiest`.](#cdbusiest)
|
|
|
|
|
|
|
|
```
|
|
|
|
$ cd
|
|
|
|
$ dbusiest | head -n3
|
|
|
|
152364 src
|
|
|
|
46518 work
|
|
|
|
20903 play
|
|
|
|
```
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [dfu](/sh/dfu#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
pretty-print `df` in GiB.
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
```
|
|
|
|
$ dfu
|
|
|
|
Filesystem Used Max Left Misc
|
|
|
|
/dev 0.00 0.46 0.46 0.00
|
|
|
|
/ 17.20 23.22 6.01 1.27
|
|
|
|
```
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [disf](/sh/disf#L9)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
disassemble a single function from an unstripped executable, unreliably.
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [document](/sh/document#L135)
|
|
|
|
|
|
|
|
generate a markdown file out of docstrings in shell scripts.
|
|
|
|
|
|
|
|
**TODO:** describe. i have a rough outline written in my scrap file.
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [e](/sh/e#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
wrap around `$EDITOR` to run it as root if necessary.
|
|
|
|
this still needs some work to detect root-owned directories.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ e /etc/sudoers
|
|
|
|
[sudo] password for notwa:
|
|
|
|
```
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [ea](/sh/ea#L7)
|
2021-08-01 00:38:05 -07:00
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
**TODO:** document.
|
2021-08-01 00:38:05 -07:00
|
|
|
|
|
|
|
### [echo2](/sh/echo2#L6)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
print arguments joined by spaces to stderr without parsing anything.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ echo -e 'this\nthat' those
|
|
|
|
this
|
|
|
|
that those
|
|
|
|
$ echo2 -e 'this\nthat' those
|
|
|
|
-e this\nthat those
|
|
|
|
```
|
2021-08-01 00:38:05 -07:00
|
|
|
|
|
|
|
### [explore](/sh/explore#L6)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
open a single directory in `explorer.exe`, defaulting to `$PWD`.
|
2021-08-01 00:38:05 -07:00
|
|
|
|
|
|
|
### [ff](/sh/ff#L6)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
select a file from a given or current directory using `fzy`.
|
2021-08-01 00:38:05 -07:00
|
|
|
|
|
|
|
### [ghmd](/sh/ghmd#L9)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
convert a markdown file to HTML in the style of GitHub.
|
|
|
|
note that this uses GitHub's API, so it requires internet connectivity.
|
|
|
|
|
|
|
|
this script utilizes the CSS provided at
|
|
|
|
[sindresorhus/github-markdown-css.](https://github.com/sindresorhus/github-markdown-css)
|
2021-08-01 00:38:05 -07:00
|
|
|
|
2021-08-01 09:46:52 -07:00
|
|
|
```
|
|
|
|
~/sh/ghmd < ~/rc/README.md > ~/rc/README.html
|
|
|
|
```
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [has](/sh/has#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
print the result of `which` if the program is found, else simply return 1.
|
|
|
|
|
2021-08-01 09:46:52 -07:00
|
|
|
```
|
|
|
|
export CC="$(has clang || has clang-3.8 || has gcc)"
|
|
|
|
```
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [hex](/sh/hex#L9)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
perform arithmetic using the shell and display the result as
|
|
|
|
an unsigned 32-bit integer in hexadecimal.
|
|
|
|
see also [`arith`](#arith) and [`bin`](#bin).
|
|
|
|
|
|
|
|
```
|
|
|
|
$ hex 0x221EA8-0x212020
|
|
|
|
0000FE88
|
|
|
|
```
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [ify](/sh/ify#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
pipe one command through another, so you can still pass arguments to the former.
|
|
|
|
|
|
|
|
this is mainly useful for aliases. 99% of the time you'll use this with `less`.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ alias ll="ify less ls -ACX --group-directories-first --color=force"
|
|
|
|
$ ll /etc
|
|
|
|
```
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [is_empty](/sh/is_empty#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
return 0 if the directory given by argument is empty.
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [isup](/sh/isup#L8)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
return 0 if a given website returns a 2xx HTTP code.
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [maybesudo_ (sh/maybesudo)](/sh/maybesudo#L6)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
mimic certain features of `sudo` for systems without it installed.
|
|
|
|
as it stands, this mostly just handles some environment variables.
|
2021-08-01 00:38:05 -07:00
|
|
|
|
2021-08-01 09:46:52 -07:00
|
|
|
try this: `maybesudo_ -u "$USER" printenv`
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [minutemaid](/sh/minutemaid#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-08-01 09:46:52 -07:00
|
|
|
return 0 and/or execute a command if the current minute
|
|
|
|
is divisible by a given number. note that a minute is
|
|
|
|
relative to the seconds since the epoch, not the minute of the hour.
|
|
|
|
this ensures that commands will run roughly every N minutes,
|
|
|
|
regardless of the minute hand on the clock.
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
```
|
|
|
|
# crontab usage:
|
|
|
|
* * * * * minutemaid 9 ~/work/do_my_bidding # runs every nine minutes
|
|
|
|
```
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [monitor](/sh/monitor#L4)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
this is [watch(1)](https://www.man7.org/linux/man-pages/man1/watch.1.html)
|
|
|
|
loosely reimplemented as a shell script.
|
|
|
|
|
2021-08-01 09:46:52 -07:00
|
|
|
```
|
|
|
|
usage: monitor [-fs] [-n {period}] {command} [{args...}]
|
|
|
|
```
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [noccom](/sh/noccom#L10)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
strip C-like comments; both multi-line and single-line.
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [note](/sh/note#L6)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
act like [`echo2`,](#echo2) but use a bright color to stand out more.
|
2021-08-01 00:38:05 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [now](/sh/now#L8)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
print a date-time (UTC) in a sortable format.
|
|
|
|
this takes a date or file as an argument,
|
|
|
|
else it defaults to the current time.
|
|
|
|
```
|
|
|
|
$ now
|
|
|
|
2019-05-27_35083906
|
|
|
|
$ now ~/sh/monitor
|
|
|
|
2017-03-14_82387259
|
|
|
|
$ now '@1234567890'
|
|
|
|
2009-02-13_84690000
|
|
|
|
```
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [pacbm](/sh/pacbm#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
display and order installed pacman packages by their filesize ascending,
|
|
|
|
and their sum. requires `expac`.
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
```
|
|
|
|
$ pacbm | head -n -1 | tail -2
|
2021-08-01 02:14:30 -07:00
|
|
|
204.78M clang
|
|
|
|
235.44M linux-firmware
|
2021-07-30 17:59:30 -07:00
|
|
|
```
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [pause](/sh/pause#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
pause — the companion script of [`confirm`.](#confirm)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
```
|
|
|
|
$ pause
|
|
|
|
Press any key to continue
|
|
|
|
$
|
|
|
|
```
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [pegg](/sh/pegg#L8)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
download and (pip) install a Python "egg" from a project on GitHub,
|
|
|
|
defaulting to the master branch. this uses [`pippy`](#pippy) internally.
|
|
|
|
|
|
|
|
```sh
|
|
|
|
# install the development version of https://github.com/rthalley/dnspython
|
|
|
|
$ pegg rthalley dnspython
|
|
|
|
# or instead install the latest stable version (as of writing)
|
|
|
|
$ pegg rthalley dnspython 3933b49
|
|
|
|
```
|
2021-08-01 00:38:05 -07:00
|
|
|
|
|
|
|
### [pippy](/sh/pippy#L7)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
install Python packages using pip,
|
|
|
|
but only update their dependencies as required.
|
|
|
|
this uses [`maybesudo`](#maybesudo_-shmaybesudo) internally.
|
2021-08-01 00:38:05 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [pre](/sh/pre#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
dump all the `#define`s that `$CC $CPPFLAGS $CFLAGS $LDFLAGS` would result in.
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
```
|
|
|
|
$ pre | shuf | head -n10
|
|
|
|
#define __GNUC_MINOR__ 3
|
|
|
|
#define __SIZEOF_LONG__ 4
|
|
|
|
#define __UINT_LEAST16_TYPE__ short unsigned int
|
|
|
|
#define __ORDER_BIG_ENDIAN__ 4321
|
|
|
|
#define __SIZEOF_FLOAT__ 4
|
|
|
|
#define __INTMAX_MAX__ 0x7fffffffffffffffLL
|
|
|
|
#define __INT64_C(c) c ## LL
|
|
|
|
#define __UINT16_MAX__ 0xffff
|
|
|
|
#define __DEC64_MANT_DIG__ 16
|
|
|
|
#define __DBL_HAS_INFINITY__ 1
|
|
|
|
```
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [psbm](/sh/psbm#L6)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
display and order processes by their memory usage ascending, and their sum.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ psbm | head -n -1 | tail -2
|
|
|
|
185.08M 1163 chromium
|
|
|
|
199.95M 1060 chromium
|
|
|
|
```
|
2021-08-01 00:38:05 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [randir](/sh/randir#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
display a random directory in the current working directory.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ randir
|
|
|
|
./sh
|
|
|
|
```
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [refresh](/sh/refresh#L6)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
invoke `hash -r`.
|
2021-08-01 00:38:05 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [rs](/sh/rs#L4)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
record screen. does not record audio.
|
|
|
|
currently only works on Windows (gdigrab).
|
|
|
|
i'm sure there's something equivalent for Linux.
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [sc](/sh/sc#L40)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
upload given files to a webserver and return a direct link for sharing them.
|
|
|
|
you'll want to tweak this if you use it yourself.
|
|
|
|
this contains some extra logic for screenshots created by `scropt`.
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [scramble](/sh/scramble#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
scrambles text in a predictable way using regex.
|
|
|
|
|
|
|
|
sacbremls ttex in a pdrceailtbe way unsig reegx.
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [screeny](/sh/screeny#L4)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
i don't use this anymore~
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [scropt](/sh/scropt#L8)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
run `scrot` through `optipng` and save the result to `~/play/$(now).png`.
|
|
|
|
|
|
|
|
`$ ~/sh/sc $(~/sh/scropt -s -d0.5)`
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [similar](/sh/similar#L6)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
highlight adjacent lines up to the first inequivalent character.
|
2021-08-01 00:38:05 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [slit](/sh/slit#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
view specific columns of text.
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [slitt](/sh/slitt#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
view specific columns of text.
|
|
|
|
this version of `slit` uses tabs for its field separators.
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [sram](/sh/sram#L4)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
convert between a couple saveram formats for N64 emulators.
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [stfu](/sh/stfu#L7)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
invoke a command, silencing stdout and stderr *unless* the command fails.
|
|
|
|
|
|
|
|
**NOTE:** don't use `stfu` for handling sensitive data or commands!
|
|
|
|
use it for 7zip.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ touch butts
|
|
|
|
$ stfu 7z a butts.7z butts
|
|
|
|
$ stfu 7z a butts.7z asses
|
|
|
|
command failed with exit status 1:
|
|
|
|
7z a butts.7z asses
|
|
|
|
|
|
|
|
$ tail -n 20 /tmp/stfu/out_1627834220
|
|
|
|
Solid = -
|
|
|
|
Blocks = 0
|
|
|
|
|
|
|
|
Scanning the drive:
|
|
|
|
0 files, 0 bytes
|
|
|
|
|
|
|
|
Updating archive: butts.7z
|
|
|
|
|
|
|
|
Keep old data in archive: 1 file, 0 bytes
|
|
|
|
Add new data to archive: 0 files, 0 bytes
|
|
|
|
|
|
|
|
|
|
|
|
Files read from disk: 0
|
|
|
|
Archive size: 82 bytes (1 KiB)
|
|
|
|
|
|
|
|
Scan WARNINGS for files and folders:
|
|
|
|
|
|
|
|
asses : The system cannot find the file specified.
|
|
|
|
----------------
|
|
|
|
Scan WARNINGS: 1
|
|
|
|
|
|
|
|
$ tail -n 20 /tmp/stfu/err_1627834220
|
|
|
|
|
|
|
|
WARNING: The system cannot find the file specified.
|
|
|
|
asses
|
|
|
|
```
|
2021-08-01 00:38:05 -07:00
|
|
|
|
|
|
|
### [mpvs (sh/streamcrap)](/sh/streamcrap#L6)
|
|
|
|
|
|
|
|
invoke mpv with some extra flags suited for streamed sources.
|
|
|
|
|
|
|
|
### [mpv_watch (sh/streamcrap)](/sh/streamcrap#L66)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
watch something in mpv with a bunch of extra audio filtering crap.
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [mpv_stream (sh/streamcrap)](/sh/streamcrap#L78)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
watch a stream in mpv with a bunch of extra audio filtering crap.
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [twitch (sh/streamcrap)](/sh/streamcrap#L87)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
watch a twitch stream in mpv with a bunch of extra audio filtering crap.
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [yt (sh/streamcrap)](/sh/streamcrap#L94)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
watch a youtube video in mpv with a bunch of extra audio filtering crap.
|
|
|
|
this can be given a full URL or just a video ID.
|
|
|
|
remaining arguments are passed to mpv.
|
|
|
|
|
|
|
|
there exist several variants for more specific use cases.
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [ytg (sh/streamcrap)](/sh/streamcrap#L106)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
watch a youtube video. like `yt`, but with a preference for different formats.
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [ytll (sh/streamcrap)](/sh/streamcrap#L113)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
watch a stream on youtube in mpv, etcetera etcetera.
|
|
|
|
this is the low latency version that does not support seeking.
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [ytgll (sh/streamcrap)](/sh/streamcrap#L120)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
watch a stream on youtube in mpv. like `ytll`, but with a preference for different formats.
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [sum](/sh/sum#L6)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
compute the summation of its arguments without forking processes.
|
|
|
|
this relies on the shell's built-in arithmetic operators.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ sum 1 2 3
|
|
|
|
6
|
|
|
|
```
|
|
|
|
|
|
|
|
**TODO:** consider renaming because sum(1) already exists.
|
2021-08-01 00:38:05 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [sv](/sh/sv#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
collect the lastmost value of every key.
|
2021-08-01 09:27:25 -07:00
|
|
|
the field separator can be given as its sole argument,
|
|
|
|
it defaults to a single space otherwise.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ echo "alpha=first\nbeta=second\nalpha=third" | sv =
|
|
|
|
alpha=third
|
|
|
|
beta=second
|
|
|
|
```
|
|
|
|
|
|
|
|
this next example uses `sv` to only print the lastmost line
|
|
|
|
matching a pattern in each file. in other words, it uses
|
|
|
|
the filename printed by grep as the key in its key-value pairs.
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
```
|
2021-08-01 09:27:25 -07:00
|
|
|
$ cd ~/play/hash && grep -r 'ing$' . | sv :
|
|
|
|
./dic_win32.txt:WriteProfileString
|
|
|
|
./cracklib-small.txt:zoning
|
|
|
|
./english-words.txt:zooming
|
|
|
|
./usernames-125k.txt:flats_gaming
|
|
|
|
./cain.txt:zoografting
|
|
|
|
./pokemon.txt:Fletchling
|
|
|
|
./pokemon8.txt:Fletchling
|
2021-07-30 17:59:30 -07:00
|
|
|
```
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
**TODO:** rename because busybox(1) sv already exists.
|
2021-07-30 17:59:30 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [tpad](/sh/tpad#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
add a 1px transparent border around an image to prevent twitter from mangling it into a jpg.
|
|
|
|
sadly, this trick doesn't work anymore.
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [trash](/sh/trash#L6)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
output a given number of bytes from `/dev/random`.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ trash 10 | hexdump -e '15 1 "%02X " 1 1 "%02X\n"'
|
|
|
|
CB 72 31 A1 BB F0 EC 9F 6E BE
|
|
|
|
```
|
2021-08-01 00:38:05 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [trunc](/sh/trunc#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
truncate text to fit within your terminal using the unicode character `…`.
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
```
|
|
|
|
$ echo $COLUMNS
|
|
|
|
84
|
|
|
|
$ seq 1 100 | tr '\n' ' ' | trunc
|
|
|
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31…
|
|
|
|
```
|
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [unscreen](/sh/unscreen#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
i don't use this anymore~
|
|
|
|
|
2021-08-01 00:38:05 -07:00
|
|
|
### [wat](/sh/wat#L8)
|
|
|
|
|
2021-08-01 09:27:25 -07:00
|
|
|
wat — a better and recursive which/whence. for zsh only.
|
|
|
|
|
|
|
|
written by [leah2.](https://leahneukirchen.org/)
|
2021-08-01 00:38:05 -07:00
|
|
|
|
2021-07-30 18:08:59 -07:00
|
|
|
### [wipe](/sh/wipe#L6)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
clear the screen and its scrollback, then print a high-contrast horizontal line.
|
|
|
|
using this, you'll know with absolute certainty that you're looking at the top of your history,
|
|
|
|
and that your terminal's scrollback didn't cap out and eat text.
|
|
|
|
|
|
|
|
**TODO:** rename because wipe(1) already exists.
|
|
|
|
|
2021-08-01 10:44:56 -07:00
|
|
|
### [xxp](/sh/xxp#L6)
|
|
|
|
|
|
|
|
act like `xxd -p`, but nicely formatted.
|
|
|
|
|
|
|
|
**TODO:** support `-r` (reverse) argument.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ xxd -p ~/rc/install | head -n2
|
|
|
|
23212f7573722f62696e2f656e762073680a232074686973207363726970
|
|
|
|
7420697320636f6d70617469626c65207769746820666f6c6c6f77696e67
|
|
|
|
$ xxp ~/rc/install | head -n2
|
|
|
|
23 21 2F 75 73 72 2F 62 69 6E 2F 65 6E 76 20 73
|
|
|
|
68 0A 23 20 74 68 69 73 20 73 63 72 69 70 74 20
|
|
|
|
```
|
|
|
|
|
2021-07-30 17:59:30 -07:00
|
|
|
## miscellaneous
|
|
|
|
|
2021-08-01 02:14:30 -07:00
|
|
|
### [dirprev (zshrc)](/home/zshrc#L70)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
rotate and change to the previous directory in the directory stack
|
|
|
|
without consuming the prompt.
|
|
|
|
|
2021-08-01 02:14:30 -07:00
|
|
|
### [dirnext (zshrc)](/home/zshrc#L77)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
rotate and change to the next directory in the directory stack
|
|
|
|
without consuming the prompt.
|
|
|
|
|
2021-08-01 02:14:30 -07:00
|
|
|
### [dirup (zshrc)](/home/zshrc#L84)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
change to the parent directory of the current working directory
|
|
|
|
without consuming the prompt.
|
|
|
|
|
2021-08-01 02:14:30 -07:00
|
|
|
### [dirview (zshrc)](/home/zshrc#L91)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
use a fuzzy finder to select a recent directory in the directory stack
|
|
|
|
and change to it without consuming the prompt.
|
|
|
|
|
2021-08-01 02:14:30 -07:00
|
|
|
### [OMFG (zshrc)](/home/zshrc#L165)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
silence stdout.
|
|
|
|
|
2021-08-01 02:14:30 -07:00
|
|
|
### [STFU (zshrc)](/home/zshrc#L166)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
silence stderr.
|
|
|
|
|
2021-08-01 02:14:30 -07:00
|
|
|
### [WHOA (zshrc)](/home/zshrc#L167)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
expand to several C/C++ flags to ease development.
|
|
|
|
|
2021-08-01 02:14:30 -07:00
|
|
|
### [WELP (zshrc)](/home/zshrc#L168)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
expand to C++ flags to enable a C++-as-C facade.
|
|
|
|
|
2021-08-01 02:14:30 -07:00
|
|
|
### [pl (zshrc)](/home/zshrc#L172)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
print each argument on its own line.
|
|
|
|
|
2021-08-01 02:14:30 -07:00
|
|
|
### [tw (zshrc)](/home/zshrc#L175)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
invoke `twitch` as a job with both stdout and stderr silenced.
|
|
|
|
|
2021-08-01 02:14:30 -07:00
|
|
|
### [reload (zshrc)](/home/zshrc#L219)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
reload zsh by wiping temp files, recompiling rc files,
|
|
|
|
and replacing the current process with a new zsh process.
|
|
|
|
|
|
|
|
### [reload (bashrc)](/home/bashrc#L49)
|
|
|
|
|
|
|
|
**TODO:** respect initctl like in `.zshrc`.
|
|
|
|
|
|
|
|
### [has (-shrc)](/home/-shrc#L8)
|
|
|
|
|
|
|
|
hardcoded here for convenience.
|
|
|
|
|
|
|
|
### [ADDPATH (-shrc)](/home/-shrc#L24)
|
|
|
|
|
|
|
|
append a directory to `$PATH` if it isn't already present.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [fils (-shrc)](/home/-shrc#L117)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
(GNU du) display human-friendly filesizes for the files in a directory.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [lsa (-shrc)](/home/-shrc#L118)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
(GNU ls) list files with directories and dotfiles ordered first.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [perlu (-shrc)](/home/-shrc#L119)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
invoke perl expecting files with UTF-8 encoding.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [rgn (-shrc)](/home/-shrc#L120)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
invoke ripgrep without respecting `.gitignore` files.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [cms (-shrc)](/home/-shrc#L121)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
invoke cryptominisat5 with less noise.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [curls (-shrc)](/home/-shrc#L122)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
invoke curl with less noise.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [get (-shrc)](/home/-shrc#L126)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
retrieve the most recent files from the default branch of a git repository, and not much else.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [gs (-shrc)](/home/-shrc#L127)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
invoke git's status subcommand.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [gd (-shrc)](/home/-shrc#L128)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
invoke git's diff subcommand with fewer lines of context.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [gds (-shrc)](/home/-shrc#L129)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
display difference stats from git.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [gl (-shrc)](/home/-shrc#L130)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
invoke git's log subcommand with a single line per commit.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [glo (-shrc)](/home/-shrc#L131)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
navigate git's commit tree succinctly.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [g1 (-shrc)](/home/-shrc#L132)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
display the most recent git commit.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [gr (-shrc)](/home/-shrc#L133)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
display remote git repositories verbosely.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [gb (-shrc)](/home/-shrc#L134)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
display the current git branch.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [revend (-shrc)](/home/-shrc#L141)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
reverse the 4-byte endianness of a single file. *this is an in-place operation!*
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [clone (-shrc)](/home/-shrc#L143)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
invoke rsync suitably for creating virtually indistinguishable copies of files.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [aligntabs (-shrc)](/home/-shrc#L144)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
align tab-delimited fields in stdin.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [crawla (-shrc)](/home/-shrc#L145)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
play Dungeon Crawl: Stone Soup through ssh on the akrasiac server.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [crawlz (-shrc)](/home/-shrc#L146)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
play Dungeon Crawl: Stone Soup through ssh on the develz server.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [eahead (-shrc)](/home/-shrc#L148)
|
|
|
|
|
|
|
|
deprecated name for [`ea head`.](#ea)
|
|
|
|
|
|
|
|
### [eaget (-shrc)](/home/-shrc#L149)
|
|
|
|
|
|
|
|
deprecated name for [`ea get`.](#ea)
|
|
|
|
|
|
|
|
### [eaput (-shrc)](/home/-shrc#L150)
|
|
|
|
|
|
|
|
deprecated name for [`ea put`.](#ea)
|
|
|
|
|
|
|
|
### [eamove (-shrc)](/home/-shrc#L151)
|
|
|
|
|
|
|
|
deprecated name for [`ea move`.](#ea)
|
|
|
|
|
|
|
|
### [eacopy (-shrc)](/home/-shrc#L152)
|
|
|
|
|
|
|
|
deprecated name for [`ea copy`.](#ea)
|
|
|
|
|
|
|
|
### [eadelete (-shrc)](/home/-shrc#L153)
|
|
|
|
|
|
|
|
deprecated name for [`ea delete`.](#ea)
|
|
|
|
|
|
|
|
### [eamv (-shrc)](/home/-shrc#L154)
|
|
|
|
|
|
|
|
invoke [`ea move`.](#ea)
|
|
|
|
|
|
|
|
### [eacp (-shrc)](/home/-shrc#L155)
|
|
|
|
|
|
|
|
invoke [`ea copy`.](#ea)
|
|
|
|
|
|
|
|
### [earm (-shrc)](/home/-shrc#L156)
|
|
|
|
|
|
|
|
invoke [`ea delete`.](#ea)
|
|
|
|
|
|
|
|
### [ll (-shrc)](/home/-shrc#L159)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
list files verbosely, fancily, ordered, but not recursively.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [diff (-shrc)](/home/-shrc#L167)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
use git's diff subcommand for general diffing.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [gc (-shrc)](/home/-shrc#L168)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
columnize text by using git's column subcommand.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [counts (-shrc)](/home/-shrc#L169)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
count files in the current directory, including files found recursively.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [exts (-shrc)](/home/-shrc#L170)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
count and sort file extensions in the current directory, including files found recursively.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [nocom (-shrc)](/home/-shrc#L171)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
strip single-line C-like and shell-like comments.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [sortip (-shrc)](/home/-shrc#L172)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
sort numerically by IPv4 segments.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [jrep (-shrc)](/home/-shrc#L173)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
extract strings comprised of basic ASCII or Japanese codepoints.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [bomb (-shrc)](/home/-shrc#L174)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
add a Byte-Order Mark to a file.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [cleanse (-shrc)](/home/-shrc#L175)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
strip unprintable and non-ASCII characters.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [rot13 (-shrc)](/home/-shrc#L176)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
rot13 with numbers rotated as well.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [unwrap (-shrc)](/home/-shrc#L177)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
join paragraphs into one line each.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [double (-shrc)](/home/-shrc#L178)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
print every line twice. <br/> print every line twice.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [join2 (-shrc)](/home/-shrc#L179)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
join every other line.
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [katagana (-shrc)](/home/-shrc#L180)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
convert katakana codepoints to their equivalent hiragana.
|
|
|
|
useful for translating [debug text from ancient games.](https://tcrf.net/)
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [picky (-shrc)](/home/-shrc#L182)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
TODO
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [unused (-shrc)](/home/-shrc#L183)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
TODO
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [makepkgf (-shrc)](/home/-shrc#L184)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
make the freakin' package!
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [rakef (-shrc)](/home/-shrc#L185)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
make the freakin' gem!
|
|
|
|
|
2021-08-01 10:29:45 -07:00
|
|
|
### [eashare (-shrc)](/home/-shrc#L187)
|
2021-07-30 17:59:30 -07:00
|
|
|
|
|
|
|
upload a file and copy its URL to the clipboard.
|
|
|
|
|
|
|
|
**NOTE:** this only works on MSYS2 for now.
|
|
|
|
|
|
|
|
**NOTE:** i lied, this doesn't work at all.
|