dotfiles/.local/bin/dimswitch
Marty Oehme 499d375791 Add basic dimswitch
Prints out current version number and simple usage instructions on invocation
with -h, --help, -v, --version. Displays used configuration file when invoked
with -i/--info.

Adds simple toggle ability script, used by simply invoking `dimswitch` from the
.local/bin/ directory. In this dotfile configuration that directory is added to
the path, so can be invoked from anywhere.

Invoked without any options it will look for a line which specifies a theme
with a `-light` or `-dark` option appended, and switch them out. Does not
change the vim colorscheme or background, and can not change the theme in
alacritty itself.

The extent of this script is still limited, if it should be expanded python
seems more suited. For further discussion, see its original Merge Request !18.
2019-09-02 11:00:28 +00:00

197 lines
5.7 KiB
Bash
Executable file
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

#!/usr/bin/env bash
#
#==============================================================================
# FILE: dimswitch
# USAGE: dimswitch [-v] [-h] [-i [application]] [-t theme name] dark/light
#
# DESCRIPTION:
# Toggle alacritty terminal, and between dark
# or light mode (if correctly set up in the alacritty.yml file), see REQUIREMENTS
# The default action is to toggle between light and dark mode.
#
# OPTIONS: see function usage below
#
# REQUIREMENTS:
# The alacritty.yml file needs to have the various color-schemes set up as yaml
# anchors. The script itself will then switch the referenced anchor in the actual
# `color` key of the file. For an example alacritty.yml refer to its wiki, or
# this file: https://gitlab.com/marty-oehme/dotfiles/blob/master/.config/alacritty/alacritty.yml
#
# NOTES: This script is in active development and its functionality and options
# are very much undergoing changes. For now, do not rely on its options
# staying stable.
#
# AUTHOR:
# Marty Oehme
#
# VERSION:
ld_version="0.1.1"
#==============================================================================
#=== environment variables ====================================================
# DESCRIPTION: Environment variables to configure the script
#==============================================================================
# Sets the programs to be dimmed
if [ -z "$DIM_PROGRAMS" ]; then DIM_PROGRAMS=(alacritty); fi
# Sets the path(s) to the alacritty configuration file
if [ -z "$DIM_ALACRITTY_CONF" ]; then DIM_ALACRITTY_CONF="$HOME/.config/alacritty/alacritty.yml:$HOME/.alacritty.yml"; fi
#=== main function ============================================================
# NAME: main
# DESCRIPTION: Display usage information for this script.
# PARAMETERS: see usage function
#==============================================================================
main() {
local cmd=""
local ret=0
case "$1" in
-v | --version)
cmd="version"
;;
-h | --help)
cmd="usage"
;;
-i | --info)
cmd="printinfo"
;;
"")
cmd="toggle"
;;
esac
shift
$cmd "$@"
ret=$((ret + $?))
exit $ret
}
#=== usage function ===========================================================
# NAME: usage
# DESCRIPTION: Display usage information for this script.
#==============================================================================
usage() {
local name
name=$(basename "$0")
cat <<EOF
$name is a command line tool to toggle alacritty terminal themes.
Usage:
$name # Toggle theme between dark and light mode
$name # Set to specified alacritty theme
$name -i | --info # Print out programs to be dimmed
$name -h | --help # Print this usage information
$name -v | --version # Print version information
EOF
}
#=== theme info function=======================================================
# NAME: printinfo
# DESCRIPTION: Displays the programs to be dimmed, and the path to their
# configuration files. Currently only alacritty is implemented.
#==============================================================================
printinfo() {
for prog in "${DIM_PROGRAMS[@]}"; do
local file
file=$(getConfFile "$prog")
if [ -z "$file" ]; then
file="No associated configuration file found."
fi
echo "$prog" "-" "$file"
done
}
#=== toggle dimming function===================================================
# NAME: toggle
# DESCRIPTION: Toggles between dark and light mode in alacritty.
#==============================================================================
toggle() {
local file
file=$(getConfFile "alacritty")
if [ -z "$file" ]; then
exit 1
fi
local line
line=$(_findline "$file")
if [ -z "$line" ]; then exit 1; fi
if [[ -n $(_isdark "$file" "$line") ]]; then
_replace "$line" "$file" dark light
exit 0
fi
if [[ -n $(_islight "$file" "$line") ]]; then
_replace "$line" "$file" light dark
exit 0
fi
echo "Did not find a light/dark theme to toggle in alacritty."
exit 1
}
#=== version function==========================================================
# NAME: version
# DESCRIPTION: Display the current version of the script.
#==============================================================================
version() {
local name
name=$(basename "$0")
cat <<EOF
$name $ld_version
EOF
}
#=== get program's config file function =======================================
# NAME: getConfFile
# DESCRIPTION: Return the configuration file of the selected program.
# PARAMETER 1: [String] Name of Program
#==============================================================================
getConfFile() {
local conf
case $1 in
alacritty)
conf=$(_findfile "$DIM_ALACRITTY_CONF")
;;
esac
echo "$conf"
}
#=== verify file exists function ==============================================
# NAME: _findfile
# DESCRIPTION: Splits the string passed in into an array of paths and finds
# the first existing file. Return nothing if no file found.
# PARAMETER 1: [String] of paths, delimited by ":"
#==============================================================================
_findfile() {
IFS=':' read -ra paths <<<"$1"
for i in "${paths[@]}"; do
if [ -f "$i" ]; then
echo "$i"
fi
done
}
# function signature: _findline FILE
_findline() {
sed -n '/^colors: .*$/=' "$1"
}
# function signature: _islight LINENUMBER FILE
_islight() {
sed -n "$2p" "$1" | grep -e "-light$"
}
# function signature: _isdark LINENUMBER FILE
_isdark() {
sed -n "$2p" "$1" | grep -e "-dark$"
}
# function signature: _replace LINENUMBER FILE OLD NEW
_replace() {
sed -i "$1 s/-$3$/-$4/" "$2"
}
main "$@"