2022-04-06 12:27:26 -07:00
|
|
|
#!/bin/bash
|
2023-01-20 10:09:56 -08:00
|
|
|
|
|
|
|
str_after () {
|
|
|
|
echo "$1" | cut -s -d "${2:-=}" -f2
|
|
|
|
}
|
|
|
|
|
|
|
|
str_before () {
|
|
|
|
echo "$1" | cut -s -d "${2:-=}" -f1
|
|
|
|
}
|
|
|
|
|
2022-04-06 12:27:26 -07:00
|
|
|
# must be json as a string, depends on jq
|
|
|
|
get_prop_value () {
|
|
|
|
local value
|
|
|
|
# echo in $1 get $2
|
|
|
|
value=$(echo $1 | jq -r .$2)
|
|
|
|
echo $value
|
|
|
|
}
|
|
|
|
|
|
|
|
is_array() {
|
|
|
|
local variable_name=$1
|
|
|
|
[[ "$(declare -p $variable_name 2>/dev/null)" =~ "declare -a" ]]
|
|
|
|
}
|
|
|
|
|
2022-12-24 12:34:03 -08:00
|
|
|
is_function() {
|
|
|
|
[[ $(type $1 2> /dev/null) ]] && echo $1 is a function
|
|
|
|
}
|
|
|
|
|
2022-04-06 12:27:26 -07:00
|
|
|
filename() {
|
|
|
|
# passed entire path
|
|
|
|
echo $(basename "$1" | rev | cut -f 2- -d '.' | rev)
|
|
|
|
}
|
|
|
|
|
2022-12-31 23:28:18 -08:00
|
|
|
fileext() {
|
|
|
|
# passed entire path
|
|
|
|
echo $1 | awk -F . '{print $NF}'
|
|
|
|
}
|
|
|
|
|
2022-04-06 12:27:26 -07:00
|
|
|
# // TODO remove and use path module
|
|
|
|
# // must change acl.lib and loginout, chromium, and ungoogled install files
|
|
|
|
adirname() {
|
|
|
|
# passed entire path
|
|
|
|
echo "$(cd "$(dirname "$1")" >/dev/null 2>&1 ; pwd -P )"
|
|
|
|
}
|
|
|
|
|
|
|
|
user_exists() {
|
|
|
|
id -u $1 > /dev/null 2>&1
|
|
|
|
[[ $? == 1 ]] || echo $1
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
chmod_dirs() {
|
|
|
|
# passed entire path
|
|
|
|
local usesudo
|
|
|
|
[[ $1 == -s ]] && usesudo="sudo" && shift 2
|
|
|
|
$usesudo find $1 -type f -exec chmod $2 {} +
|
|
|
|
}
|
|
|
|
|
|
|
|
parse_option () {
|
|
|
|
# usage: parse_option -f "-b one -p 22 -F another" -p
|
|
|
|
# if -f is used then it will return the complete option
|
|
|
|
# otherwise just the options value
|
|
|
|
local opts;local f;local opt; local ret
|
|
|
|
[[ $1 = "-f" ]] && { f=true;shift 1; }
|
|
|
|
[[ $1 && $2 ]] || return 1
|
|
|
|
opts=$1
|
|
|
|
opt=$2
|
|
|
|
[[ ! $opts =~ "$opt" ]] && return 1
|
|
|
|
ret=$(sed -n "/^.*$opt\s\+\(\w\+\).*$/s//\1/p" <<< $opts)
|
|
|
|
[[ $f ]] && echo "$2 $ret" || echo $ret
|
|
|
|
}
|
|
|
|
|
2023-01-05 12:36:23 -08:00
|
|
|
remove_empty_lines () {
|
2024-02-16 23:49:08 -08:00
|
|
|
if [[ -f $1 ]]; then cat $1; else echo "$1"; fi | sed -n '/^\s*$/!p'
|
|
|
|
# sed -rz 's/^\n+//; s/\n+$/\n/g'
|
2023-01-05 12:36:23 -08:00
|
|
|
}
|
|
|
|
|
2022-04-06 12:27:26 -07:00
|
|
|
remove_end_spaces () {
|
|
|
|
del=${2:-\'}
|
|
|
|
# echo delimiter: $del
|
|
|
|
# sed -e "s/[[:space:]]\{1,\}$del/$del/" <<< "$1"
|
|
|
|
res=$(sed -e "s/^$del[[:space:]]*/$del/" <<< "$1")
|
|
|
|
sed -e "s/[[:space:]]*${del}$/$del/" <<< "$res"
|
|
|
|
}
|
|
|
|
|
2023-01-05 12:36:23 -08:00
|
|
|
# pass any sed ' ' string and comments lines will be ignored
|
2022-12-24 12:34:03 -08:00
|
|
|
# https://unix.stackexchange.com/a/301432/201387
|
|
|
|
# https://stackoverflow.com/a/35874420/4695378
|
|
|
|
sed_ignore_comments () {
|
|
|
|
cmd="sed -r 'h;s/[^#]*//1;x;s/#.*//;${1};G;s/(.*)\n/\1/'"
|
|
|
|
if (( $# == 2 )) ; then
|
|
|
|
eval $cmd <<< "$2"
|
|
|
|
else
|
|
|
|
eval $cmd < /dev/stdin
|
|
|
|
fi
|
|
|
|
}
|
2023-01-20 10:09:56 -08:00
|
|
|
|
2024-02-16 23:49:08 -08:00
|
|
|
compact_file () {
|
|
|
|
# removes trailing spaces, blank lines and comments
|
|
|
|
# echo -e "$1"
|
|
|
|
# grep -v '^\s*#' $1
|
|
|
|
[[ -f $1 ]] && sed -i -e '/^\s*#/d' -e '/^\s*$/d' "$1"
|
|
|
|
# if [[ -f "$1" ]]; then cat "$1"; else echo -e "$@"; fi | sed 's/\\s*$//g' | sed -r '/^\s*$/d' | grep -v '^\s*#'
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2023-12-14 13:59:24 -08:00
|
|
|
#rows between matched rows
|
|
|
|
# sed '1,/firstmatch/d;/secondmatch/,$d'
|
|
|
|
|