aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xfunctions/utilities.zsh36
-rwxr-xr-xpowerlevel9k.zsh-theme78
2 files changed, 52 insertions, 62 deletions
diff --git a/functions/utilities.zsh b/functions/utilities.zsh
index 88470885..56fcdc59 100755
--- a/functions/utilities.zsh
+++ b/functions/utilities.zsh
@@ -45,34 +45,18 @@ function _p9k_g_expand() {
typeset -g $1=${(g::)${(P)1}}
}
-# Converts large memory values into a human-readable unit (e.g., bytes --> GB)
-# Takes two arguments:
-# * $size - The number which should be prettified
-# * $base - The base of the number (default Bytes)
-printSizeHumanReadable() {
- typeset -F 2 size
- size="$1"+0.00001
- local extension
- extension=('B' 'K' 'M' 'G' 'T' 'P' 'E' 'Z' 'Y')
- local index=1
+typeset -g _P9K_BYTE_SUFFIX=('B' 'K' 'M' 'G' 'T' 'P' 'E' 'Z' 'Y')
- # if the base is not Bytes
- if [[ -n $2 ]]; then
- local idx
- for idx in "${extension[@]}"; do
- if [[ "$2" == "$idx" ]]; then
- break
- fi
- index=$(( index + 1 ))
- done
- fi
-
- while (( (size / 1024) > 0.1 )); do
- size=$(( size / 1024 ))
- index=$(( index + 1 ))
+# 42 => 42B
+# 1536 => 1.5K
+function _p9k_human_readable_bytes() {
+ typeset -F 2 n=$1
+ local suf
+ for suf in $_P9K_BYTE_SUFFIX; do
+ (( n < 100 )) && break
+ (( n /= 1024 ))
done
-
- echo "$size${extension[$index]}"
+ _P9K_RETVAL=$n$suf
}
# Determine if the passed segment is used in the prompt
diff --git a/powerlevel9k.zsh-theme b/powerlevel9k.zsh-theme
index 829bff28..6dd8e6c2 100755
--- a/powerlevel9k.zsh-theme
+++ b/powerlevel9k.zsh-theme
@@ -1279,26 +1279,30 @@ prompt_php_version() {
################################################################
# Segment to display free RAM and used Swap
prompt_ram() {
- local ROOT_PREFIX="${4}"
- local base=''
- local ramfree=0
- if [[ "$OS" == "OSX" ]]; then
- # Available = Free + Inactive
- # See https://support.apple.com/en-us/HT201538
- ramfree=$(vm_stat | grep "Pages free" | grep -o -E '[0-9]+')
- ramfree=$((ramfree + $(vm_stat | grep "Pages inactive" | grep -o -E '[0-9]+')))
- # Convert pages into Bytes
- ramfree=$(( ramfree * 4096 ))
- else
- if [[ "$OS" == "BSD" ]]; then
- ramfree=$(grep 'avail memory' ${ROOT_PREFIX}/var/run/dmesg.boot | awk '{print $4}')
- else
- ramfree=$(grep -o -E "MemAvailable:\s+[0-9]+" ${ROOT_PREFIX}/proc/meminfo | grep -o -E "[0-9]+")
- base='K'
- fi
- fi
+ local -F free_bytes
+
+ case $OS in
+ OSX)
+ (( $+commands[vm_stat] )) || return
+ local stat && stat=$(command vm_stat 2>/dev/null) || return
+ [[ $stat =~ 'Pages free:[[:space:]]+([0-9]+)' ]] || return
+ (( free_bytes+=match[1] ))
+ [[ $stat =~ 'Pages inactive:[[:space:]]+([0-9]+)' ]] || return
+ (( free_bytes+=match[1] ))
+ (( free_bytes *= 4096 ))
+ ;;
+ BSD)
+ local stat && stat=$(command grep -F 'avail memory' /var/run/dmesg.boot 2>/dev/null) || return
+ free_bytes=${${(A)=stat}[4]}
+ ;;
+ *)
+ local stat && stat=$(command grep -F MemAvailable /proc/meminfo 2>/dev/null) || return
+ free_bytes=$(( ${${(A)=stat}[2]} * 1024 ))
+ ;;
+ esac
- "$1_prompt_segment" "$0" "$2" "yellow" "$DEFAULT_COLOR" 'RAM_ICON' 0 '' "$(printSizeHumanReadable "$ramfree" $base)"
+ _p9k_human_readable_bytes $free_bytes
+ $1_prompt_segment $0 $2 yellow "$DEFAULT_COLOR" RAM_ICON 0 '' $_P9K_RETVAL
}
function _p9k_read_rbenv_version_file() {
@@ -1505,28 +1509,30 @@ prompt_status() {
################################################################
# Segment to display Swap information
prompt_swap() {
- local ROOT_PREFIX="${4}"
- local swap_used=0
- local base=''
+ local -F used_bytes
if [[ "$OS" == "OSX" ]]; then
- local raw_swap_used
- raw_swap_used=$(sysctl vm.swapusage | grep -o "used\s*=\s*[0-9,.A-Z]*" | grep -o "[0-9,.A-Z]*$")
-
- typeset -F 2 swap_used
- swap_used=${$(echo $raw_swap_used | grep -o "[0-9,.]*")//,/.}
- # Replace comma
- swap_used=${swap_used//,/.}
-
- base=$(echo "$raw_swap_used" | grep -o "[A-Z]*$")
+ (( $+commands[sysctl] )) || return
+ [[ "$(sysctl vm.swapusage)" =~ "used = ([0-9,.]+)([A-Z]+)" ]] || return
+ used_bytes=${match[1]//,/.}
+ case ${match[2]} in
+ K) (( used_bytes *= 1024 ));;
+ M) (( used_bytes *= 1048576 ));;
+ G) (( used_bytes *= 1073741824 ));;
+ T) (( used_bytes *= 1099511627776 ));;
+ *) return;;
+ esac
else
- swap_total=$(grep -o -E "SwapTotal:\s+[0-9]+" ${ROOT_PREFIX}/proc/meminfo | grep -o -E "[0-9]+")
- swap_free=$(grep -o -E "SwapFree:\s+[0-9]+" ${ROOT_PREFIX}/proc/meminfo | grep -o -E "[0-9]+")
- swap_used=$(( swap_total - swap_free ))
- base='K'
+ local meminfo && meminfo=$(command grep -F 'Swap' /proc/meminfo) || return
+ [[ $meminfo =~ 'SwapTotal:[[:space:]]+([0-9]+)' ]] || return
+ (( used_bytes+=match[1] ))
+ [[ $meminfo =~ 'SwapFree:[[:space:]]+([0-9]+)' ]] || return
+ (( used_bytes-=match[1] ))
+ (( used_bytes *= 1024 ))
fi
- "$1_prompt_segment" "$0" "$2" "yellow" "$DEFAULT_COLOR" 'SWAP_ICON' 0 '' "$(printSizeHumanReadable "$swap_used" $base)"
+ _p9k_human_readable_bytes $used_bytes
+ $1_prompt_segment $0 $2 yellow "$DEFAULT_COLOR" SWAP_ICON 0 '' $_P9K_RETVAL
}
################################################################