mirror of
https://github.com/jessebot/dot_files.git
synced 2025-10-01 01:48:43 +00:00
80 lines
2.6 KiB
Bash
80 lines
2.6 KiB
Bash
# ------------------------------------------------------------------------- #
|
|
# Text Editor
|
|
# Default, in order of preference (subject to availability): nvim, vim, vi
|
|
# ------------------------------------------------------------------------- #
|
|
|
|
# Default EDITOR is nvim
|
|
if [ -n "$(which nvim)" ]; then
|
|
export EDITOR=nvim
|
|
# if nvim is not available, set EDITOR to vim
|
|
else
|
|
export EDITOR=vim
|
|
fi
|
|
|
|
# always use nvim (or vim) instead of vi
|
|
alias vi=$EDITOR
|
|
# use nvim instead of vim when available
|
|
alias vim=$EDITOR
|
|
# I and many others always try to type neovim :)
|
|
alias neovim=$EDITOR
|
|
alias nivm=$EDITOR
|
|
alias ivm=$EDITOR
|
|
alias vmi=$EDITOR
|
|
|
|
# this is useful because I split a lot of files
|
|
alias vsplit="$EDITOR -O"
|
|
|
|
# make all colors work by default, including via ssh!!
|
|
unset TERM
|
|
export TERM=xterm-256color
|
|
export COLORTERM=truecolor
|
|
|
|
# -- This is for making some basic resizing working with various cli tools --
|
|
# check the window size after each command and, if necessary,
|
|
# update the values of LINES and COLUMNS.
|
|
shopt -s checkwinsize
|
|
|
|
|
|
# ------------------------------------------------------------------------- #
|
|
# TEXT VIEWING #
|
|
# ------------------------------------------------------------------------- #
|
|
# make less more friendly for non-text input files, see lesspipe(1)
|
|
[ -x /usr/bin/lesspipe ] && eval "$(SHELL=/bin/sh lesspipe)"
|
|
|
|
# colors for less when displaying man pages
|
|
export LESS_TERMCAP_mb=$'\e[1;32m'
|
|
export LESS_TERMCAP_md=$'\e[1;32m'
|
|
export LESS_TERMCAP_me=$'\e[0m'
|
|
export LESS_TERMCAP_se=$'\e[0m'
|
|
export LESS_TERMCAP_so=$'\e[01;33m'
|
|
export LESS_TERMCAP_ue=$'\e[0m'
|
|
export LESS_TERMCAP_us=$'\e[1;4;35m'
|
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ cat ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ #
|
|
|
|
# TODO: Write those docs with links to both apps (rich, and bat)
|
|
# Function to use the best syntax highlighting app for the job
|
|
function dog {
|
|
# if file has more lines than legnth of the terminal use app with pager
|
|
too_long=false
|
|
if [ $(wc -l $1 | awk '{print $1}') -gt $(tput lines) ]; then
|
|
too_long=true
|
|
fi
|
|
|
|
# if this is a markdown or csv file, ALWAYS use rich to print the data
|
|
if [[ "$1" == *".md" ]] || [[ "$1" == *".csv" ]]; then
|
|
if $too_long; then
|
|
# pager allows moving with j for down, k for up, and :q for quit
|
|
rich --pager $1
|
|
else
|
|
rich $1
|
|
echo ""
|
|
fi
|
|
else
|
|
# use batcat - sytnax highlighting + git support and pager
|
|
bat $1 || batcat $1
|
|
fi
|
|
}
|
|
|
|
alias raw='env cat'
|
|
alias cat='dog'
|