clean up shell scripts
This commit is contained in:
parent
b4ad04e6be
commit
890dc7638e
3 changed files with 539 additions and 514 deletions
common/.local/bin
|
@ -33,7 +33,7 @@ __CHTSH_DATETIME="2021-04-25 12:30:30 +0200"
|
|||
#
|
||||
CHTSH_HOME=${CHTSH:-"$HOME"/.cht.sh}
|
||||
[ -z "$CHTSH_CONF" ] && CHTSH_CONF=$CHTSH_HOME/cht.sh.conf
|
||||
# shellcheck disable=SC1090,SC2002
|
||||
# shellcheck disable=SC1090
|
||||
[ -e "$CHTSH_CONF" ] && source "$CHTSH_CONF"
|
||||
[ -z "$CHTSH_URL" ] && CHTSH_URL=https://cht.sh
|
||||
|
||||
|
@ -44,7 +44,6 @@ CHTSH_MODE="$(cat "$CHTSH_HOME"/mode 2> /dev/null)"
|
|||
[ "$CHTSH_MODE" != lite ] && CHTSH_MODE=auto
|
||||
CHEATSH_INSTALLATION="$(cat "$CHTSH_HOME/standalone" 2>/dev/null)"
|
||||
|
||||
|
||||
export LESSSECURE=1
|
||||
STEALTH_MAX_SELECTION_LENGTH=5
|
||||
|
||||
|
@ -59,25 +58,23 @@ if echo "$KSH_VERSION" | grep -q ' 93' && ! local foo 2>/dev/null; then
|
|||
alias local=typeset
|
||||
fi
|
||||
|
||||
fatal()
|
||||
{
|
||||
fatal() {
|
||||
echo "ERROR: $*" >&2
|
||||
exit 1
|
||||
}
|
||||
|
||||
_say_what_i_do()
|
||||
{
|
||||
_say_what_i_do() {
|
||||
[ -n "$LOG" ] && echo "$(date '+[%Y-%m-%d %H:%M%S]') $*" >>"$LOG"
|
||||
|
||||
local this_prompt="\033[0;1;4;32m>>\033[0m"
|
||||
printf "\n${this_prompt}%s\033[0m\n" " $* "
|
||||
}
|
||||
|
||||
cheatsh_standalone_install()
|
||||
{
|
||||
cheatsh_standalone_install() {
|
||||
# the function installs cheat.sh with the upstream repositories
|
||||
# in the standalone mode
|
||||
local installdir; installdir="$1"
|
||||
local installdir
|
||||
installdir="$1"
|
||||
local default_installdir="$HOME/.cheat.sh"
|
||||
|
||||
[ -z "$installdir" ] && installdir=${default_installdir}
|
||||
|
@ -124,20 +121,23 @@ EOF
|
|||
|
||||
local dependencies=(python git virtualenv)
|
||||
for dep in "${dependencies[@]}"; do
|
||||
command -v "$dep" >/dev/null || \
|
||||
{ echo "DEPENDENCY: \"$dep\" is needed to install cheat.sh in the standalone mode" >&2; _exit_code=1; }
|
||||
command -v "$dep" >/dev/null ||
|
||||
{
|
||||
echo "DEPENDENCY: \"$dep\" is needed to install cheat.sh in the standalone mode" >&2
|
||||
_exit_code=1
|
||||
}
|
||||
done
|
||||
[ "$_exit_code" -ne 0 ] && return "$_exit_code"
|
||||
|
||||
while true; do
|
||||
local _installdir
|
||||
echo -n "Where should cheat.sh be installed [$installdir]? "; read -r _installdir
|
||||
echo -n "Where should cheat.sh be installed [$installdir]? "
|
||||
read -r _installdir
|
||||
[ -n "$_installdir" ] && installdir=$_installdir
|
||||
|
||||
if [ "$installdir" = y ] \
|
||||
|| [ "$installdir" = Y ] \
|
||||
|| [ "$(echo "$installdir" | tr "[:upper:]" "[:lower:]")" = yes ]
|
||||
then
|
||||
if [ "$installdir" = y ] ||
|
||||
[ "$installdir" = Y ] ||
|
||||
[ "$(echo "$installdir" | tr "[:upper:]" "[:lower:]")" = yes ]; then
|
||||
echo Please enter the directory name
|
||||
echo If it was the directory name already, please prepend it with \"./\": "./$installdir"
|
||||
else
|
||||
|
@ -158,7 +158,8 @@ EOF
|
|||
fi
|
||||
|
||||
local space_needed=700
|
||||
local space_available; space_available=$(($(df -k "$installdir" | awk '{print $4}' | tail -1)/1024))
|
||||
local space_available
|
||||
space_available=$(($(df -k "$installdir" | awk '{print $4}' | tail -1) / 1024))
|
||||
|
||||
if [ "$space_available" -lt "$space_needed" ]; then
|
||||
echo "ERROR: Installation directory has no enough space (needed: ${space_needed}M, available: ${space_available}M"
|
||||
|
@ -199,8 +200,8 @@ EOF
|
|||
fi
|
||||
|
||||
_say_what_i_do Creating virtual environment
|
||||
virtualenv "${virtualenv_python3_option[@]}" ve \
|
||||
|| fatal "Could not create virtual environment with 'virtualenv ve'"
|
||||
virtualenv "${virtualenv_python3_option[@]}" ve ||
|
||||
fatal "Could not create virtual environment with 'virtualenv ve'"
|
||||
|
||||
export CHEATSH_PATH_WORKDIR=$PWD
|
||||
|
||||
|
@ -212,8 +213,8 @@ EOF
|
|||
fi
|
||||
|
||||
_say_what_i_do Installing python requirements into the virtual environment
|
||||
ve/bin/"$pip" install -r requirements.txt > "$LOG" \
|
||||
|| {
|
||||
ve/bin/"$pip" install -r requirements.txt >"$LOG" ||
|
||||
{
|
||||
|
||||
echo "ERROR:"
|
||||
echo "---"
|
||||
|
@ -234,8 +235,7 @@ EOF
|
|||
if CHEATSH_TEST_STANDALONE=YES \
|
||||
CHEATSH_TEST_SKIP_ONLINE=NO \
|
||||
CHEATSH_TEST_SHOW_DETAILS=NO \
|
||||
PYTHON=../ve/bin/python bash run-tests.sh | tee -a "$LOG"
|
||||
then
|
||||
PYTHON=../ve/bin/python bash run-tests.sh | tee -a "$LOG"; then
|
||||
printf "\033[0;32m%s\033[0m\n" "SUCCESS"
|
||||
else
|
||||
printf "\033[0;31m%s\033[0m\n" "FAILED"
|
||||
|
@ -250,8 +250,10 @@ EOF
|
|||
|
||||
_say_what_i_do Done
|
||||
|
||||
local v1; v1=$(printf "\033[0;1;32m")
|
||||
local v2; v2=$(printf "\033[0m")
|
||||
local v1
|
||||
v1=$(printf "\033[0;1;32m")
|
||||
local v2
|
||||
v2=$(printf "\033[0m")
|
||||
|
||||
cat <<EOF | sed "s/{/$v1/; s/}/$v2/"
|
||||
|
||||
|
@ -286,11 +288,11 @@ with the ENTRY-POINT from the URL https://ENTRY-POINT/:actualize specified
|
|||
EOF
|
||||
}
|
||||
|
||||
chtsh_mode()
|
||||
{
|
||||
chtsh_mode() {
|
||||
local mode="$1"
|
||||
|
||||
local text; text=$(
|
||||
local text
|
||||
text=$(
|
||||
echo " auto use the standalone installation first"
|
||||
echo " lite use the cheat sheets server directly"
|
||||
)
|
||||
|
@ -318,8 +320,7 @@ chtsh_mode()
|
|||
fi
|
||||
}
|
||||
|
||||
get_query_options()
|
||||
{
|
||||
get_query_options() {
|
||||
local query="$*"
|
||||
if [ -n "$CHTSH_QUERY_OPTIONS" ]; then
|
||||
case $query in
|
||||
|
@ -330,8 +331,7 @@ get_query_options()
|
|||
printf "%s" "$query"
|
||||
}
|
||||
|
||||
do_query()
|
||||
{
|
||||
do_query() {
|
||||
local query="$*"
|
||||
local b_opts=
|
||||
local uri="${CHTSH_URL}/\"\$(get_query_options $query)\""
|
||||
|
@ -349,10 +349,11 @@ do_query()
|
|||
fi
|
||||
}
|
||||
|
||||
prepare_query()
|
||||
{
|
||||
local section="$1"; shift
|
||||
local input="$1"; shift
|
||||
prepare_query() {
|
||||
local section="$1"
|
||||
shift
|
||||
local input="$1"
|
||||
shift
|
||||
local arguments="$1"
|
||||
|
||||
local query
|
||||
|
@ -366,13 +367,11 @@ prepare_query()
|
|||
printf %s "$query$arguments"
|
||||
}
|
||||
|
||||
get_list_of_sections()
|
||||
{
|
||||
get_list_of_sections() {
|
||||
curl -s "${CHTSH_URL}"/:list | grep -v '/.*/' | grep '/$' | xargs
|
||||
}
|
||||
|
||||
gen_random_str()
|
||||
(
|
||||
gen_random_str() (
|
||||
len=$1
|
||||
if command -v openssl >/dev/null; then
|
||||
openssl rand -base64 $((len * 3 / 4)) | awk -v ORS='' //
|
||||
|
@ -386,7 +385,10 @@ gen_random_str()
|
|||
elif command -v xxd >/dev/null; then
|
||||
xxd -l $((len / 2)) -ps "$rdev" | awk -v ORS='' //
|
||||
else
|
||||
cd /tmp || { echo Cannot cd into /tmp >&2; exit 1; }
|
||||
cd /tmp || {
|
||||
echo Cannot cd into /tmp >&2
|
||||
exit 1
|
||||
}
|
||||
s=
|
||||
# shellcheck disable=SC2000
|
||||
while [ "$(echo "$s" | wc -c)" -lt "$len" ]; do
|
||||
|
@ -407,7 +409,9 @@ if [ "$CHTSH_MODE" = auto ] && [ -d "$CHEATSH_INSTALLATION" ]; then
|
|||
done
|
||||
shift $((OPTIND - 1))
|
||||
|
||||
local url; url="$1"; shift
|
||||
local url
|
||||
url="$1"
|
||||
shift
|
||||
PYTHONIOENCODING=UTF-8 "$CHEATSH_INSTALLATION/ve/bin/python" "$CHEATSH_INSTALLATION/lib/standalone.py" "${url#"$CHTSH_URL"}" "$@"
|
||||
}
|
||||
elif [ "$(uname -s)" = OpenBSD ] && [ -x /usr/bin/ftp ]; then
|
||||
|
@ -418,14 +422,20 @@ elif [ "$(uname -s)" = OpenBSD ] && [ -x /usr/bin/ftp ]; then
|
|||
case $opt in
|
||||
b) args="$args -c $OPTARG" ;;
|
||||
s) args="$args -M -V" ;;
|
||||
*) echo "internal error: unsupported cURL option '$opt'" >&2; exit 1;;
|
||||
*)
|
||||
echo "internal error: unsupported cURL option '$opt'" >&2
|
||||
exit 1
|
||||
;;
|
||||
esac
|
||||
done
|
||||
shift $((OPTIND - 1))
|
||||
/usr/bin/ftp "$args" "$@"
|
||||
}
|
||||
else
|
||||
command -v curl >/dev/null || { echo 'DEPENDENCY: install "curl" to use cht.sh' >&2; exit 1; }
|
||||
command -v curl >/dev/null || {
|
||||
echo 'DEPENDENCY: install "curl" to use cht.sh' >&2
|
||||
exit 1
|
||||
}
|
||||
_CURL=$(command -v curl)
|
||||
if [ x"$CHTSH_CURL_OPTIONS" != x ]; then
|
||||
curl() {
|
||||
|
@ -496,7 +506,11 @@ if [ "$shell_mode" != yes ]; then
|
|||
else
|
||||
new_section="$1"
|
||||
valid_sections=$(get_list_of_sections)
|
||||
valid=no; for q in $valid_sections; do [ "$q" = "$new_section/" ] && { valid=yes; break; }; done
|
||||
valid=no
|
||||
for q in $valid_sections; do [ "$q" = "$new_section/" ] && {
|
||||
valid=yes
|
||||
break
|
||||
}; done
|
||||
|
||||
if [ "$valid" = yes ]; then
|
||||
section="$new_section"
|
||||
|
@ -520,7 +534,10 @@ if [ "$is_macos" != yes ]; then
|
|||
command -v xsel >/dev/null || echo 'DEPENDENCY: please install "xsel" for "copy"' >&2
|
||||
fi
|
||||
fi
|
||||
command -v rlwrap >/dev/null || { echo 'DEPENDENCY: install "rlwrap" to use cht.sh in the shell mode' >&2; exit 1; }
|
||||
command -v rlwrap >/dev/null || {
|
||||
echo 'DEPENDENCY: install "rlwrap" to use cht.sh in the shell mode' >&2
|
||||
exit 1
|
||||
}
|
||||
|
||||
mkdir -p "$CHTSH_HOME/"
|
||||
lines=$(tput lines)
|
||||
|
@ -542,15 +559,19 @@ cmd_cd() {
|
|||
section=""
|
||||
else
|
||||
valid_sections=$(get_list_of_sections)
|
||||
valid=no; for q in $valid_sections; do [ "$q" = "$new_section/" ] && { valid=yes; break; }; done
|
||||
valid=no
|
||||
for q in $valid_sections; do [ "$q" = "$new_section/" ] && {
|
||||
valid=yes
|
||||
break
|
||||
}; done
|
||||
if [ "$valid" = no ]; then
|
||||
echo "Invalid section: $new_section"
|
||||
echo "Valid sections:"
|
||||
echo "$valid_sections" \
|
||||
| xargs printf "%-10s\n" \
|
||||
| tr ' ' . \
|
||||
| xargs -n 10 \
|
||||
| sed 's/\./ /g; s/^/ /'
|
||||
echo "$valid_sections" |
|
||||
xargs printf "%-10s\n" |
|
||||
tr ' ' . |
|
||||
xargs -n 10 |
|
||||
sed 's/\./ /g; s/^/ /'
|
||||
else
|
||||
section="$new_section"
|
||||
fi
|
||||
|
@ -720,13 +741,16 @@ cmd_stealth() {
|
|||
do_query "$query"
|
||||
fi
|
||||
fi
|
||||
sleep 1;
|
||||
sleep 1
|
||||
done
|
||||
trap - INT
|
||||
}
|
||||
|
||||
cmd_update() {
|
||||
[ -w "$0" ] || { echo "The script is readonly; please update manually: curl -s ${CHTSH_URL}/:cht.sh | sudo tee $0"; return; }
|
||||
[ -w "$0" ] || {
|
||||
echo "The script is readonly; please update manually: curl -s ${CHTSH_URL}/:cht.sh | sudo tee $0"
|
||||
return
|
||||
}
|
||||
TMP2=$(mktemp /tmp/cht.sh.XXXXXXXXXXXXX)
|
||||
curl -s "${CHTSH_URL}"/:cht.sh >"$TMP2"
|
||||
if ! cmp "$0" "$TMP2" >/dev/null 2>&1; then
|
||||
|
@ -790,7 +814,10 @@ while true; do
|
|||
stealth) cmd_name=stealth ;;
|
||||
update) cmd_name=update ;;
|
||||
version) cmd_name=version ;;
|
||||
*) cmd_name="query"; cmd_args="$input";;
|
||||
*)
|
||||
cmd_name="query"
|
||||
cmd_args="$input"
|
||||
;;
|
||||
esac
|
||||
"cmd_$cmd_name" $cmd_args
|
||||
done
|
||||
|
|
|
@ -1,5 +1,4 @@
|
|||
#!/bin/sh
|
||||
# shellcheck disable=2154
|
||||
|
||||
term=
|
||||
[ -n "$SCRATCHPAD" ] && {
|
||||
|
|
|
@ -1,5 +1,4 @@
|
|||
#!/bin/sh
|
||||
# shellcheck disable=2089,2090
|
||||
|
||||
year=$1
|
||||
month=$2
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue