Created
January 13, 2019 22:00
-
-
Save fallwith/128ec07273298a3eaa69347a13e1bdad to your computer and use it in GitHub Desktop.
Colors and images in the terminal
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/bin/bash | |
# This file was originally taken from iterm2 https://github.com/gnachman/iTerm2/blob/master/tests/24-bit-color.sh | |
# | |
# This file echoes a bunch of 24-bit color codes | |
# to the terminal to demonstrate its functionality. | |
# The foreground escape sequence is ^[38;2;<r>;<g>;<b>m | |
# The background escape sequence is ^[48;2;<r>;<g>;<b>m | |
# <r> <g> <b> range from 0 to 255 inclusive. | |
# The escape sequence ^[0m returns output to default | |
setBackgroundColor() | |
{ | |
#printf '\x1bPtmux;\x1b\x1b[48;2;%s;%s;%sm' $1 $2 $3 | |
printf '\x1b[48;2;%s;%s;%sm' $1 $2 $3 | |
} | |
resetOutput() | |
{ | |
echo -en "\x1b[0m\n" | |
} | |
# Gives a color $1/255 % along HSV | |
# Who knows what happens when $1 is outside 0-255 | |
# Echoes "$red $green $blue" where | |
# $red $green and $blue are integers | |
# ranging between 0 and 255 inclusive | |
rainbowColor() | |
{ | |
let h=$1/43 | |
let f=$1-43*$h | |
let t=$f*255/43 | |
let q=255-t | |
if [ $h -eq 0 ] | |
then | |
echo "255 $t 0" | |
elif [ $h -eq 1 ] | |
then | |
echo "$q 255 0" | |
elif [ $h -eq 2 ] | |
then | |
echo "0 255 $t" | |
elif [ $h -eq 3 ] | |
then | |
echo "0 $q 255" | |
elif [ $h -eq 4 ] | |
then | |
echo "$t 0 255" | |
elif [ $h -eq 5 ] | |
then | |
echo "255 0 $q" | |
else | |
# execution should never reach here | |
echo "0 0 0" | |
fi | |
} | |
for i in `seq 0 127`; do | |
setBackgroundColor $i 0 0 | |
echo -en " " | |
done | |
resetOutput | |
for i in `seq 255 -1 128`; do | |
setBackgroundColor $i 0 0 | |
echo -en " " | |
done | |
resetOutput | |
for i in `seq 0 127`; do | |
setBackgroundColor 0 $i 0 | |
echo -n " " | |
done | |
resetOutput | |
for i in `seq 255 -1 128`; do | |
setBackgroundColor 0 $i 0 | |
echo -n " " | |
done | |
resetOutput | |
for i in `seq 0 127`; do | |
setBackgroundColor 0 0 $i | |
echo -n " " | |
done | |
resetOutput | |
for i in `seq 255 -1 128`; do | |
setBackgroundColor 0 0 $i | |
echo -n " " | |
done | |
resetOutput | |
for i in `seq 0 127`; do | |
setBackgroundColor `rainbowColor $i` | |
echo -n " " | |
done | |
resetOutput | |
for i in `seq 255 -1 128`; do | |
setBackgroundColor `rainbowColor $i` | |
echo -n " " | |
done | |
resetOutput |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/bin/bash | |
# tmux requires unrecognized OSC sequences to be wrapped with DCS tmux; | |
# <sequence> ST, and for all ESCs in <sequence> to be replaced with ESC ESC. It | |
# only accepts ESC backslash for ST. | |
function print_osc() { | |
if [[ $TERM == screen* ]] ; then | |
printf "\033Ptmux;\033\033]" | |
else | |
printf "\033]" | |
fi | |
} | |
# More of the tmux workaround described above. | |
function print_st() { | |
if [[ $TERM == screen* ]] ; then | |
printf "\a\033\\" | |
else | |
printf "\a" | |
fi | |
} | |
# print_image filename inline base64contents print_filename | |
# filename: Filename to convey to client | |
# inline: 0 or 1 | |
# base64contents: Base64-encoded contents | |
# print_filename: If non-empty, print the filename | |
# before outputting the image | |
function print_image() { | |
print_osc | |
printf '1337;File=' | |
if [[ -n "$1" ]]; then | |
printf 'name='`printf "%s" "$1" | base64`";" | |
fi | |
VERSION=$(base64 --version 2>&1) | |
if [[ "$VERSION" =~ fourmilab ]]; then | |
BASE64ARG=-d | |
elif [[ "$VERSION" =~ GNU ]]; then | |
BASE64ARG=-di | |
else | |
BASE64ARG=-D | |
fi | |
printf "%s" "$3" | base64 $BASE64ARG | wc -c | awk '{printf "size=%d",$1}' | |
printf ";inline=$2" | |
printf ":" | |
printf "%s" "$3" | |
print_st | |
printf '\n' | |
if [[ -n "$4" ]]; then | |
echo $1 | |
fi | |
} | |
function error() { | |
echo "ERROR: $*" 1>&2 | |
} | |
function show_help() { | |
echo "Usage: imgcat [-p] filename ..." 1>& 2 | |
echo " or: cat filename | imgcat" 1>& 2 | |
} | |
## Main | |
if [ -t 0 ]; then | |
has_stdin=f | |
else | |
has_stdin=t | |
fi | |
# Show help if no arguments and no stdin. | |
if [ $has_stdin = f -a $# -eq 0 ]; then | |
show_help | |
exit | |
fi | |
# Look for command line flags. | |
while [ $# -gt 0 ]; do | |
case "$1" in | |
-h|--h|--help) | |
show_help | |
exit | |
;; | |
-p|--p|--print) | |
print_filename=1 | |
;; | |
-*) | |
error "Unknown option flag: $1" | |
show_help | |
exit 1 | |
;; | |
*) | |
if [ -r "$1" ] ; then | |
has_stdin=f | |
print_image "$1" 1 "$(base64 < "$1")" "$print_filename" | |
else | |
error "imgcat: $1: No such file or directory" | |
exit 2 | |
fi | |
;; | |
esac | |
shift | |
done | |
# Read and print stdin | |
if [ $has_stdin = t ]; then | |
print_image "" 1 "$(cat | base64)" "" | |
fi | |
exit 0 |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment