diff options
| author | EuAndreh <eu@euandre.org> | 2022-05-12 12:01:54 -0300 |
|---|---|---|
| committer | EuAndreh <eu@euandre.org> | 2022-05-12 12:01:54 -0300 |
| commit | 90eaebabcaaea74237f34cf05709625345f276cc (patch) | |
| tree | 349e7609d20ecfb6567652a7e28595cec9647eb0 /bin/e | |
| parent | .usr/etc/i3/config: WIP setup extra bindings (diff) | |
| download | dotfiles-90eaebabcaaea74237f34cf05709625345f276cc.tar.gz dotfiles-90eaebabcaaea74237f34cf05709625345f276cc.tar.xz | |
Move Git repository into ~/.usr/.git/
Diffstat (limited to 'bin/e')
| -rwxr-xr-x | bin/e | 79 |
1 files changed, 79 insertions, 0 deletions
@@ -0,0 +1,79 @@ +#!/bin/sh +set -eu + +usage() { + cat <<-'EOF' + Usage: + e [FILE] + e -h + EOF +} + +help() { + cat <<-'EOF' + + Options: + -h, --help + + + Flexibly run a text editor, either directly on in a pipe. + + Examples: + + Edit "file.txt": + + $ e file.txt + + Manipulate the content of a pipe midway: + + $ seq 10 | e | grep 5 + + The editor used is either $VISUAL or $EDITOR, with a fallback to + vi in case any of those variables aren't defined. + EOF +} + +for flag in "$@"; do + case "$flag" in + --) + break + ;; + --help) + usage + help + exit + ;; + *) + ;; + esac +done + +while getopts 'h' flag; do + case "$flag" in + h) + usage + help + exit + ;; + *) + usage >&2 + exit 2 + ;; + esac +done +shift $((OPTIND - 1)) + + +CMD="${VISUAL:-${EDITOR:-vi}}" + +if [ ! -t 0 ]; then + F="$(mkstemp)" + cat > "$F" + exec 0</dev/tty + exec 3>&1 + exec 1>/dev/tty + $CMD "$F" + cat "$F" >&3 +else + $CMD "$@" +fi |
