Merge branch 'master' of github.com:dylanaraps/neofetch
This commit is contained in:
commit
4b0a430585
3 changed files with 38 additions and 32 deletions
|
@ -20,7 +20,7 @@ script:
|
||||||
- time ./neofetch --ascii --config config/travis.conf -v
|
- time ./neofetch --ascii --config config/travis.conf -v
|
||||||
# See this wiki page for why we're disabling these errors.
|
# See this wiki page for why we're disabling these errors.
|
||||||
# https://github.com/dylanaraps/neofetch/wiki/Shellcheck-Exclusions
|
# https://github.com/dylanaraps/neofetch/wiki/Shellcheck-Exclusions
|
||||||
- if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then shellcheck neofetch -e SC1090,SC2009,SC2012,SC2016,SC2034,SC2128,SC2153,SC2154,SC2178,SC2010,SC1004; fi
|
- if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then shellcheck neofetch -e SC1090,SC2009,SC2012,SC2016,SC2034,SC2128,SC2153,SC2154,SC2178,SC2010,SC1004,SC1117; fi
|
||||||
# The if statement is here to invert the exit code from grep.
|
# The if statement is here to invert the exit code from grep.
|
||||||
# grep normally errors if no match is found but we want the opposite.
|
# grep normally errors if no match is found but we want the opposite.
|
||||||
# We invert it so grep fails if a match is found.
|
# We invert it so grep fails if a match is found.
|
||||||
|
|
|
@ -1,2 +1,8 @@
|
||||||
## Contributors
|
## Contributors
|
||||||
|
|
||||||
|
|
||||||
|
## Info
|
||||||
|
|
||||||
|
**Title**
|
||||||
|
|
||||||
|
- Fixed unexpected backslash being inserted on some systems
|
||||||
|
|
62
neofetch
62
neofetch
|
@ -30,7 +30,7 @@ export GIO_EXTRA_MODULES="/usr/lib/x86_64-linux-gnu/gio/modules/"
|
||||||
shopt -s nocasematch
|
shopt -s nocasematch
|
||||||
|
|
||||||
# Reset colors and bold.
|
# Reset colors and bold.
|
||||||
reset="\\e[0m"
|
reset="\e[0m"
|
||||||
|
|
||||||
# DETECT INFORMATION
|
# DETECT INFORMATION
|
||||||
|
|
||||||
|
@ -2543,9 +2543,9 @@ get_cols() {
|
||||||
# Generate the string.
|
# Generate the string.
|
||||||
for ((start; start<=end; start++)); do
|
for ((start; start<=end; start++)); do
|
||||||
case "$start" in
|
case "$start" in
|
||||||
[0-6]) blocks+="${reset}\\e[3${start}m\\e[4${start}m${block_width}" ;;
|
[0-6]) blocks+="${reset}\e[3${start}m\e[4${start}m${block_width}" ;;
|
||||||
7) blocks+="${reset}\\e[3${start}m\\e[4${start}m${block_width}" ;;
|
7) blocks+="${reset}\e[3${start}m\e[4${start}m${block_width}" ;;
|
||||||
*) blocks2+="\\e[38;5;${start}m\\e[48;5;${start}m${block_width}" ;;
|
*) blocks2+="\e[38;5;${start}m\e[48;5;${start}m${block_width}" ;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
|
@ -2558,12 +2558,12 @@ get_cols() {
|
||||||
|
|
||||||
# Add newlines to the string.
|
# Add newlines to the string.
|
||||||
cols="${cols%%'nl'}"
|
cols="${cols%%'nl'}"
|
||||||
cols="${cols//nl/\\n\\\e[${text_padding}C${zws}}"
|
cols="${cols//nl/\\n\\e[${text_padding}C${zws}}"
|
||||||
|
|
||||||
# Add block height to info height.
|
# Add block height to info height.
|
||||||
info_height="$((info_height+=block_height+2))"
|
info_height="$((info_height+=block_height+2))"
|
||||||
|
|
||||||
printf "%b\n" "\\e[${text_padding}C${zws}${cols}"
|
printf "%b\n" "\e[${text_padding}C${zws}${cols}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
unset -v blocks blocks2 cols
|
unset -v blocks blocks2 cols
|
||||||
|
@ -2571,7 +2571,7 @@ get_cols() {
|
||||||
# TosWin2 on FreeMiNT is terrible at this,
|
# TosWin2 on FreeMiNT is terrible at this,
|
||||||
# so we'll reset colors arbitrarily.
|
# so we'll reset colors arbitrarily.
|
||||||
[[ "$term" == "TosWin2" ]] && \
|
[[ "$term" == "TosWin2" ]] && \
|
||||||
printf "%b\n" "\\e[30;47m"
|
printf "%b\n" "\e[30;47m"
|
||||||
|
|
||||||
# Tell info() that we printed manually.
|
# Tell info() that we printed manually.
|
||||||
prin=1
|
prin=1
|
||||||
|
@ -2625,7 +2625,7 @@ image_backend() {
|
||||||
esac
|
esac
|
||||||
|
|
||||||
# Set cursor position next image/ascii.
|
# Set cursor position next image/ascii.
|
||||||
[[ "$image_backend" != "off" ]] && printf "%b" "\\e[${lines:-0}A\\e[9999999D"
|
[[ "$image_backend" != "off" ]] && printf "%b" "\e[${lines:-0}A\e[9999999D"
|
||||||
}
|
}
|
||||||
|
|
||||||
get_ascii() {
|
get_ascii() {
|
||||||
|
@ -2819,14 +2819,14 @@ get_term_size() {
|
||||||
# so we have to use a slightly different sequence to
|
# so we have to use a slightly different sequence to
|
||||||
# get the terminal size.
|
# get the terminal size.
|
||||||
if [[ -n "$TMUX" ]]; then
|
if [[ -n "$TMUX" ]]; then
|
||||||
printf "%b" "\\ePtmux;\\e\\e[14t\\e\\e[c\\e\\"
|
printf "%b" "\ePtmux;\e\e[14t\e\e[c\e\\"
|
||||||
read_flags=(-d c)
|
read_flags=(-d c)
|
||||||
|
|
||||||
elif [[ "$image_backend" == "tycat" ]]; then
|
elif [[ "$image_backend" == "tycat" ]]; then
|
||||||
printf "%b" "\\e}qs\000"
|
printf "%b" "\e}qs\000"
|
||||||
|
|
||||||
else
|
else
|
||||||
printf "%b" "\\e[14t\\e[c"
|
printf "%b" "\e[14t\e[c"
|
||||||
read_flags=(-d c)
|
read_flags=(-d c)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -2845,7 +2845,7 @@ get_term_size() {
|
||||||
term_width="${term_size[2]/t*}"
|
term_width="${term_size[2]/t*}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Get terminal width/height if \\e[14t is unsupported.
|
# Get terminal width/height if \e[14t is unsupported.
|
||||||
if [[ -z "$term_width" ]] || (( "$term_width" < 50 )); then
|
if [[ -z "$term_width" ]] || (( "$term_width" < 50 )); then
|
||||||
if type -p xdotool >/dev/null 2>&1; then
|
if type -p xdotool >/dev/null 2>&1; then
|
||||||
current_window="$(xdotool getactivewindow)"
|
current_window="$(xdotool getactivewindow)"
|
||||||
|
@ -3043,10 +3043,10 @@ display_image() {
|
||||||
|
|
||||||
"iterm2")
|
"iterm2")
|
||||||
image="$(base64 < "$image")"
|
image="$(base64 < "$image")"
|
||||||
iterm_cmd="\\e]1337;File=width=${width}px;height=${height}px;inline=1:${image}"
|
iterm_cmd="\e]1337;File=width=${width}px;height=${height}px;inline=1:${image}"
|
||||||
|
|
||||||
# Tmux requires an additional escape sequence for this to work.
|
# Tmux requires an additional escape sequence for this to work.
|
||||||
[[ -n "$TMUX" ]] && iterm_cmd="\\ePtmux;\\e${iterm_cmd}\\e\\"
|
[[ -n "$TMUX" ]] && iterm_cmd="\ePtmux;\e${iterm_cmd}\e\\"
|
||||||
|
|
||||||
printf "%b\a\n" "$iterm_cmd"
|
printf "%b\a\n" "$iterm_cmd"
|
||||||
;;
|
;;
|
||||||
|
@ -3082,7 +3082,7 @@ to_ascii() {
|
||||||
get_ascii
|
get_ascii
|
||||||
|
|
||||||
# Set cursor position next image/ascii.
|
# Set cursor position next image/ascii.
|
||||||
printf "%b" "\\e[${lines:-0}A\\e[9999999D"
|
printf "%b" "\e[${lines:-0}A\e[9999999D"
|
||||||
}
|
}
|
||||||
|
|
||||||
to_off() {
|
to_off() {
|
||||||
|
@ -3242,7 +3242,7 @@ prin() {
|
||||||
string="${2:-$1}"
|
string="${2:-$1}"
|
||||||
local subtitle_color="$info_color"
|
local subtitle_color="$info_color"
|
||||||
fi
|
fi
|
||||||
string="$(trim "${string//$'\\e[0m'}")"
|
string="$(trim "${string//$'\e[0m'}")"
|
||||||
|
|
||||||
# Log length if it doesn't exist.
|
# Log length if it doesn't exist.
|
||||||
if [[ -z "$length" ]]; then
|
if [[ -z "$length" ]]; then
|
||||||
|
@ -3255,7 +3255,7 @@ prin() {
|
||||||
string="${subtitle_color}${bold}${string}"
|
string="${subtitle_color}${bold}${string}"
|
||||||
|
|
||||||
# Print the info.
|
# Print the info.
|
||||||
printf "%b\n" "${text_padding:+\\e[${text_padding}C}${zws}${string}${reset} "
|
printf "%b\n" "${text_padding:+\e[${text_padding}C}${zws}${string}${reset} "
|
||||||
|
|
||||||
# Calculate info height.
|
# Calculate info height.
|
||||||
((++info_height))
|
((++info_height))
|
||||||
|
@ -3267,7 +3267,7 @@ prin() {
|
||||||
get_underline() {
|
get_underline() {
|
||||||
if [[ "$underline_enabled" == "on" ]]; then
|
if [[ "$underline_enabled" == "on" ]]; then
|
||||||
printf -v underline "%${length}s"
|
printf -v underline "%${length}s"
|
||||||
printf "%b%b\n" "${text_padding:+\\e[${text_padding}C}${zws}${underline_color}" \
|
printf "%b%b\n" "${text_padding:+\e[${text_padding}C}${zws}${underline_color}" \
|
||||||
"${underline// /$underline_char}${reset} "
|
"${underline// /$underline_char}${reset} "
|
||||||
unset -v length
|
unset -v length
|
||||||
fi
|
fi
|
||||||
|
@ -3288,12 +3288,12 @@ get_line_break() {
|
||||||
|
|
||||||
get_bold() {
|
get_bold() {
|
||||||
case "$ascii_bold" in
|
case "$ascii_bold" in
|
||||||
"on") ascii_bold="\\e[1m" ;;
|
"on") ascii_bold="\e[1m" ;;
|
||||||
"off") ascii_bold="" ;;
|
"off") ascii_bold="" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
case "$bold" in
|
case "$bold" in
|
||||||
"on") bold="\\e[1m" ;;
|
"on") bold="\e[1m" ;;
|
||||||
"off") bold="" ;;
|
"off") bold="" ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
@ -3313,10 +3313,10 @@ trim_quotes() {
|
||||||
}
|
}
|
||||||
|
|
||||||
strip_sequences() {
|
strip_sequences() {
|
||||||
strip="${1//$'\\e['3[0-9]m}"
|
strip="${1//$'\e['3[0-9]m}"
|
||||||
strip="${strip//$'\\e['38\;5\;[0-9]m}"
|
strip="${strip//$'\e['38\;5\;[0-9]m}"
|
||||||
strip="${strip//$'\\e['38\;5\;[0-9][0-9]m}"
|
strip="${strip//$'\e['38\;5\;[0-9][0-9]m}"
|
||||||
strip="${strip//$'\\e['38\;5\;[0-9][0-9][0-9]m}"
|
strip="${strip//$'\e['38\;5\;[0-9][0-9][0-9]m}"
|
||||||
|
|
||||||
printf "%s\n" "$strip"
|
printf "%s\n" "$strip"
|
||||||
}
|
}
|
||||||
|
@ -4175,9 +4175,9 @@ set_text_colors() {
|
||||||
|
|
||||||
color() {
|
color() {
|
||||||
case "$1" in
|
case "$1" in
|
||||||
[0-6]) printf "%b" "${reset}\\e[3${1}m" ;;
|
[0-6]) printf "%b" "${reset}\e[3${1}m" ;;
|
||||||
7 | "fg") printf "%b" "\\e[37m${reset}" ;;
|
7 | "fg") printf "%b" "\e[37m${reset}" ;;
|
||||||
*) printf "%b" "\\e[38;5;${1}m" ;;
|
*) printf "%b" "\e[38;5;${1}m" ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4200,7 +4200,7 @@ stdout() {
|
||||||
}
|
}
|
||||||
|
|
||||||
err() {
|
err() {
|
||||||
err+="$(color 1)[!]\\e[0m $1\n"
|
err+="$(color 1)[!]\e[0m $1\n"
|
||||||
}
|
}
|
||||||
|
|
||||||
get_full_path() {
|
get_full_path() {
|
||||||
|
@ -4384,7 +4384,7 @@ dynamic_prompt() {
|
||||||
if ((lines > 1)); then
|
if ((lines > 1)); then
|
||||||
case "$kernel_name" in
|
case "$kernel_name" in
|
||||||
"OpenBSD") tput cud "$lines" ;;
|
"OpenBSD") tput cud "$lines" ;;
|
||||||
*) printf "%b" "\\e[${lines}B" ;;
|
*) printf "%b" "\e[${lines}B" ;;
|
||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
@ -5037,10 +5037,10 @@ main() {
|
||||||
# Minix doesn't support these sequences.
|
# Minix doesn't support these sequences.
|
||||||
if [[ "$TERM" != "minix" && "$stdout" != "on" ]]; then
|
if [[ "$TERM" != "minix" && "$stdout" != "on" ]]; then
|
||||||
# If the script exits for any reason, unhide the cursor.
|
# If the script exits for any reason, unhide the cursor.
|
||||||
trap 'printf "\\e[?25h\\e[?7h"' EXIT
|
trap 'printf "\e[?25h\e[?7h"' EXIT
|
||||||
|
|
||||||
# Hide the cursor and disable line wrap.
|
# Hide the cursor and disable line wrap.
|
||||||
printf "\\e[?25l\\e[?7l"
|
printf "\e[?25l\e[?7l"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
image_backend
|
image_backend
|
||||||
|
|
Loading…
Reference in a new issue