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)_
|
|
|
|
|
2013-06-28 05:51:52 -07:00
|
|
|
there's probably a lot of subtle things gone uncredited,
|
|
|
|
but oh well.
|
2016-06-27 06:02:53 -07:00
|
|
|
|
2016-06-27 07:12:01 -07:00
|
|
|
## stuff defined in RC files
|
2016-06-27 06:02:53 -07:00
|
|
|
|
2016-06-27 07:02:58 -07:00
|
|
|
such as [.bashrc](/home/bashrc) and [.zshrc](/home/zshrc)
|
|
|
|
but mostly [-shrc](/home/-shrc) and [.streamcrap](/home/streamcrap)
|
2016-06-27 06:02:53 -07:00
|
|
|
|
2016-06-27 07:02:58 -07:00
|
|
|
### reload
|
|
|
|
|
|
|
|
exec's the current shell.
|
|
|
|
if it's `zsh`, it'll recompile `.zshrc` so everything actually reloads.
|
|
|
|
|
|
|
|
### ADDPATH
|
|
|
|
|
|
|
|
adds a directory to `$PATH` if it isn't already there.
|
|
|
|
|
|
|
|
### ify
|
|
|
|
|
|
|
|
pipes a command through another command, so you can pass arguments at the end as usual.
|
|
|
|
|
|
|
|
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
|
|
|
|
```
|
|
|
|
|
|
|
|
### has
|
|
|
|
|
|
|
|
prints the result of `which` if the program is found, or shuts up and returns 1.
|
|
|
|
|
|
|
|
```
|
|
|
|
export CC="$(has clang || has clang-3.6 || has gcc)"
|
|
|
|
```
|
|
|
|
|
|
|
|
### revend
|
|
|
|
|
|
|
|
reverses the 4-byte endianness of a file. this is an in-place operation!
|
|
|
|
|
|
|
|
### exts
|
|
|
|
|
|
|
|
prints and sorts the most used file extensions in the CWD.
|
|
|
|
|
|
|
|
### freq
|
|
|
|
|
|
|
|
prints the most frequently used commands found in `~/.histfile`.
|
|
|
|
arguments are passed to `head`.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ freq
|
|
|
|
507 ls
|
|
|
|
349 sudo
|
|
|
|
308 git
|
|
|
|
268 less
|
|
|
|
259 e
|
|
|
|
208 luajit
|
|
|
|
188 :
|
|
|
|
185 twitch
|
|
|
|
138 th
|
|
|
|
131 z
|
|
|
|
```
|
|
|
|
|
|
|
|
that `:` is probably something i should fix.
|
|
|
|
|
|
|
|
### nocom
|
|
|
|
|
|
|
|
strips lines that begin with a `#` character.
|
|
|
|
|
|
|
|
### jrep
|
|
|
|
|
|
|
|
extracts ascii and japanese unicode characters.
|
|
|
|
|
|
|
|
### bomb
|
|
|
|
|
|
|
|
adds a Byte Order Mark to a file.
|
|
|
|
|
|
|
|
### cleanse
|
|
|
|
|
|
|
|
extracts readable ascii characters.
|
|
|
|
|
|
|
|
### rot13
|
|
|
|
|
|
|
|
rot13 with rotated numbers as well.
|
|
|
|
|
|
|
|
### unwrap
|
|
|
|
|
|
|
|
unwraps text that was wrapped using double-newlines as spacing,
|
|
|
|
e.g. this readme file.
|
|
|
|
|
|
|
|
### picky + unused
|
|
|
|
|
|
|
|
attempts to print non-standard packages that were installed on an arch linux box,
|
|
|
|
so you can reinstall them later on a fresh installation.
|
|
|
|
|
|
|
|
`unused` will print unused packages instead.
|
|
|
|
|
|
|
|
seems to be broken since the functionality of `tee -` changed.
|
|
|
|
|
|
|
|
### makepkgf + rakef
|
|
|
|
|
|
|
|
make the freakin' package!
|
|
|
|
|
|
|
|
### trash
|
|
|
|
|
|
|
|
given a number of bytes, outputs binary garbage from `/dev/random`.
|
|
|
|
|
|
|
|
### yt
|
|
|
|
|
|
|
|
watches a youtube video through mpv with a bunch of audio filtering crap.
|
|
|
|
|
|
|
|
can be given a full URL or just a video ID.
|
|
|
|
remaining arguments are passed to mpv.
|
|
|
|
|
|
|
|
### twitch + hitbox
|
|
|
|
|
|
|
|
watches twitch/hitbox streams through mpv with a bunch of audio filtering crap.
|
|
|
|
|
|
|
|
give it a username.
|
|
|
|
remaining arguments are passed to mpv.
|
|
|
|
|
|
|
|
run `alias watchstream=watchstream2` to use `livestreamer` if `youtube-dl` is acting up.
|
2016-06-27 06:02:53 -07:00
|
|
|
|
|
|
|
## shell scripts
|
|
|
|
|
|
|
|
most (but not all) stuff that's written for bash will work in zsh too.
|
|
|
|
if it just says `(sh)` then it'll probably work on anything,
|
|
|
|
but probably depends on GNU awk.
|
|
|
|
|
2016-06-27 06:04:09 -07:00
|
|
|
### [arith](/sh/arith) + [hex](/sh/hex)
|
2016-06-27 06:02:53 -07:00
|
|
|
|
2016-06-27 06:04:09 -07:00
|
|
|
(zsh) does arithmetic using the shell.
|
2016-06-27 06:02:53 -07:00
|
|
|
|
|
|
|
```
|
2016-06-27 07:02:58 -07:00
|
|
|
$ noglob arith 10**(6/20.)
|
2016-06-27 06:02:53 -07:00
|
|
|
1.9952623149688795
|
2016-06-27 06:04:09 -07:00
|
|
|
$ hex 0x221EA8-0x212020
|
|
|
|
0000FE88
|
2016-06-27 06:02:53 -07:00
|
|
|
```
|
|
|
|
|
|
|
|
### [aur](/sh/aur)
|
|
|
|
|
|
|
|
(bash) downloads, edits, makes, and installs packages from the [AUR.](//aur.archlinux.org)
|
|
|
|
|
2016-06-27 06:21:17 -07:00
|
|
|
it's a little broken.
|
2016-06-27 06:02:53 -07:00
|
|
|
|
|
|
|
```
|
|
|
|
$ aur -eyoI cmdpack-uips applyppf
|
|
|
|
```
|
|
|
|
|
|
|
|
### [cdbusiest](/sh/cdbusiest) + [dbusiest](/sh/dbusiest)
|
|
|
|
|
|
|
|
(zsh) cd to the directory with the most files in it (recursive).
|
|
|
|
dbusiest just outputs file counts without changing the directory.
|
|
|
|
|
|
|
|
useful for finding the biggest stinkers when archiving.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ cd
|
|
|
|
$ cdbusiest
|
|
|
|
197195 src
|
|
|
|
$ pwd
|
|
|
|
/home/notwa/src
|
|
|
|
```
|
|
|
|
|
|
|
|
### [colors](/sh/colors)
|
|
|
|
|
|
|
|
(bash) print out all the foreground and background terminal color combinations.
|
|
|
|
a 76-character script!
|
|
|
|
|
|
|
|
### [compandy](/sh/compandy)
|
|
|
|
|
|
|
|
(zsh) a dumb thing to generate compand arguments for ffmpeg audio filters.
|
|
|
|
|
|
|
|
### [confirm](/sh/confirm)
|
|
|
|
|
|
|
|
(bash/zsh) displays a simple yes/no prompt and returns 0 or 1 respectively.
|
|
|
|
|
2016-06-27 06:21:17 -07:00
|
|
|
```
|
|
|
|
$ confirm && echo yay || echo nay
|
|
|
|
Continue? [y/N] y
|
|
|
|
yay
|
|
|
|
$ confirm && echo yay || echo nay
|
|
|
|
Continue? [y/N] n
|
|
|
|
nay
|
|
|
|
```
|
|
|
|
|
2016-06-27 06:02:53 -07:00
|
|
|
### [days](/sh/days)
|
|
|
|
|
|
|
|
(bash) compute days since a date.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ days 'January 1 1970'
|
|
|
|
16979
|
|
|
|
```
|
|
|
|
|
|
|
|
### [dfu](/sh/dfu)
|
|
|
|
|
|
|
|
(sh) pretty df output in GiB.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ dfu
|
|
|
|
Filesystem Used Max Misc
|
|
|
|
/ 6.90 13.75 0.75
|
|
|
|
/dev 0.00 0.45 0.00
|
|
|
|
/boot 0.02 0.10 0.00
|
|
|
|
/media/2tb 1528.48 1740.49 93.17
|
|
|
|
```
|
|
|
|
|
|
|
|
### [e](/sh/e)
|
|
|
|
|
|
|
|
(zsh) wraps around $EDITOR to run as root if necessary. needs some work.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ e /etc/sudoers
|
|
|
|
[sudo] password for notwa:
|
|
|
|
```
|
|
|
|
|
|
|
|
### [gitall](/sh/gitall)
|
|
|
|
|
|
|
|
(zsh) asks you to update most of the git repos it finds. i don't really use this.
|
|
|
|
|
|
|
|
### [is\_empty](/sh/is_empty)
|
|
|
|
|
|
|
|
(bash) returns 0 if the directory given by $1 is empty.
|
|
|
|
|
|
|
|
### [isup](/sh/isup)
|
|
|
|
|
|
|
|
(zsh) returns 0 if a website returns a 2xx HTTP code.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ isup google.com && echo yay || echo nay
|
|
|
|
yay
|
|
|
|
$ isup fdhafdslkjgfjs.com && echo yay || echo nay
|
|
|
|
nay
|
|
|
|
```
|
|
|
|
|
|
|
|
### [logs](/sh/logs)
|
|
|
|
|
2016-06-27 07:12:01 -07:00
|
|
|
(bash/zsh) just wraps around `journalctl`. i don't remember how it works exactly.
|
2016-06-27 06:02:53 -07:00
|
|
|
|
|
|
|
### [lol-twitter](/sh/lol-twitter)
|
|
|
|
|
|
|
|
(zsh) checks if usernames (from stdin) are available on twitter.
|
|
|
|
|
|
|
|
seems to return a 403 code these days, but you could probably fix that.
|
|
|
|
|
|
|
|
### [lsarchive](/sh/lsarchive) + [unarchive](/sh/unarchive)
|
|
|
|
|
|
|
|
(zsh) guess what these do. written by Sorin Ionescu.
|
|
|
|
includes autocomplete files.
|
|
|
|
|
|
|
|
### [lsz](/sh/lsz)
|
|
|
|
|
|
|
|
(zsh) a needlessly fancy alternative to `ls`.
|
2016-06-27 06:21:17 -07:00
|
|
|
|
2016-06-27 06:02:53 -07:00
|
|
|
based on lsf or something, which might be [a gist somewhere.](//gist.github.com/notwa)
|
2016-06-27 06:21:17 -07:00
|
|
|
you can find [similar, more mature projects on github.](//github.com/trapd00r/ls--)
|
2016-06-27 06:02:53 -07:00
|
|
|
|
|
|
|
### [minutemaid](/sh/minutemaid)
|
|
|
|
|
|
|
|
(zsh) returns 0 if the current minute is divisible by a number.
|
2016-06-27 06:21:17 -07:00
|
|
|
|
2016-06-27 06:02:53 -07:00
|
|
|
note that a minute is relative to the seconds since the epoch,
|
|
|
|
not the minute of the hour.
|
|
|
|
|
|
|
|
```
|
|
|
|
# crontab usage:
|
|
|
|
* * * * * minutemaid 9 cd repo && git pull # runs every nine minutes
|
|
|
|
```
|
|
|
|
|
|
|
|
### [mkgist](/sh/mkgist)
|
|
|
|
|
|
|
|
(bash) makes a (mostly) empty gist and pulls it so you never have to visit the site.
|
|
|
|
i think this is broken.
|
|
|
|
|
|
|
|
### [monitor](/sh/monitor)
|
|
|
|
|
|
|
|
(zsh) literally just `watch` as a shell script. kinda nice though.
|
|
|
|
|
|
|
|
### [mw](/sh/mw) + [mw-cyg](/sh/mw-cyg)
|
|
|
|
|
|
|
|
(zsh) manages a ton of environment variables for cross-compiling programs.
|
|
|
|
you'll want to tweak this if you use it yourself.
|
|
|
|
|
|
|
|
### [now](/sh/now)
|
|
|
|
|
|
|
|
(bash) returns the local date-time in a sortable format.
|
|
|
|
will take a date or a file as an argument too.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ now
|
|
|
|
2016-06-27_19551873
|
|
|
|
$ now ./now
|
|
|
|
2016-03-12_25288645
|
|
|
|
$ now '@1234567890'
|
|
|
|
2009-02-13_55890000
|
|
|
|
```
|
|
|
|
|
|
|
|
### [pacbm](/sh/pacbm)
|
|
|
|
|
|
|
|
(zsh) lists installed pacman packages by their filesize, and the sum, ascending.
|
|
|
|
requires `expac`.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ pacbm | head -n -1 | tail -2
|
|
|
|
155.67M clang
|
|
|
|
192.34M chromium
|
|
|
|
```
|
|
|
|
|
|
|
|
### [pacman-list-disowned](/sh/pacman-list-disowned)
|
|
|
|
|
|
|
|
(zsh?) lists disowned pacman files. this might take a while.
|
|
|
|
written by Benjamin Boudreau and Sorin Ionescu.
|
|
|
|
|
|
|
|
### [pause](/sh/pause)
|
|
|
|
|
2016-06-27 06:21:17 -07:00
|
|
|
(bash/zsh) pause; the companion script of `confirm`.
|
2016-06-27 06:02:53 -07:00
|
|
|
|
|
|
|
```
|
|
|
|
$ pause
|
|
|
|
Press any key to continue
|
|
|
|
$
|
|
|
|
```
|
|
|
|
|
|
|
|
### [pre](/sh/pre)
|
|
|
|
|
2016-06-27 06:21:17 -07:00
|
|
|
(bash/zsh) dumps all the #defines that `$CC $CFLAGS $LDFLAGS` would result in.
|
2016-06-27 06:02:53 -07:00
|
|
|
|
|
|
|
```
|
|
|
|
$ pre | shuf | head -10
|
|
|
|
#define __NO_MATH_INLINES 1
|
|
|
|
#define __FLT_MIN_10_EXP__ (-37)
|
|
|
|
#define __INT_LEAST32_TYPE__ int
|
|
|
|
#define __FLT_MIN_EXP__ (-125)
|
|
|
|
#define __LDBL_MIN_EXP__ (-16381)
|
|
|
|
#define __UINT8_C_SUFFIX__
|
|
|
|
#define __WINT_UNSIGNED__ 1
|
|
|
|
#define __INT_LEAST16_FMTd__ "hd"
|
|
|
|
#define __UINT_FAST32_MAX__ 4294967295U
|
|
|
|
#define __SSE__ 1
|
|
|
|
```
|
|
|
|
|
|
|
|
### [psbm](/sh/psbm)
|
|
|
|
|
|
|
|
(sh) lists processes by their memory usage, and the sum, ascending.
|
|
|
|
|
|
|
|
```
|
2016-06-27 06:21:17 -07:00
|
|
|
$ psbm | head -n -1 | tail -2
|
2016-06-27 06:02:53 -07:00
|
|
|
155.91M 795 chromium
|
|
|
|
171.04M 832 chromium
|
|
|
|
```
|
|
|
|
|
|
|
|
### [randir](/sh/randir)
|
|
|
|
|
|
|
|
(sh) outputs a random directory in the working directory.
|
|
|
|
seems to return `./` sometimes, whoops.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ randir
|
|
|
|
./sh
|
|
|
|
```
|
|
|
|
|
|
|
|
### [sc](/sh/sc)
|
|
|
|
|
|
|
|
(bash) uploads given files to dropbox and returns a direct link for sharing.
|
|
|
|
you'll want to tweak this if you use it yourself.
|
|
|
|
|
|
|
|
has some extra logic for screenshots created by `scropt`.
|
|
|
|
|
|
|
|
### [scramble](/sh/sc)
|
|
|
|
|
|
|
|
(bash) scrambles text in a predictable way using regex.
|
|
|
|
|
|
|
|
(bhas) sacbremls ttex in a pdrceailtbe way unsig reegx.
|
|
|
|
|
|
|
|
### [screeny](/sh/screeny) + [unscreen](/sh/unscreen)
|
|
|
|
|
|
|
|
(zsh) sets up and detaches a screen for running daemons as other users, etc.
|
|
|
|
|
|
|
|
will close any existing screens of the same name using its companion script, unscreen.
|
|
|
|
|
|
|
|
e.g. run znc as user znc in a screen called znc: `screeny znc znc znc -f`. znc!
|
|
|
|
|
|
|
|
### [scropt](/sh/scropt)
|
|
|
|
|
2016-06-27 07:02:58 -07:00
|
|
|
(bash) runs `scrot` through `optipng` and saves to `~/play/$(now).png`.
|
2016-06-27 06:02:53 -07:00
|
|
|
|
|
|
|
```
|
|
|
|
$ ~/sh/sc $(~/sh/scropt -s -d0.5)
|
|
|
|
```
|
|
|
|
|
|
|
|
### [similar](/sh/similar)
|
|
|
|
|
2016-06-27 06:21:17 -07:00
|
|
|
(sh) sorts stdin and colors similarities between adjacent lines. kinda broken.
|
2016-06-27 06:02:53 -07:00
|
|
|
|
|
|
|
### [slit](/sh/slit)
|
|
|
|
|
2016-06-27 06:21:17 -07:00
|
|
|
(zsh) views specific columns of text.
|
2016-06-27 06:02:53 -07:00
|
|
|
via [pretzo.](https://github.com/sorin-ionescu/prezto/)
|
|
|
|
|
|
|
|
```
|
2016-06-27 06:21:17 -07:00
|
|
|
$ df | slit 1 5
|
2016-06-27 06:02:53 -07:00
|
|
|
Filesystem Use%
|
|
|
|
dev 0%
|
|
|
|
run 1%
|
|
|
|
/dev/sda6 30%
|
|
|
|
tmpfs 3%
|
|
|
|
tmpfs 0%
|
|
|
|
tmpfs 1%
|
|
|
|
tmpfs 1%
|
|
|
|
```
|
|
|
|
|
|
|
|
### [sram](/sh/sram)
|
|
|
|
|
|
|
|
(zsh) converts between a couple saveram formats for N64 emulators.
|
|
|
|
|
|
|
|
### [sv](/sh/sv)
|
|
|
|
|
2017-02-09 22:59:53 -08:00
|
|
|
(bash) collects the lastmost value of every key.
|
|
|
|
takes the field separator as an argument.
|
|
|
|
|
|
|
|
```
|
|
|
|
echo "this=that\nthem=those\nthis=cat" | sv =
|
|
|
|
this=cat
|
|
|
|
them=those
|
|
|
|
```
|
2016-06-27 06:02:53 -07:00
|
|
|
|
|
|
|
### [trunc](/sh/trunc)
|
|
|
|
|
|
|
|
(bash) truncates text to fit within your terminal using the unicode character `…`.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ echo $COLUMNS
|
|
|
|
64
|
|
|
|
$ unwrap /usr/share/licenses/common/GPL3/license.txt | trunc | head
|
|
|
|
GNU GENERAL PUBLIC LICENSE …
|
|
|
|
|
|
|
|
Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.…
|
|
|
|
|
|
|
|
Preamble
|
|
|
|
|
|
|
|
The GNU General Public License is a free, copyleft license fo…
|
|
|
|
|
|
|
|
The licenses for most software and other practical works are …
|
|
|
|
```
|
|
|
|
|
|
|
|
## submodules
|
|
|
|
|
|
|
|
probably horribly outdated
|
|
|
|
|
2016-06-27 06:21:17 -07:00
|
|
|
### [meow.sh](//github.com/notwa/meow.sh)
|
2016-06-27 06:02:53 -07:00
|
|
|
|
|
|
|
scrapes and downloads nyaa torrents.
|
|
|
|
|
|
|
|
### [z](//github.com/rupa/z)
|
|
|
|
|
|
|
|
cd to the most "frecently" used directory matching a regex.
|