Centering ANSI images on a terminal
Nothing screams last decade like CSS centering. Nowadays it’s all about the terminal. Say you have this nice snorlax on a text file. It all looks nice, except it’s not centered.
data:image/s3,"s3://crabby-images/6c5f5/6c5f5374125e37fc05c56c9748db3a0f2080efbf" alt=""
It’s full of ANSI escape codes, so fmt
won’t do it
data:image/s3,"s3://crabby-images/d37b3/d37b325939c779f6e02a8e7a40cb584da0f69940" alt=""
We could clean it up
data:image/s3,"s3://crabby-images/aa53d/aa53d2c182a876f710c89e2d6198f65268077104" alt=""
Get the length of the longest line
data:image/s3,"s3://crabby-images/2a86f/2a86f5b01d8f9c30b6e4646eb08b52b82a66fd71" alt=""
Get the width of the terminal, subtract the length and divide it by two
data:image/s3,"s3://crabby-images/82fa7/82fa761d6cfaf5c27bbf4c1b738cbf18a585486c" alt=""
Finally use that magic number and pad your snorlax
data:image/s3,"s3://crabby-images/90ff1/90ff1a7902d684b771b35a14fa2c4e90dfc7dbbf" alt=""
Ah yes, a nice oneliner
data:image/s3,"s3://crabby-images/e430f/e430f7e40368017ccceaee8e284f4c27ae4fe400" alt=""
you know.. let’s make it nice and readable
data:image/s3,"s3://crabby-images/ad479/ad479fdd8269c1ac97800114994762cd7de384d2" alt=""
function center {
local f p s
f=$(mktemp);p=${1:-$(tput cols)};s="s,\x1B\[[0-9;]*[a-zA-Z],,g";cat>$f
s=$(cat $f|sed $s|while IFS= read -r l;do echo ${#l};done|sort -n|tail -1)
s=$(((p-s)/2));s=$(printf "%${s}s" " ");cat $f|sed -e 's/^/'"$s"'/';rm $f
}