This repository has been archived on 2024-11-03. You can view files and clone it, but cannot push or open issues or pull requests.
neofetch/neofetch

2868 lines
75 KiB
Plaintext
Raw Normal View History

2016-01-04 02:09:23 +00:00
#!/usr/bin/env bash
# vim: fdm=marker:noai:ts=4:sw=4
2016-01-29 15:14:29 +00:00
#
2016-02-28 00:44:45 +00:00
# Neofetch info about your system
# https://github.com/dylanaraps/neofetch
2015-12-30 10:18:17 +00:00
#
2016-01-22 07:04:53 +00:00
# Required Dependencies:
# Bash 3.0+
2016-02-17 06:29:01 +00:00
# xprop
2016-01-22 07:04:53 +00:00
# [Linux / BSD / Windows] Uptime detection: procps or procps-ng
#
2015-12-31 00:21:10 +00:00
# Optional Dependencies: (You'll lose these features without them)
2016-01-04 23:24:41 +00:00
# Displaying Images: w3m + w3m-img
2015-12-30 10:18:17 +00:00
# Image Cropping: ImageMagick
# [ Linux / BSD ] Wallpaper Display: feh, nitrogen or gsettings
2016-03-11 04:20:34 +00:00
# [ Linux / BSD ] Current Song: mpc, cmus, moc
# [ Linux ] Current Song: spotify
2016-01-22 07:04:53 +00:00
# [ Linux / BSD ] Resolution detection: xorg-xdpyinfo
2015-12-30 10:18:17 +00:00
#
# Created by Dylan Araps
2016-01-05 04:02:24 +00:00
# https://github.com/dylanaraps/
2015-12-30 10:18:17 +00:00
2016-02-23 22:30:11 +00:00
version=${BASH_VERSION/.*}
2016-02-10 11:54:07 +00:00
SYS_LOCALE="$LANG"
2016-02-23 22:30:11 +00:00
# Speed up script by not using unicode
export LC_ALL=C
export LANG=C
2016-01-06 07:34:34 +00:00
# Config Options {{{
# Info Options {{{
2016-01-06 07:34:34 +00:00
# Info
2016-01-20 22:49:50 +00:00
# See this wiki page for more info:
2016-02-28 00:44:45 +00:00
# https://github.com/dylanaraps/neofetch/wiki/Customizing-Info
printinfo () {
info title
info underline
info "OS" distro
info "Kernel" kernel
info "Uptime" uptime
info "Packages" packages
info "Shell" shell
info "Resolution" resolution
info "Desktop Environment" de
info "Window Manager" wm
info "Theme" theme
info "Icons" icons
info "CPU" cpu
info "GPU" gpu
info "Memory" memory
2016-03-18 23:58:03 +00:00
# info "Font" font
# info "Disk" disk
# info "Battery" battery
# info "Song" song
# info "Local IP" localip
2016-02-24 05:50:09 +00:00
# info "Public IP" publicip
# info "Users" users
2016-01-30 12:35:52 +00:00
# info "Birthday" birthday
info linebreak
info cols
info linebreak
info linebreak
}
2016-01-05 04:02:24 +00:00
# Kernel
# Show more kernel info
# --kernel_shorthand on/off
kernel_shorthand="on"
2016-01-28 01:44:06 +00:00
# Distro
2016-01-28 01:44:06 +00:00
# Mac OS X hide/show build version
# --osx_buildversion on/off
osx_buildversion="on"
2016-01-05 04:02:24 +00:00
# Mac OS X hide/show codename
# --osx_codename on/off
osx_codename="on"
# Show 'x86_64' and 'x86' in 'Distro:' output.
# --os_arch on/off
os_arch="on"
2016-01-05 04:02:24 +00:00
# Uptime
# Shorten the output of the uptime function
# --uptime_shorthand tiny, on, off
uptime_shorthand="off"
# Shell
# Show the path to $SHELL
# --shell_path on/off
shell_path="on"
# Show $SHELL's version
# --shell_version on/off
shell_version="off"
# CPU
# CPU speed type
2016-01-19 11:30:17 +00:00
# Only works on Linux with cpufreq.
2016-01-24 21:58:56 +00:00
# --speed_type current, min, max, bios,
# scaling_current, scaling_min, scaling_max
speed_type="max"
2016-03-12 20:58:46 +00:00
# CPU Display
# Set shorthand setting and progress bar setting
# --cpu_display (name, speed, tiny, on, off) (bar, infobar, barinfo, off)
cpu_shorthand="off"
cpu_display="off"
2016-03-15 07:55:35 +00:00
# CPU Cores
# Display CPU cores in output
# --cpu_cores on/off
cpu_cores="on"
# GPU
# Shorten output of the getgpu funcion
# --gpu_shorthand on/off/tiny
2016-02-10 22:20:03 +00:00
gpu_shorthand="on"
# Gtk Theme / Icons
# Shorten output (Hide [GTK2] etc)
# --gtk_shorthand on/off
gtk_shorthand="off"
# Enable/Disable gtk2 theme/icons output
# --gtk2 on/off
gtk2="on"
# Enable/Disable gtk3 theme/icons output
# --gtk3 on/off
gtk3="on"
# Battery
# Which battery to display.
# By default we display all batteries.
# NOTE: Only works on Linux.
# --battery_num all, 0, 1, 2, etc
battery_num="all"
# Whether or not to print each battery on the same line.
# By default each battery gets its own line and title.
# NOTE: Only works on Linux.
# --battery_shorthand on/off
battery_shorthand="off"
# IP Address
# Website to ping for the public IP
# --ip_host url
public_ip_host="http://ident.me"
# Song
# Print the Artist and Title on seperate lines
# --song_shorthand on/off
song_shorthand="off"
2016-01-30 11:41:58 +00:00
# Birthday
# Whether to show a long pretty output
# or a shortened one
2016-01-31 00:02:32 +00:00
# NOTE: Long pretty output doesn't work on OpenBSD or NetBSD.
2016-01-30 11:41:58 +00:00
# --birthday_shorthand on/off
birthday_shorthand="off"
# Whether to show the time in the output
# --birthday_time on/off
birthday_time="on"
# Date format to use when printing birthday
# --birthday_format "format"
birthday_format="%a %d %b %Y %l:%M %p"
# Color Blocks
2015-12-30 10:18:17 +00:00
# Color block range
# --block_range start end
start=0
end=7
2015-12-30 10:18:17 +00:00
# Toggle color blocks
# --color_blocks on/off
color_blocks="on"
2015-12-30 10:18:17 +00:00
# Color block width
# --color_block_width num
2016-01-03 08:55:09 +00:00
block_width=3
2015-12-30 10:18:17 +00:00
# }}}
# Text Colors {{{
2015-12-30 10:18:17 +00:00
2016-02-23 05:52:25 +00:00
# Text Colors
# Each number represents a different part of
# the text in this order:
# title, @, underline, subtitle, colon, info
# colors=(4 6 1 8 8 6)
colors=(distro)
2015-12-30 10:18:17 +00:00
# }}}
# Text Options {{{
# Toggle line wrapping
# --line_wrap on/off
line_wrap="on"
# Toggle bold text
# --bold on/off
bold="on"
# Enable/Disable Underline
# --underline on/off
underline="on"
# Underline character
# --underline_char char
underline_char="-"
2015-12-30 10:18:17 +00:00
# Prompt height
# You should only have to change this if your
# prompt is greater than 2 lines high.
# --prompt_height num
prompt_height=1
2015-12-30 10:18:17 +00:00
2016-03-02 23:12:21 +00:00
# }}}
# Progress Bars {{{
# Progress bar character
# --progress_char char
progress_char="━"
# Progress bar length in spaces
# Number of chars long to make the progress bars.
# --progress_length num
progress_length="15"
2016-03-02 23:12:21 +00:00
# Progress bar colors
# --progress_colors col col
progress_color_elapsed="6"
progress_color_total="8"
2016-03-12 21:37:33 +00:00
# Customize how the info is displayed.
# bar: Only the progress bar is displayed.
# infobar: The bar is displayed after the info.
# barinfo: The bar is displayed before the info.
# off: Only the info is displayed.
#
# --memory_display bar/infobar/barinfo/off
# --battery_display bar/infobar/barinfo/off
# --disk_display bar/infobar/barinfo/off
2016-03-12 20:58:46 +00:00
memory_display="off"
battery_display="off"
disk_display="off"
2015-12-30 10:18:17 +00:00
# }}}
# Image Options {{{
# Image Source
# --image wall, ascii, /path/to/img, /path/to/dir/, off
image="wall"
2016-01-28 09:11:18 +00:00
# Thumbnail directory
2016-02-28 00:44:45 +00:00
thumbnail_dir="$HOME/.cache/thumbnails/neofetch"
# Image Backend
# Which program to draw images with
# --image_backend w3m, iterm2
image_backend="w3m"
# W3m-img path
# Some systems have this in another location
w3m_img_path="/usr/lib/w3m/w3mimgdisplay"
# Image position
# Only works with the w3m backend
# --image_position left/right
image_position="left"
# Crop mode
# --crop_mode normal/fit/fill
crop_mode="normal"
2015-12-31 22:33:08 +00:00
# Crop offset
# Only affects normal mode.
# --crop_offset northwest/north/northeast/west/center
# east/southwest/south/southeast
crop_offset="center"
2015-12-31 00:21:10 +00:00
# Image size
# The image is half the terminal width by default.
2016-02-24 01:19:55 +00:00
# --size auto, 00px, 00%
image_size="auto"
# Right gap between image and text
# --gap num
2016-03-10 03:36:49 +00:00
gap=2
2015-12-31 00:21:10 +00:00
# Image offsets
# --xoffset px
# --yoffset px
2015-12-30 10:18:17 +00:00
yoffset=0
xoffset=0
2016-01-27 11:33:22 +00:00
# }}}
# Ascii Options {{{
# Default ascii image to use
# When this is set to distro it will use your
# distro's logo as the ascii.
# --ascii 'distro', path/to/ascii
ascii="distro"
2016-01-27 11:33:22 +00:00
# Ascii colors
# When this is set to distro it will use your
# ditro's colors to color the ascii.
# NOTE: You can also set this to a range of colors
# which will allow you to custom color distro logos
# --ascii_colors distro
# --ascii_colors 2 4 5 6
ascii_colors=(distro)
2016-01-27 11:33:22 +00:00
# Logo size
# Arch, Crux and Gentoo have a smaller logo
# variant. Changing the value below to 'small'
# will make neofetch use the small logo.
# --ascii_logo_size small, normal
ascii_logo_size="normal"
2016-01-27 11:33:22 +00:00
# }}}
2015-12-30 10:18:17 +00:00
2016-01-29 15:14:29 +00:00
# Scrot Options {{{
# Whether or not to always take a screenshot
# You can manually take a screenshot with "--scrot" or "-s"
scrot="off"
# Screenshot program to launch
# --scrot_cmd
scrot_cmd="scrot -c -d 3"
# Scrot dir
# Where to save the screenshots
# --scrot_dir /path/to/screenshot/folder
2016-03-18 22:37:29 +00:00
scrot_dir="$HOME/Pictures/"
# Scrot filename
# What to name the screenshots
# --scrot_name str
2016-03-18 22:37:29 +00:00
scrot_name="neofetch-$(date +%F-%T).png"
# }}}
# Stdout options {{{
# Separator for stdout mode
# --stdout_separator string
stdout_separator=" "
2016-01-29 15:14:29 +00:00
# }}}
# Config Options {{{
# Enable/Disable config file
2016-01-31 21:00:20 +00:00
# --config off, none
config="on"
2016-01-30 00:09:36 +00:00
# Path to custom config file location
2016-01-29 15:14:29 +00:00
# --config path/to/config
2016-02-28 00:44:45 +00:00
config_file="$HOME/.config/neofetch/config"
2016-01-29 15:14:29 +00:00
# }}}
2015-12-30 10:18:17 +00:00
# }}}
# Gather Info {{{
2015-12-30 10:18:17 +00:00
# Set no case match
shopt -s nocasematch
# Operating System {{{
case "$(uname)" in
2016-02-20 21:21:55 +00:00
"Linux") os="Linux" ;;
"Darwin") os="Mac OS X" ;;
"OpenBSD") os="OpenBSD" ;;
*"BSD") os="BSD" ;;
"CYGWIN"*) os="Windows" ;;
*) printf "%s\n" "Unknown OS detected: $(uname)"; exit 1 ;;
esac
2015-12-30 10:18:17 +00:00
# }}}
# Distro {{{
# Default bit style
x64="x86_64"
x32="x86"
case "$os" in
"Linux" )
if type -p lsb_release >/dev/null 2>&1; then
2016-02-15 01:39:02 +00:00
distro="$(lsb_release -d 2>/dev/null | awk -F':' '/Description/ {printf $2}')"
distro=${distro/[[:space:]]}
2016-02-15 01:39:02 +00:00
elif type -p crux >/dev/null 2>&1; then
distro="$(crux)"
2016-02-16 10:54:21 +00:00
else
distro="$(grep -h '^NAME=' /etc/*ease)"
2016-02-13 10:14:50 +00:00
# Workaround for distros that store the value differently.
2016-02-13 08:29:08 +00:00
[ -z "$distro" ] && distro="$(grep -h 'TAILS_PRODUCT_NAME' /etc/*ease)"
2016-02-13 10:14:50 +00:00
[ -z "$distro" ] && distro="$(awk '/BLAG/ {print $1; exit}' /etc/*ease)"
2016-02-13 08:29:08 +00:00
distro=${distro/*NAME\=}
2016-02-16 10:54:21 +00:00
distro=${distro//\"}
fi
;;
"Mac OS X")
2016-03-13 11:49:37 +00:00
osx_version=$(sw_vers -productVersion)
2016-03-15 06:15:56 +00:00
osx_build=$(sw_vers -buildVersion)
2016-03-13 11:49:37 +00:00
2016-03-13 12:35:43 +00:00
case "${osx_version%.*}" in
2016-03-13 12:23:10 +00:00
"10.4") codename="Mac OS X Tiger" ;;
"10.5") codename="Mac OS X Leopard" ;;
"10.6") codename="Mac OS X Snow Leopard" ;;
"10.7") codename="Mac OS X Lion" ;;
"10.8") codename="OS X Mountain Lion" ;;
"10.9") codename="OS X Mavericks" ;;
"10.10") codename="OS X Yosemite" ;;
"10.11") codename="OS X El Capitan" ;;
*) codename="Mac OS X" ;;
2016-03-13 11:49:37 +00:00
esac
2016-03-15 06:15:56 +00:00
distro="$codename $osx_version $osx_build"
;;
"OpenBSD")
distro="OpenBSD"
;;
"BSD")
distro="$(uname -v)"
distro=${distro%% *}
;;
2016-01-18 23:42:41 +00:00
"Windows")
distro="$(wmic os get Caption /value)"
# Strip crap from the output of wmic
2016-01-31 21:42:12 +00:00
distro=${distro/Caption'='}
distro=${distro//[[:space:]]/ }
distro=${distro// }
distro=${distro/Microsoft }
# Change bits to xx-bit for Windows
x64="64-bit"
x32="32-bit"
;;
2016-01-05 05:32:34 +00:00
*)
distro="Unknown"
;;
esac
ascii_distro="$distro"
getdistro () {
# Get architecture
if [ "$os_arch" == "on" ]; then
case "$(getconf LONG_BIT)" in
64) distro+=" $x64" ;;
32) distro+=" $x32" ;;
esac
fi
}
# }}}
# Title {{{
gettitle () {
title="${USER}@$(hostname)"
}
2015-12-30 10:18:17 +00:00
# }}}
# Kernel {{{
getkernel() {
case "$kernel_shorthand" in
"on") kernel="$(uname -r)" ;;
"off") kernel="$(uname -srm)" ;;
esac
}
2015-12-30 10:18:17 +00:00
# }}}
# Uptime {{{
getuptime () {
case "$os" in
"Linux")
2016-02-08 20:49:42 +00:00
case "$distro" in
2016-03-09 11:43:52 +00:00
"Puppy Linux"* | "Quirky Werewolf"* | "Precise Puppy"* | "Alpine Linux"*)
2016-02-08 20:49:42 +00:00
uptime=$(uptime | awk -F ':[0-9]{2}+ |(, ){1}+' '{printf $2}')
uptime=${uptime/ / }
2016-02-08 22:02:07 +00:00
;;
"openSUSE"*)
uptime=$(uptime | awk -F ':[0-9]{2}+[a-z][a-z] |(, ){1}+' '{printf $2}')
uptime=${uptime/ / }
2016-02-08 20:49:42 +00:00
;;
*)
uptime="$(uptime -p)"
2016-02-14 13:56:02 +00:00
[ "$uptime" == "up " ] && uptime="up $(awk -F'.' '{print $1}' /proc/uptime) seconds"
2016-02-08 20:49:42 +00:00
;;
esac
;;
2016-01-19 06:33:41 +00:00
"Mac OS X" | *"BSD")
2016-01-06 00:00:20 +00:00
# Get boot time in seconds
2016-01-04 04:30:14 +00:00
boot="$(sysctl -n kern.boottime)"
boot="${boot/'{ sec = '}"
2016-01-04 04:30:14 +00:00
boot=${boot/,*}
# Get current date in seconds
now=$(date +%s)
uptime=$((now - boot))
2016-01-04 04:30:14 +00:00
# Convert uptime to days/hours/mins
mins=$((uptime / 60%60))
hours=$((uptime / 3600%24))
days=$((uptime / 86400))
2016-01-04 04:30:14 +00:00
# Format the output like Linux's "uptime -p" cmd.
if [ "$mins" == 1 ]; then
2016-03-25 23:04:23 +00:00
mins+=" minute"
elif [ "$mins" != 0 ]; then
2016-03-25 23:04:23 +00:00
mins+=" minutes"
fi
if [ "$hours" == 1 ]; then
2016-03-25 23:04:23 +00:00
hours+=" hour,"
elif [ "$mins" != 0 ]; then
2016-03-25 23:04:23 +00:00
hours+=" hours,"
fi
if [ "$days" == 1 ]; then
2016-03-25 23:04:23 +00:00
days+=" day,"
elif [ "$days" != 0 ]; then
2016-03-25 23:04:23 +00:00
days+=" days,"
fi
2016-03-25 23:04:23 +00:00
uptime="up $days $hours $mins"
;;
2016-01-05 05:32:34 +00:00
"Windows")
uptime=$(uptime | awk -F ':[0-9]{2}+ |(, ){1}+' '{printf $2}')
2016-01-18 23:45:56 +00:00
uptime=${uptime/ / }
2016-01-05 05:32:34 +00:00
;;
*)
uptime="Unknown"
;;
2015-12-30 10:18:17 +00:00
esac
# Make the output of uptime smaller.
case "$uptime_shorthand" in
"on")
uptime=${uptime/up}
uptime=${uptime/minutes/mins}
uptime=${uptime/minute/min}
uptime=${uptime/seconds/secs}
uptime=${uptime# }
;;
"tiny")
uptime=${uptime/up}
uptime=${uptime/ days/d}
uptime=${uptime/ day/d}
uptime=${uptime/ hours/h}
uptime=${uptime/ hour/h}
uptime=${uptime/ minutes/m}
uptime=${uptime/ minute/m}
uptime=${uptime/ seconds/s}
uptime=${uptime/,}
uptime=${uptime# }
;;
esac
2015-12-30 10:18:17 +00:00
}
# }}}
# Package Count {{{
getpackages () {
case "$os" in
"Linux")
if type -p dpkg >/dev/null 2>&1; then
packages="$(dpkg --get-selections | grep -cv deinstall$)"
elif type -p pacman >/dev/null 2>&1; then
packages="$(pacman -Qq --color never | wc -l)"
2016-02-15 11:59:28 +00:00
elif type -p /sbin/pkgtool >/dev/null 2>&1; then
2016-02-16 04:21:45 +00:00
packages="$(ls -1 /var/log/packages | wc -l)"
elif type -p rpm >/dev/null 2>&1; then
packages="$(rpm -qa | wc -l)"
2016-02-14 22:28:51 +00:00
elif type -p xbps-query >/dev/null 2>&1; then
packages="$(xbps-query -l | wc -l)"
elif type -p pkginfo >/dev/null 2>&1; then
packages="$(pkginfo -i | wc -l)"
elif type -p pisi >/dev/null 2>&1; then
packages="$(pisi list-installed | wc -l)"
elif type -p pkg >/dev/null 2>&1; then
packages="$(ls -1 /var/db/pkg | wc -l)"
2015-12-30 10:18:17 +00:00
elif type -p emerge >/dev/null 2>&1; then
packages="$(ls -d /var/db/pkg/*/* | wc -l)"
2015-12-30 10:18:17 +00:00
elif type -p nix-env >/dev/null 2>&1; then
packages="$(ls -d -1 /nix/store/*/ | wc -l)"
2016-03-09 11:43:52 +00:00
elif type -p apk >/dev/null 2>&1; then
packages="$(apk info | wc -l)"
elif type -p pacman-g2 >/dev/null 2>&1; then
packages="$(pacman-g2 -Q | wc -l)"
2016-02-16 05:31:55 +00:00
elif type -p cave >/dev/null 2>&1; then
cross_packages=$(ls -d -1 /var/db/paludis/repositories/cross-installed/*/data/* | wc -l)
packages=$(ls -d -1 /var/db/paludis/repositories/installed/data/* | wc -l)
packages=$((packages + cross_packages))
fi
2016-02-14 08:42:27 +00:00
;;
"Mac OS X")
if [ -d "/usr/local/bin" ]; then
local_packages=$(ls -l /usr/local/bin/ | grep -v "\(../Cellar/\|brew\)" | wc -l)
packages=$((local_packages - 1))
fi
if type -p port >/dev/null 2>&1; then
port_packages=$(port installed 2>/dev/null | wc -l)
packages=$((packages + $((port_packages - 1))))
fi
if type -p brew >/dev/null 2>&1; then
brew_packages=$(brew list -1 2>/dev/null | wc -l)
packages=$((packages + brew_packages))
fi
if type -p pkgin >/dev/null 2>&1; then
pkgsrc_packages=$(pkgin list 2>/dev/null | wc -l)
packages=$((packages + pkgsrc_packages))
fi
;;
*"BSD")
if type -p pkg_info >/dev/null 2>&1; then
packages=$(pkg_info | wc -l)
2016-01-18 05:22:21 +00:00
elif type -p pkg >/dev/null 2>&1; then
packages=$(pkg info | wc -l)
fi
;;
"Windows")
2016-01-05 05:32:34 +00:00
packages=$(cygcheck -cd | wc -l)
# Count chocolatey packages
if [ -d "/cygdrive/c/ProgramData/chocolatey/lib" ]; then
choco_packages=$(ls -1 /cygdrive/c/ProgramData/chocolatey/lib | wc -l)
packages=$((packages + choco_packages))
fi
2016-01-05 05:32:34 +00:00
;;
esac
2016-01-18 23:44:25 +00:00
packages=${packages// }
[ -z "$packages" ] && packages="Unknown"
}
# }}}
# Shell {{{
getshell () {
case "$shell_path" in
"on") shell="$SHELL" ;;
"off") shell="${SHELL##*/}" ;;
esac
if [ "$shell_version" == "on" ]; then
shell+=" "
case "$shell" in
*"bash"*)
shell+="$(bash --version | head -n 1)"
shell=${shell/ *, version}
;;
*"zsh"*)
shell+="$(zsh --version)"
shell=${shell/ zsh}
;;
2016-01-29 04:40:52 +00:00
*"mksh"* | *"ksh")
shell+="$("$SHELL" -c 'printf "%s" "$KSH_VERSION"')"
shell=${shell/ * KSH}
;;
2016-01-29 04:40:52 +00:00
*"tcsh"* | *"csh"*)
shell+="$("$SHELL" --version)"
shell=${shell/tcsh}
shell=${shell/\(*}
;;
esac
shell="${shell/\(*\)}"
fi
}
# }}}
# Desktop Environment {{{
getde () {
[ "$XDG_CURRENT_DESKTOP" != "i3" ] && de="$XDG_CURRENT_DESKTOP"
}
# }}}
# Window Manager {{{
getwm () {
2016-02-20 20:08:50 +00:00
if [ -n "$DISPLAY" ] && [ "$os" != "Mac OS X" ]; then
2016-02-24 04:04:08 +00:00
id="$(xprop -root -notype | awk '$1=="_NET_SUPPORTING_WM_CHECK:"{print $5}')"
2016-02-17 05:54:18 +00:00
wm="$(xprop -id "$id" -notype -f _NET_WM_NAME 8t)"
wm=${wm/*_NET_WM_NAME = }
wm=${wm/\"}
wm=${wm/\"*}
# Fallback for Wayland wms
case "$wm" in
"xwlc")
wm="$(ps -e | grep -m 1 -oE "sway|orbment|velox|orbital")"
[ "$version" -ge 4 ] && wm=${wm^}
;;
esac
else
case "$os" in
"Mac OS X") wm="Quartz Compositor" ;;
"Windows") wm="Explorer" ;;
esac
fi
2015-12-31 00:21:10 +00:00
}
2015-12-30 10:18:17 +00:00
# }}}
# CPU {{{
getcpu () {
case "$os" in
"Linux")
2016-01-05 04:02:24 +00:00
# Get cpu name
cpu="$(grep -F 'model name' /proc/cpuinfo)"
cpu=${cpu/model name*: }
2016-01-30 03:37:50 +00:00
cpu=${cpu/ @*}
2016-02-13 10:14:50 +00:00
cpu=${cpu// }
cpu=${cpu%% }
2016-01-05 04:02:24 +00:00
# Get cpu speed
if [ -d "/sys/devices/system/cpu/cpu0/cpufreq" ]; then
case "$speed_type" in
current) speed_type="scaling_cur_freq" ;;
min) speed_type="scaling_min_freq" ;;
max) speed_type="scaling_max_freq" ;;
bios) speed_type="bios_limit" ;;
scaling_current) speed_type="scaling_cur_freq" ;;
scaling_min) speed_type="scaling_min_freq" ;;
scaling_max) speed_type="scaling_max_freq" ;;
esac
read -r speed < \
/sys/devices/system/cpu/cpu0/cpufreq/${speed_type}
else
speed=$(awk -F ': ' '/cpu MHz/ {printf $2; exit}' /proc/cpuinfo)
speed=${speed/\.}
fi
# Convert mhz to ghz without bc
speed=$((speed / 100000))
speed=${speed:0:1}.${speed:1}
2016-01-19 11:30:17 +00:00
cpu="$cpu @ ${speed}GHz"
cores=$(awk -F ': ' '/siblings/ {printf $2; exit}' /proc/cpuinfo)
;;
"Mac OS X")
cpu="$(sysctl -n machdep.cpu.brand_string)"
2016-02-22 22:35:31 +00:00
cpu=${cpu/ }
cores=$(sysctl -n hw.ncpu)
;;
2016-02-20 21:30:23 +00:00
*"BSD" | "Windows")
2016-01-19 00:05:43 +00:00
case "$distro" in
2016-02-01 03:56:53 +00:00
"OpenBSD"* | "FreeBSD"*)
# Get cpu name
2016-01-19 06:33:41 +00:00
cpu="$(sysctl -n hw.model)"
2016-03-25 22:40:35 +00:00
cpu=${cpu/[0-9]\.*}
cpu=${cpu/ @*}
cpu=${cpu// }
cpu=${cpu% }
# Get cpu speed
case "$distro" in
2016-02-01 03:56:53 +00:00
"OpenBSD"*) speed=$(sysctl -n hw.cpuspeed) ;;
"FreeBSD"*) speed=$(sysctl -n hw.clockrate) ;;
esac
2016-01-19 06:33:41 +00:00
speed=$((speed / 100))
cores=$(sysctl -n hw.ncpu)
2016-01-19 06:33:41 +00:00
;;
2016-02-20 21:30:23 +00:00
"NetBSD"* | "Windows"*)
2016-01-19 00:05:43 +00:00
# Get cpu name
cpu="$(grep -F 'model name' /proc/cpuinfo)"
cpu=${cpu/model name*: }
cpu=${cpu/ @*}
cpu=${cpu// }
2016-01-19 00:17:45 +00:00
cpu=${cpu% }
2016-01-19 00:12:38 +00:00
# Get cpu speed
speed="$(grep -F 'cpu MHz' /proc/cpuinfo)"
speed=${speed/cpu MHz*: }
speed=${speed/\.}
2016-02-20 21:34:02 +00:00
case "$distro" in
"NetBSD"*) speed=$((speed / 10000)) ;;
"Windows"*) speed=$((speed / 100000)) ;;
2016-02-20 21:34:02 +00:00
esac
cores=$(awk -F ': ' '/siblings/ {printf $2; exit}' /proc/cpuinfo)
2016-01-19 00:05:43 +00:00
;;
esac
speed=${speed:0:1}.${speed:1}
cpu="$cpu @ ${speed}GHz"
;;
*)
cpu="Unknown"
;;
esac
# Remove uneeded patterns from cpu output
# This is faster than sed/gsub
cpu=${cpu//(tm)}
cpu=${cpu//(TM)}
cpu=${cpu//(r)}
cpu=${cpu//(R)}
cpu=${cpu// CPU}
cpu=${cpu// Processor}
cpu=${cpu// Six-Core}
cpu=${cpu// Eight-Core}
cpu=${cpu// with Radeon HD Graphics}
2016-03-12 12:01:20 +00:00
2016-03-15 07:55:35 +00:00
# Add cpu cores to output
2016-03-25 11:17:54 +00:00
[ "$cpu_cores" == "on" ] && [ ! -z "$cores" ] && \
2016-03-15 07:55:35 +00:00
cpu=${cpu/@/\(${cores}\) @}
2016-03-12 12:01:20 +00:00
# Make the output of cpu shorter
case "$cpu_shorthand" in
"name")
cpu=${cpu/@*}
;;
"speed")
cpu=${cpu#*@ }
;;
"on" | "tiny")
cpu=${cpu/Intel }
cpu=${cpu/Core }
cpu=${cpu/Core? Duo }
cpu=${cpu/AMD }
case "$cpu_shorthand" in
"tiny") cpu=${cpu/@*} ;;
esac
;;
esac
# Add CPU info bar
2016-03-12 20:58:46 +00:00
prin "${subtitle}: ${cpu}"
cpu_usage="$(ps aux | awk 'BEGIN { sum = 0 } { sum += $3 }; END { print sum }')"
cpu_usage="${cpu_usage/\.*}%"
case "$cpu_display" in
2016-03-12 21:37:33 +00:00
"info") prin "${subtitle} Usage: ${cpu_usage}" ;;
"bar") prin "${subtitle} Usage: $(bar "${cpu_usage/'%'}" $(( 100 * ${cores} )))" ;;
"infobar") prin "${subtitle} Usage: ${cpu_usage} $(bar "${cpu_usage/'%'}" $(( 100 * ${cores} )))" ;;
"barinfo") prin "${subtitle} Usage: $(bar "${cpu_usage/'%'}" $(( 100 * ${cores} ))) ${cpu_usage}" ;;
2016-03-17 05:10:16 +00:00
"off") ;;
2016-03-12 12:01:20 +00:00
esac
2016-03-17 05:10:16 +00:00
[ "$stdout_mode" != "on" ] && unset cpu
}
2015-12-30 10:18:17 +00:00
# }}}
# GPU {{{
2016-01-19 00:55:45 +00:00
getgpu () {
2016-01-19 01:02:04 +00:00
case "$os" in
"Linux")
gpu="$(PATH="/sbin:$PATH" lspci | grep -F "3D")"
# If a GPU with a prefix of '3D' doesn't exist
# fallback to looking for a prefix of 'VGA'
[ -z "$gpu" ] && \
2016-02-09 09:58:41 +00:00
gpu="$(PATH="/sbin:$PATH" lspci | grep -F "VGA")"
gpu=${gpu//??':'??'.'?}
2016-01-31 01:52:28 +00:00
# Count the number of GPUs
count="$(printf "%s" "$gpu" | uniq -c)"
count=${count/ VGA*}
count=${count/ 3D*}
2016-01-31 01:52:28 +00:00
count=${count//[[:space:]]}
# If there's more than one gpu
# Display the count.
if [ "$count" -gt 1 ]; then
count=" x $count"
else
unset count
fi
# Format the output
gpu=${gpu/* VGA compatible controller: }
gpu=${gpu/* 3D controller: }
gpu=${gpu/(rev*)}
case "$gpu" in
intel*)
gpu=${gpu/Intel Corporation }
gpu=${gpu/Haswell-??? }
gpu=${gpu/?th Gen }
2016-03-05 12:33:05 +00:00
gpu=${gpu/Core }
gpu=${gpu/Processor }
2016-02-18 11:04:02 +00:00
gpu=${gpu/ Mobile}
gpu=${gpu/ Express}
2016-03-15 07:01:14 +00:00
gpu=${gpu/ Controller}
2016-02-26 04:01:38 +00:00
gpu=${gpu/Sky }
gpu=${gpu/Lake }
2016-01-26 01:58:46 +00:00
brand="Intel "
;;
advanced*)
gpu=${gpu/Advanced Micro Devices, Inc\. }
gpu=${gpu/'[AMD/ATI]' }
gpu=${gpu/Tahiti PRO}
gpu=${gpu/Seymour}
gpu=${gpu/Richland}
2016-02-28 19:56:10 +00:00
gpu=${gpu/Pitcairn}
2016-03-06 03:10:08 +00:00
gpu=${gpu/Hawaii}
gpu=${gpu/ OEM}
2016-02-10 22:20:03 +00:00
gpu=${gpu/ Cape Verde}
gpu=${gpu/ \[}
gpu=${gpu/\]}
2016-01-26 01:58:46 +00:00
brand="AMD "
;;
nvidia*)
gpu=${gpu/NVIDIA Corporation }
gpu=${gpu/nVidia Corporation }
gpu=${gpu/G????M }
gpu=${gpu/G???? }
gpu=${gpu/\[}
gpu=${gpu/\] }
2016-01-26 01:58:46 +00:00
brand="Nvidia "
;;
*virtualbox*)
gpu="VirtualBox Graphics Adapter"
;;
esac
2016-01-26 01:58:46 +00:00
gpu="${brand}${gpu}"
2016-01-19 00:55:45 +00:00
;;
"Mac OS X")
gpu=$(system_profiler SPDisplaysDataType | awk -F': ' '/^\ *Chipset Model:/ {printf $2 ", "}')
gpu=${gpu//'/ $'}
gpu=${gpu%,*}
2016-01-19 00:55:45 +00:00
;;
2016-01-25 23:54:07 +00:00
*"BSD")
2016-01-19 00:55:45 +00:00
case "$distro" in
2016-02-01 03:56:53 +00:00
"FreeBSD"*)
2016-01-19 00:55:45 +00:00
gpu=$(pciconf -lv 2>/dev/null | grep -B 4 "VGA" | grep "device")
gpu=${gpu/device*= }
gpu=${gpu//\'}
2016-01-19 02:57:29 +00:00
gpu=${gpu//[[:space:]]/ }
gpu=${gpu// }
2016-01-19 00:55:45 +00:00
;;
2016-01-24 23:51:06 +00:00
*)
gpu="Unknown"
;;
2016-01-19 00:55:45 +00:00
esac
;;
"Windows")
gpu=$(wmic path Win32_VideoController get caption /value)
gpu=${gpu/Caption'='}
2016-01-19 01:22:32 +00:00
gpu=${gpu//[[:space:]]/ }
gpu=${gpu// }
2016-01-19 00:55:45 +00:00
;;
esac
2016-01-19 02:52:33 +00:00
case "$gpu_shorthand" in
"on" | "tiny")
gpu=${gpu// Rev\. ?}
gpu=${gpu//AMD*\/ATI\]/AMD}
gpu=${gpu// Tahiti}
gpu=${gpu// PRO}
gpu=${gpu// OEM}
gpu=${gpu// Mars}
gpu=${gpu// Series}
gpu=${gpu// Controller}
gpu=${gpu/\/*}
case "$gpu_shorthand" in
"tiny")
gpu=${gpu/Graphics }
gpu=${gpu/GeForce }
gpu=${gpu/Radeon }
;;
esac
;;
esac
2016-01-31 01:52:28 +00:00
gpu="${gpu}${count}"
2016-01-19 00:55:45 +00:00
}
# }}}
# Memory {{{
getmemory () {
case "$os" in
"Linux")
2016-01-05 05:20:06 +00:00
# Read first 3 lines
mem=$(awk -F ':' '/MemTotal|MemAvailable/ {printf $2}' /proc/meminfo )
2016-01-05 05:20:06 +00:00
# Do some substitution on each line
memtotal=${mem/kB*/kB}
memavail=${mem/${memtotal}}
memtotal=${memtotal/kB*}
memavail=${memavail/kB*}
2016-01-05 05:20:06 +00:00
memused=$((memtotal - memavail))
memory="$((memused / 1024))MB / $((memtotal / 1024))MB"
;;
"Mac OS X")
2016-01-04 03:59:47 +00:00
memtotal=$(printf "%s\n" "$(sysctl -n hw.memsize)"/1024^2 | bc)
memwired=$(vm_stat | awk '/wired/ { print $4 }')
2016-01-22 04:12:43 +00:00
memactive=$(vm_stat | awk '/active / { printf $3 }')
memcompressed=$(vm_stat | awk '/occupied/ { printf $5 }')
2016-01-30 05:31:22 +00:00
memused=$(((${memwired//.} + ${memactive//.} + ${memcompressed//.}) * 4 / 1024))
memory="${memused}MB / ${memtotal}MB"
;;
2016-01-18 06:48:27 +00:00
"OpenBSD" | "BSD")
2016-01-18 06:45:32 +00:00
case "$distro" in
2016-03-25 22:45:46 +00:00
"OpenBSD"*)
mem=($(top -d 1 | awk -F ': |/| |M' '/Memory:/ {printf $4 " " $6 " " $11 "\n"}'))
memtotal=$((${mem[1]} + ${mem[2]}))
memused=$((memtotal - ${mem[0]}))
memory="${memused}MB / ${memtotal}MB"
;;
"FreeBSD"*)
2016-01-19 06:33:41 +00:00
memtotal=$(dmesg | awk '/real mem/ {printf $5}')
memtotal=${memtotal/\(}
memtotal=${memtotal/MB\)}
2016-01-19 06:33:41 +00:00
memfree=$(top -d 1 | awk '/Mem:/ {printf $10}')
memfree=${memfree/M}
2016-01-19 00:05:43 +00:00
memused=$((memtotal - memfree))
memory="${memused}MB / ${memtotal}MB"
;;
2016-02-01 03:56:53 +00:00
"NetBSD"*)
2016-01-19 00:05:43 +00:00
memfree=$(($(vmstat | awk 'END{printf $4}') / 1000))
memused=$(($(vmstat | awk 'END{printf $3}') / 1000))
memtotal=$((memused + memfree))
memused=$((memtotal - memfree))
memory="${memused}MB / ${memtotal}MB"
2016-01-18 06:45:32 +00:00
;;
esac
2016-01-18 06:17:32 +00:00
;;
2016-01-05 06:10:34 +00:00
"Windows")
mem="$(awk 'NR < 3 {printf $2 " "}' /proc/meminfo)"
2016-02-24 04:04:08 +00:00
memtotal=${mem/ *}
memfree=${mem#* }
2016-01-05 06:10:34 +00:00
memavail=$((memtotal - memfree))
memused=$((memtotal - memavail))
2016-01-06 01:04:43 +00:00
memory="$((${memused%% *} / 1024))MB / "
memory+="$((${memtotal%% *} / 1024))MB"
2016-01-05 06:10:34 +00:00
;;
*)
memory="Unknown"
;;
esac
# Progress bars
2016-03-12 20:58:46 +00:00
case "$memory_display" in
2016-03-12 13:00:02 +00:00
"bar") memory="$(bar "${memused}" "${memtotal}")" ;;
"infobar") memory="${memory} $(bar "${memused}" "${memtotal}")" ;;
"barinfo") memory="$(bar "${memused}" "${memtotal}") ${memory}" ;;
esac
}
# }}}
# Song {{{
getsong () {
if mpc version >/dev/null 2>&1; then
2016-02-16 03:50:20 +00:00
song="$(mpc current 2>/dev/null)"
state=$(mpc | awk -F '\\[|\\]' '/\[/ {printf $2}' 2>/dev/null)
elif pgrep "cmus" >/dev/null 2>&1; then
2016-02-16 03:50:20 +00:00
song="$(cmus-remote -Q | grep "tag artist\|title" 2>/dev/null)"
2016-01-20 10:24:04 +00:00
song=${song/tag artist }
song=${song/tag title/-}
song=${song//[[:space:]]/ }
2016-02-16 03:50:20 +00:00
state=$(cmus-remote -Q | awk -F ' ' '/status/ {printf $2}' 2>/dev/null)
elif pgrep "mocp" >/dev/null 2>&1; then
2016-02-16 03:50:20 +00:00
song="$(mocp -Q "%artist - %song" 2>/dev/null)"
state="$(mocp -Q "%state" 2>/dev/null)"
2016-02-15 13:12:15 +00:00
elif [ -n "$(ps aux | awk '!(/awk/) && /spotify/')" ]; then
case "$os" in
"Linux")
# This command is way too long
song="$(\
dbus-send --print-reply --dest=org.mpris.MediaPlayer2.spotify /org/mpris/MediaPlayer2 \
org.freedesktop.DBus.Properties.Get string:'org.mpris.MediaPlayer2.Player' string:'Metadata' |\
awk -F 'string "' '/string|array/ {printf "%s",$2; next}{print ""}' |\
2016-03-10 07:48:41 +00:00
awk -F '"' '/artist|title/ {printf $2 " - "}'
)"
song=${song% - }
song=${song/'('*}
song=${song//'['*}
;;
"Mac OS X")
song="$(osascript -e 'tell application "Spotify" to artist of current track as string & " - " & name of current track as string')"
state="$(osascript -e 'tell application "Spotify" to player state as string')"
;;
esac
2016-03-25 02:44:15 +00:00
elif [ -n "$(ps aux | awk '!(/awk/ || /Helper/) && /Google Play Music Desktop Player/')" ] && type -p gpmdp >/dev/null 2>&1; then
song="$(gpmdp current)"
state="$(gpmdp status)"
2016-03-12 07:16:22 +00:00
elif [ -n "$(ps aux | awk '!(/awk/ || /Helper/) && /iTunes/')" ]; then
song="$(osascript -e 'tell application "iTunes" to artist of current track as string & " - " name of current track as string')"
state="$(osascript -e 'tell application "iTunes" to player state as string')"
2016-01-20 10:24:29 +00:00
else
song="Unknown"
2016-01-20 10:24:04 +00:00
fi
2016-02-16 03:50:20 +00:00
case "$state" in
"paused" | "PAUSE")
song="Paused"
;;
"stopped" | "STOP")
2016-02-16 03:50:20 +00:00
song="Stopped"
;;
esac
2016-02-20 21:38:07 +00:00
# Display Artist and Title on seperate lines.
2016-03-17 05:16:15 +00:00
if [ "$song_shorthand" == "on" ] && [ "$stdout_mode" != "on" ]; then
artist="${song/ -*}"
song=${song/$artist - }
if [ "$song" != "$artist" ]; then
prin "Artist: ${artist}"
prin "Song: ${song}"
else
prin "${subtitle}: ${song}"
fi
unset song
fi
}
# }}}
# Resolution {{{
getresolution () {
case "$os" in
"Linux" | *"BSD")
type -p xdpyinfo >/dev/null 2>&1 && \
2016-01-29 13:34:48 +00:00
resolution=$(xdpyinfo 2>/dev/null | awk '/dimensions:/ {printf $2}')
;;
"Mac OS X")
resolution=$(system_profiler SPDisplaysDataType |\
2016-01-22 04:12:43 +00:00
awk '/Resolution:/ {printf $2"x"$4" "}')
;;
2016-01-18 06:24:08 +00:00
2016-02-21 10:01:46 +00:00
"Windows")
width=$(wmic desktopmonitor get screenwidth /value 2>/dev/null)
width=${width/ScreenWidth'='/}
width=${width//[[:space:]]}
height=$(wmic desktopmonitor get screenheight /value 2>/dev/null)
height=${height/ScreenHeight'='/}
height=${height//[[:space:]]}
[ ! -z "$width" ] && \
resolution="${width}x${height}"
2016-02-21 10:01:46 +00:00
;;
2016-01-29 13:34:48 +00:00
"*")
resolution="Unknown"
;;
esac
}
# }}}
# Theme/Icons/Font {{{
getstyle () {
# Fix weird output when the function
# is run multiple times.
2016-02-19 12:18:02 +00:00
unset gtk2theme gtk3theme theme path
case "$1" in
theme)
name="gtk-theme-name"
gsettings="gtk-theme"
2016-02-08 12:29:48 +00:00
gconf="gtk_theme"
xfconf="ThemeName"
kde="widgetStyle"
path="/proc/registry/HKEY_CURRENT_USER/Software/Microsoft"
path+="/Windows/CurrentVersion/Themes/CurrentTheme"
;;
icons)
name="gtk-icon-theme-name"
gsettings="icon-theme"
2016-02-08 12:29:48 +00:00
gconf="icon_theme"
xfconf="IconThemeName"
kde="Theme"
;;
font)
name="gtk-font-name"
gsettings="font-name"
2016-02-08 12:29:48 +00:00
gconf="font_theme"
xfconf="FontName"
kde="font"
;;
esac
2016-02-20 21:38:07 +00:00
if [ -n "$DISPLAY" ] && [ "$os" != "Mac OS X" ]; then
# Current DE
2016-02-23 22:30:11 +00:00
case "$XDG_CURRENT_DESKTOP" in
"KDE"*)
if type -p kde5-config >/dev/null 2>&1; then
kde_config_dir=$(kde5-config --localprefix)
elif type -p kde4-config >/dev/null 2>&1; then
kde_config_dir=$(kde4-config --localprefix)
elif type -p kde-config >/dev/null 2>&1; then
kde_config_dir=$(kde-config --localprefix)
fi
2016-02-15 23:31:13 +00:00
if [ -f "${kde_config_dir}/share/config/kdeglobals" ]; then
kde_config_file="${kde_config_dir}/share/config/kdeglobals"
2016-02-15 23:31:13 +00:00
theme=$(grep "^[^#]*$kde" "$kde_config_file")
theme=${theme/${kde}*=}
2016-02-23 22:30:11 +00:00
[ "$version" -ge 4 ] && theme=${theme^}
gtk_shorthand="on"
return
fi
;;
2016-03-05 22:14:44 +00:00
*"Cinnamon")
if type -p gsettings >/dev/null 2>&1; then
gtk3theme=$(gsettings get org.cinnamon.desktop.interface $gsettings)
gtk3theme=${gtk3theme//"'"}
gtk2theme=${gtk3theme}
fi
;;
"Gnome"* | "Unity"* | "Budgie")
if type -p gsettings >/dev/null 2>&1; then
gtk3theme=$(gsettings get org.gnome.desktop.interface $gsettings)
gtk3theme=${gtk3theme//"'"}
gtk2theme=${gtk3theme}
elif type -p gconftool-2 >/dev/null 2>&1; then
gtk2theme=$(gconftool-2 -g /desktop/gnome/interface/$gconf)
fi
;;
"Mate"*)
gtk3theme=$(gsettings get org.mate.interface $gsettings)
2016-02-08 12:29:48 +00:00
gtk2theme=${gtk3theme}
;;
"Xfce"*)
if type -p xfconf-query >/dev/null 2>&1; then
gtk2theme=$(xfconf-query -c xsettings -p /Net/$xfconf)
fi
;;
esac
# Check for gtk2 theme
if [ -z "$gtk2theme" ]; then
if [ -f "$HOME/.gtkrc-2.0" ]; then
gtk2theme=$(grep "^[^#]*$name" "$HOME/.gtkrc-2.0")
2016-01-28 00:34:41 +00:00
elif [ -f "/usr/share/gtk-2.0/gtkrc" ]; then
gtk2theme=$(grep "^[^#]*$name" /usr/share/gtk-2.0/gtkrc)
elif [ -f "/etc/gtk-2.0/gtkrc" ]; then
gtk2theme=$(grep "^[^#]*$name" /etc/gtk-2.0/gtkrc)
2016-02-08 12:29:48 +00:00
fi
gtk2theme=${gtk2theme/${name}*=}
gtk2theme=${gtk2theme//\"}
fi
# Check for gtk3 theme
if [ -z "$gtk3theme" ]; then
if [ -f "$HOME/.config/gtk-3.0/settings.ini" ]; then
gtk3theme=$(grep "^[^#]*$name" "$HOME/.config/gtk-3.0/settings.ini")
elif type -p gsettings >/dev/null 2>&1; then
gtk3theme="$(gsettings get org.gnome.desktop.interface $gsettings)"
gtk3theme=${gtk3theme//\'}
2016-01-28 00:34:41 +00:00
elif [ -f "/usr/share/gtk-3.0/settings.ini" ]; then
gtk3theme=$(grep "^[^#]*$name" /usr/share/gtk-3.0/settings.ini)
elif [ -f "/etc/gtk-3.0/settings.ini" ]; then
gtk3theme=$(grep "^[^#]*$name" /etc/gtk-3.0/settings.ini)
fi
gtk3theme=${gtk3theme/${name}*=}
gtk3theme=${gtk3theme//\"}
gtk3theme=${gtk3theme/[[:space:]]/ }
fi
2016-01-23 23:38:46 +00:00
# Uppercase the first letter of each gtk theme
2016-02-23 22:30:11 +00:00
if [ "$version" -ge 4 ]; then
gtk2theme=${gtk2theme^}
gtk3theme=${gtk3theme^}
fi
# Toggle visibility of gtk themes.
[ "$gtk2" == "off" ] && unset gtk2theme
[ "$gtk3" == "off" ] && unset gtk3theme
2016-02-08 13:47:51 +00:00
# Format the string based on which themes exist
if [ "$gtk2theme" ] && [ "$gtk2theme" == "$gtk3theme" ]; then
gtk3theme+=" [GTK2/3]"
unset gtk2theme
elif [ "$gtk2theme" ] && [ "$gtk3theme" ]; then
gtk2theme+=" [GTK2], "
gtk3theme+=" [GTK3] "
else
[ "$gtk2theme" ] && gtk2theme+=" [GTK2] "
[ "$gtk3theme" ] && gtk3theme+=" [GTK3] "
fi
# Final string
theme="${gtk2theme}${gtk3theme}"
theme=${theme//\"}
theme=${theme//\'}
# Make the output shorter by removing "[GTKX]" from the string
if [ "$gtk_shorthand" == "on" ]; then
theme=${theme/ '[GTK2]'}
theme=${theme/ '[GTK3]'}
theme=${theme/ '[GTK2/3]'}
fi
else
case "$os" in
"Windows")
2016-02-19 12:36:58 +00:00
[ -z "$path" ] && return
2016-02-19 23:39:33 +00:00
theme="$(head -n1 "$path" 2>/dev/null)"
theme="${theme##*\\}"
theme="${theme%.*}"
theme="${theme^}"
;;
esac
fi
}
gettheme () {
getstyle theme
}
geticons () {
getstyle icons
icons="$theme"
}
getfont () {
getstyle font
font="$theme"
}
# }}}
# Disk Usage {{{
2016-01-26 10:25:28 +00:00
getdisk () {
# df flags
case "$os" in
"Linux" | "Windows") df_flags="-h -l --total" ;;
"Mac OS X") df_flags="-H / -l" ;;
*"BSD")
case "$os" in
"FreeBSD") df_flags="-h -c -l" ;;
*) disk="Unknown"; return ;;
esac
;;
esac
2016-01-26 10:25:28 +00:00
# Get the disk info
disk=$(df $df_flags 2>/dev/null | awk 'END{print $2 ":" $3 ":" $5}')
2016-01-26 10:25:28 +00:00
# Format the output
disk_used=${disk#*:}
disk_used=${disk_used%%:*}
disk_total=${disk%%:*}
disk_total_per=${disk#*:*:}
2016-01-26 10:25:28 +00:00
# Put it all together
disk="${disk_used} / ${disk_total} (${disk_total_per})"
2016-03-03 00:52:39 +00:00
2016-03-12 12:43:16 +00:00
# Add info bar
2016-03-12 20:58:46 +00:00
disk_used=${disk_used/G}
disk_total=${disk_total/G}
2016-03-14 10:41:14 +00:00
[[ "$disk_used" == *"T" ]] && \
2016-03-14 10:33:14 +00:00
disk_used=$(printf "%s\n" "${disk_used/T} * 1000" | bc)
2016-03-14 10:41:14 +00:00
[[ "$disk_total" == *"T" ]] && \
2016-03-14 10:33:14 +00:00
disk_total=$(printf "%s\n" "${disk_total/T} * 1000" | bc)
2016-03-12 20:58:46 +00:00
case "$disk_display" in
"bar") disk="$(bar "${disk_used/'.'*}" "${disk_total/'.'*}")" ;;
"infobar") disk+=" $(bar "${disk_used/'.'*}" "${disk_total/'.'*}")" ;;
"barinfo") disk="$(bar "${disk_used/'.'*}" "${disk_total/'.'*}") $disk" ;;
"perc") disk="$disk_total_per $(bar "${disk_used/'.'*}" "${disk_total/'.'*}")" ;;
2016-03-12 12:43:16 +00:00
esac
2016-01-26 10:25:28 +00:00
}
# }}}
# Battery Usage {{{
getbattery () {
case "$os" in
"Linux")
2016-02-26 08:09:22 +00:00
if [ "$(ls /sys/class/power_supply/)" ]; then
# Set the index to the battery number.
case "$battery_num" in
"all") battery_num="*" index=0 ;;
*) index="$battery_num" ;;
esac
batteries=($(cat /sys/class/power_supply/BAT${battery_num}/capacity))
2016-03-25 13:24:18 +00:00
battery_state=($(cat /sys/class/power_supply/BAT${battery_num}/status))
2016-03-25 13:18:16 +00:00
# Get the subtitle and reassign it so it doesn't change.
title="$subtitle"
# If shorthand is on, print each value on the same line
if [ "$battery_shorthand" == "on" ] || [ "$stdout_mode" == "on" ]; then
2016-02-02 03:11:20 +00:00
battery=${batteries[*]}
battery=${battery// /%, }
battery="${battery}%"
else
2016-03-03 00:18:28 +00:00
if [ "${#batteries[@]}" -gt 1 ]; then
2016-03-12 21:37:33 +00:00
unset battery
2016-03-03 00:18:28 +00:00
# Print each battery on a separate line.
index=0
2016-03-03 00:18:28 +00:00
for bat in "${batteries[@]}"; do
case "$battery_display" in
"bar") prin "${title}${index}: $(bar ${bat/'%'} 100)" ;;
"infobar") prin "${title}${index}: ${bat}% $(bar "${bat/'%'}" 100)" ;;
"barinfo") prin "${title}${index}: $(bar "${bat/'%'}" 100) ${bat}%" ;;
*) prin "${title}${index}: ${bat}%" ;;
esac
index=$((index + 1))
2016-03-03 00:18:28 +00:00
done
return
fi
2016-03-25 13:18:16 +00:00
battery="${batteries[0]}%"
fi
else
battery="None"
fi
;;
2016-02-23 08:21:30 +00:00
2016-02-23 09:24:38 +00:00
"BSD")
2016-02-23 08:21:30 +00:00
case "$distro" in
"FreeBSD"*)
2016-03-25 13:18:16 +00:00
battery=$(acpiconf -i 0 | awk -F ':\t' '/Remaining capacity/ {print $2}')
2016-03-25 13:24:18 +00:00
battery_state=$(acpiconf -i 0 | awk -F ':\t\t\t' '/State/ {print $2}')
2016-02-23 08:21:30 +00:00
;;
2016-02-27 09:25:39 +00:00
"NetBSD"*)
battery=$(envstat | awk '\\(|\\)' '/charge:/ {print $2}')
battery="${battery/\.*}%"
;;
2016-02-23 09:24:38 +00:00
esac
;;
2016-02-23 09:21:16 +00:00
2016-02-23 09:24:38 +00:00
"OpenBSD")
2016-02-23 09:39:09 +00:00
battery0full=$(sysctl -n hw.sensors.acpibat0.watthour0)
battery0full=${battery0full/ Wh*}
2016-02-23 09:21:16 +00:00
2016-02-23 09:39:09 +00:00
battery0now=$(sysctl -n hw.sensors.acpibat0.watthour3)
battery0now="${battery0now/ Wh*}"
2016-02-23 09:24:38 +00:00
2016-03-14 11:31:40 +00:00
battery="$(printf "%s\n" "100 * $battery0now / $battery0full" | bc)%"
;;
"Mac OS X")
battery="$(pmset -g batt | grep -o '[0-9]*%')"
2016-03-25 13:24:18 +00:00
battery_state="$(pmset -g batt | awk 'NR==2 {print $3}')"
;;
"Windows")
2016-02-04 02:41:16 +00:00
battery="$(wmic Path Win32_Battery get EstimatedChargeRemaining /value)"
battery=${battery/EstimatedChargeRemaining'='}
battery=${battery//[[:space:]]/ }
2016-02-05 11:08:32 +00:00
battery=${battery// }
battery+="%"
;;
esac
2016-03-03 00:09:40 +00:00
2016-03-25 13:24:18 +00:00
case "$battery_state" in
2016-03-25 14:24:08 +00:00
"charging"*) battery+=" Charging" ;;
2016-03-25 13:18:16 +00:00
esac
2016-03-12 20:58:46 +00:00
case "$battery_display" in
"bar") battery="$(bar ${battery/'%'*} 100)" ;;
2016-03-25 14:26:42 +00:00
"infobar") battery="${battery} $(bar "${battery/'%'*}" 100)" ;;
"barinfo") battery="$(bar "${battery/'%'*}" 100) ${battery}" ;;
2016-03-12 13:05:48 +00:00
esac
}
# }}}
# IP Address {{{
getlocalip () {
case "$os" in
"Linux")
localip="$(ip route get 1 | awk '{print $NF;exit}')"
;;
2016-02-08 23:48:37 +00:00
"Mac OS X")
localip="$(ipconfig getifaddr en0)"
[ -z "$localip" ] && localip="$(ipconfig getifaddr en1)"
;;
*"BSD")
localip="$(ifconfig | awk '/broadcast/ {print $2}')"
;;
"Windows")
localip="$(ipconfig | awk -F ': ' '/IPv4 Address/ {printf $2}')"
;;
*)
localip="Unknown"
;;
esac
}
getpublicip () {
if type -p dig >/dev/null 2>&1; then
publicip="$(dig +short myip.opendns.com @resolver1.opendns.com)"
elif type -p curl >/dev/null 2>&1; then
publicip="$(curl -w '\n' "$public_ip_host")"
elif type -p wget >/dev/null 2>&1; then
publicip="$(wget -qO- "$public_ip_host"; printf "%s")"
else
publicip="Unknown"
fi
}
# }}}
# Logged In Users {{{
getusers () {
users="$(who | awk '!seen[$1]++ {printf $1 ", "}')"
users=${users%\,*}
}
# }}}
2016-01-30 11:10:28 +00:00
# Birthday {{{
getbirthday () {
case "$os" in
2016-01-30 12:34:53 +00:00
"Linux")
2016-01-30 11:10:28 +00:00
birthday="$(ls -alct --full-time / | awk '/lost\+found/ {printf $6 " " $7}')"
date_cmd="$(date -d"$birthday" +"$birthday_format")"
2016-01-30 11:10:28 +00:00
;;
2016-01-30 12:51:12 +00:00
"Mac OS X")
birthday="$(ls -lUT /var/log/install.log | awk '{printf $6 " " $7 " " $9 " " $8}')"
# Split the string into Date + time
time=${birthday/*???? }
birthday=${birthday/$time}
case "${time/:*}" in
0? | 10 | 11)
2016-03-11 23:25:19 +00:00
time+=" AM"
;;
*)
2016-03-11 23:25:19 +00:00
time+=" PM"
;;
esac
birthday+="$time"
birthday_shorthand="on"
2016-01-30 23:31:29 +00:00
;;
*"BSD")
2016-01-30 23:38:20 +00:00
case "$distro" in
2016-02-01 03:56:53 +00:00
"OpenBSD"*)
2016-01-30 23:38:20 +00:00
birthday="$(ls -alctT / | awk '/lost\+found/ {printf $6 " " $7 " " $9 " " $8}')"
birthday_shorthand="on"
2016-01-30 23:38:20 +00:00
;;
2016-02-01 03:56:53 +00:00
"FreeBSD"*)
2016-01-30 23:38:20 +00:00
birthday="$(ls -alctT /etc/hostid | awk '{printf $6 " " $7 " " $9 " " $8}')"
date_cmd="$(date -j -f "%b %d %Y" "$birthday" +"$birthday_format")"
2016-01-30 23:38:20 +00:00
;;
2016-02-01 03:56:53 +00:00
"NetBSD"*)
2016-01-31 00:02:32 +00:00
birthday="$(ls -alctT /etc/defaults/rc.conf | awk '{printf $6 " " $7 " " $9 " " $8}')"
birthday_shorthand="on"
;;
2016-01-30 23:38:20 +00:00
*)
birthday="Unknown"
;;
esac
2016-01-30 11:10:28 +00:00
;;
2016-01-31 00:10:13 +00:00
"Windows")
birthday="$(ls -alct --full-time /cygdrive/c/Windows/explorer.exe | awk '{printf $8 " " $9}')"
date_cmd="$(date -d"$birthday" +"$birthday_format")"
2016-01-31 00:10:13 +00:00
;;
2016-01-30 11:10:28 +00:00
*)
birthday="Unknown"
;;
esac
2016-01-30 11:41:58 +00:00
# Strip seconds from time output
2016-03-11 23:25:19 +00:00
birthday=${birthday/:?? / }
2016-01-30 11:41:58 +00:00
# Pretty output
2016-03-05 23:01:57 +00:00
[ "$birthday_shorthand" == "off" ] && \
birthday="${date_cmd/ / }"
2016-01-30 11:41:58 +00:00
# Toggle showing the time
[ "$birthday_time" == "off" ] && \
2016-01-30 11:41:58 +00:00
birthday=${birthday/??:??*}
2016-01-30 11:10:28 +00:00
}
# }}}
# Terminal colors {{{
getcols () {
if [ "$color_blocks" == "on" ]; then
2016-01-04 23:11:25 +00:00
printf "${padding}%s"
while [ $start -le $end ]; do
printf "\033[48;5;${start}m%${block_width}s"
start=$((start + 1))
# Split the blocks at 8 colors
[ $end -ge 9 ] && [ $start -eq 8 ] && \
2016-01-04 23:11:25 +00:00
printf "\n%s${clear}${padding}"
done
# Clear formatting
printf "%b%s" "$clear"
fi
}
2015-12-30 10:18:17 +00:00
# }}}
# }}}
2015-12-30 10:18:17 +00:00
# Images {{{
2015-12-30 10:18:17 +00:00
# Wallpaper {{{
2016-01-05 07:19:38 +00:00
getwallpaper () {
case "$os" in
"Linux" | *"BSD")
if type -p feh >/dev/null 2>&1 && [ -f "$HOME/.fehbg" ]; then
2016-01-20 10:35:32 +00:00
img="$(awk -F\' '/feh/ {printf $2}' "$HOME/.fehbg")"
2016-01-20 10:35:32 +00:00
elif type -p nitrogen >/dev/null 2>&1; then
img="$(awk -F'=' '/file/ {printf $2;exit;}' "$HOME/.config/nitrogen/bg-saved.cfg")"
2016-01-24 00:03:29 +00:00
elif type -p gsettings >/dev/null 2>&1; then
case "$XDG_CURRENT_DESKTOP" in
"MATE"*) img="$(gsettings get org.mate.background picture-filename 2>/dev/null)" ;;
*) img="$(gsettings get org.gnome.desktop.background picture-uri 2>/dev/null)" ;;
esac
# Strip quotes etc from the path.
2016-01-24 00:03:29 +00:00
img=${img/'file://'}
img=${img//\'}
2016-01-20 10:35:32 +00:00
fi
2016-01-05 07:19:38 +00:00
;;
2016-01-17 21:37:37 +00:00
"Mac OS X")
2016-01-17 22:10:59 +00:00
img="$(osascript -e 'tell app "finder" to get posix path of (get desktop picture as text)')"
2016-01-17 21:37:37 +00:00
;;
2016-01-05 07:50:06 +00:00
"Windows")
case "$distro" in
"Windows XP")
img="/cygdrive/c/Documents and Settings/${USER}"
img+="/Local Settings/Application Data/Microsoft"
img+="/Wallpaper1.bmp"
2016-01-05 07:50:06 +00:00
;;
2016-01-05 07:19:38 +00:00
2016-01-05 07:50:06 +00:00
"Windows"*)
img="$APPDATA/Microsoft/Windows/Themes"
img+="/TranscodedWallpaper.jpg"
2016-01-05 07:50:06 +00:00
;;
esac
2016-01-05 07:19:38 +00:00
;;
esac
# If img is an xml file don't use it.
[ "${img/*\./}" == "xml" ] && img=""
2016-01-05 07:19:38 +00:00
}
# }}}
2016-01-27 11:33:22 +00:00
# Ascii {{{
getascii () {
2016-02-28 06:02:05 +00:00
if [ ! -f "$ascii" ] || [ "$ascii" == "distro" ]; then
# Lowercase the distro name
2016-02-23 22:30:11 +00:00
if [ "$version" -le 3 ]; then
ascii=$(tr '[:upper:]' '[:lower:]' <<< "$ascii_distro")
else
ascii=${ascii_distro,,}
fi
[ "$ascii_logo_size" == "small" ] && \
ascii="${ascii/ *}_small"
2016-02-28 00:44:45 +00:00
if [ -f "/usr/share/neofetch/ascii/distro/${ascii/ *}" ]; then
ascii="/usr/share/neofetch/ascii/distro/${ascii/ *}"
2016-02-28 00:44:45 +00:00
elif [ -f "/usr/local/share/neofetch/ascii/distro/${ascii/ *}" ]; then
ascii="/usr/local/share/neofetch/ascii/distro/${ascii/ *}"
else
2016-01-29 15:14:29 +00:00
getscriptdir
2016-02-24 10:15:30 +00:00
# If the ascii file doesn't exist fallback to text mode.
2016-01-29 15:14:29 +00:00
if [ ! -f "$script_dir/ascii/distro/${ascii/ *}" ]; then
padding="\033[0C"
2016-01-29 00:06:26 +00:00
image="off"
return
fi
2016-01-29 06:56:39 +00:00
2016-01-29 15:14:29 +00:00
ascii="$script_dir/ascii/distro/${ascii/ *}"
fi
# We only use eval in the distro ascii files.
print="$(eval printf "$(<"$ascii")")"
else
2016-02-04 10:22:58 +00:00
case "${ascii_colors[0]}" in
"distro") ascii_color="$c1" ;;
2016-02-23 05:52:25 +00:00
*) ascii_color="\033[38;5;${ascii_colors[0]}m" ;;
esac
2016-02-04 10:22:58 +00:00
print="${ascii_color}$(<"$ascii")"
fi
2016-02-09 23:20:51 +00:00
# Set locale to get correct padding
2016-02-10 11:54:07 +00:00
export LC_ALL="$SYS_LOCALE"
2016-02-09 23:20:51 +00:00
2016-02-24 10:15:30 +00:00
# Turn the file into a variable and strip escape codes.
2016-01-30 05:31:22 +00:00
ascii_strip=$(<"$ascii")
ascii_strip=${ascii_strip//\$\{??\}}
ascii_strip=${ascii_strip//\\}
2016-01-27 11:33:22 +00:00
# Get length of longest line
2016-02-09 23:20:51 +00:00
length="$(wc -L 2>/dev/null <<< "$ascii_strip")"
# Get the height in lines
2016-02-09 23:20:51 +00:00
lines="$(($(wc -l 2>/dev/null <<< "$ascii_strip") + 1))"
# Fallback to using awk on systems without 'wc -L'
[ -z "$length" ] && \
2016-02-09 23:20:51 +00:00
length="$(awk 'length>max{max=length}END{print max}' <<< "$ascii_strip")"
2016-01-27 11:33:22 +00:00
padding="\033[$((length + gap))C"
printf "%b%s" "$print"
2016-02-09 23:20:51 +00:00
export LC_ALL=C
2016-01-27 11:33:22 +00:00
}
# }}}
# Image {{{
getimage () {
# Fallback to ascii mode if imagemagick isn't installed.
2016-02-19 23:39:33 +00:00
type -p convert >/dev/null 2>&1 || image="ascii"
2016-02-20 20:07:41 +00:00
# Get terminal lines
lines=$(tput lines)
case "$image" in
2016-02-19 23:39:33 +00:00
"wall") getwallpaper ;;
"ascii") getascii; return ;;
*)
if [ "${image: -1}" == "/" ]; then
files=("$image"*.png "$image"*.jpg)
img="$(printf "%s" "${files[RANDOM % ${#files[@]}]}")"
else
img="$image"
fi
;;
esac
2016-02-18 03:19:41 +00:00
# Get terminal width and height
2016-02-21 00:32:02 +00:00
if [ -n "$TMUX" ]; then
printf "%b%s" "\033Ptmux;\033\033[14t\033\033[c\033\\"
2016-02-21 00:32:02 +00:00
else
printf "%b%s" "\033[14t\033[c"
2016-02-21 00:32:02 +00:00
fi
2016-02-18 03:19:41 +00:00
2016-02-19 23:39:33 +00:00
# The ascape code above prints the output AFTER the prompt so this
# loop below reads it as input. wtf xterm
read -d c -s -r term_size
2016-01-20 10:46:20 +00:00
# Split the string
term_size=${term_size//'['}
term_size=${term_size/';'}
term_size=${term_size/$'\E4'}
term_size=${term_size/t*}
term_height=${term_size/';'*}
term_width=${term_size/*';'}
# If $img isn't a file or the terminal doesn't support xterm escape sequences,
# fallback to ascii mode.
if [ ! -f "$img" ] || [ ${#term_size} -le 5 ]; then
image="ascii"
getascii
return
fi
2016-02-20 20:07:41 +00:00
# Get terminal columns
2016-02-01 00:05:46 +00:00
columns=$(tput cols)
2016-02-18 03:19:41 +00:00
# Calculate font size
font_width=$((term_width / columns))
font_height=$((term_height / lines))
# Image size is half of the terminal
2016-02-20 02:35:07 +00:00
case "$image_size" in
"auto")
image_size=$((columns * font_width / 2))
term_height=$((term_height - term_height / 4))
[ "$term_height" -lt "$image_size" ] && \
image_size="$term_height"
2016-02-20 02:35:07 +00:00
;;
*"%")
percent=${image_size/\%}
image_size=$((percent * term_width / 100))
[ "$((percent * term_height / 50))" -lt "$image_size" ] && \
image_size=$((percent * term_height / 100))
;;
esac
2016-02-24 01:19:55 +00:00
image_size=${image_size/px}
2016-02-18 03:19:41 +00:00
# Where to draw the image
case "$image_position" in
"left")
# Padding is half the terminal width + gap
2016-03-12 23:49:57 +00:00
padding="\033[$((image_size / font_width + gap + xoffset/font_width))C"
;;
"right")
padding="\033[0C"
xoffset=$((columns * font_width / 2 - gap))
;;
esac
# Make the directory if it doesn't exist
2016-01-31 10:33:02 +00:00
mkdir -p "$thumbnail_dir"
2016-02-19 23:39:33 +00:00
# Check to see if the image has a file extension, if it doesn't
# then add one.
case "${img##*/}" in
2016-02-19 23:39:33 +00:00
*"."*) imgname="$crop_mode-$crop_offset-$image_size-${img##*/}" ;;
*) imgname="$crop_mode-$crop_offset-$image_size-${img##*/}.jpg" ;;
esac
# Check to see if the thumbnail exists before we do any cropping.
2016-01-31 10:33:02 +00:00
if [ ! -f "$thumbnail_dir/$imgname" ]; then
# Get image size so that we can do a better crop
2016-01-05 08:24:57 +00:00
size=$(identify -format "%w %h" "$img")
width=${size%% *}
height=${size##* }
# This checks to see if height is geater than width
# so we can do a better crop of portrait images.
2016-02-19 23:39:33 +00:00
size=$height
[ "$height" -gt "$width" ] && size=$width
case "$crop_mode" in
fit)
c=$(convert "$img" \
-colorspace srgb \
-format "%[pixel:p{0,0}]" info:)
convert \
"$img" \
-trim +repage \
-gravity south \
-background "$c" \
-extent "$size"x"$size" \
-scale "$image_size"x"$image_size" \
2016-01-31 10:33:02 +00:00
"$thumbnail_dir/$imgname"
;;
fill)
convert \
"$img" \
-trim +repage \
-scale "$image_size"x"$image_size"^ \
-extent "$image_size"x"$image_size" \
2016-01-31 10:33:02 +00:00
"$thumbnail_dir/$imgname"
;;
*)
convert \
"$img" \
-gravity $crop_offset \
-crop "$size"x"$size"+0+0 \
-quality 95 \
-scale "$image_size"x"$image_size" \
2016-01-31 10:33:02 +00:00
"$thumbnail_dir/$imgname"
;;
esac
fi
# The final image
2016-01-31 10:33:02 +00:00
img="$thumbnail_dir/$imgname"
2015-12-30 10:18:17 +00:00
}
takescrot () {
2016-03-18 22:37:29 +00:00
$scrot_cmd "${scrot_dir}${scrot_name}"
}
2015-12-30 10:18:17 +00:00
# }}}
2016-01-30 06:44:52 +00:00
# Find w3m-img {{{
# Find w3mimgdisplay automatically
getw3m_img_path () {
if [ -x "$w3m_img_path" ]; then
return
elif [ -x "/usr/lib/w3m/w3mimgdisplay" ]; then
w3m_img_path="/usr/lib/w3m/w3mimgdisplay"
elif [ -x "/usr/libexec/w3m/w3mimgdisplay" ]; then
w3m_img_path="/usr/libexec/w3m/w3mimgdisplay"
elif [ -x "/usr/lib64/w3m/w3mimgdisplay" ]; then
w3m_img_path="/usr/lib64/w3m/w3mimgdisplay"
elif [ -x "/usr/libexec64/w3m/w3mimgdisplay" ]; then
w3m_img_path="/usr/libexec64/w3m/w3mimgdisplay"
else
image="ascii"
fi
}
# }}}
2015-12-30 10:18:17 +00:00
# }}}
# Text Formatting {{{
2015-12-30 10:18:17 +00:00
# Info {{{
info () {
# $1 is the subtitle
subtitle="$1"
# Call the function and update variable
if [ -z "$2" ]; then
"get$1" 2>/dev/null
eval output="\$${1}"
else
"get$2" 2>/dev/null
eval output="\$${2}"
fi
# If the output is empty, don't print anything
[ -z "$output" ] && return
case "$1" in
title)
string="${bold}${title_color}${output}"
string="${string/@/${at_color}@${title_color}}"
length=${#output}
;;
underline)
string="${underline_color}${output}"
;;
*)
string="${bold}${subtitle_color}${subtitle}${clear}"
string+="${colon_color}: ${info_color}${output}"
length=$((${#subtitle} + ${#output} + 2))
;;
esac
# If there's no subtitle don't print one
[ -z "$2" ] && string=${string/*: }
# Print the string
printf "%b%s\n" "${padding}${string}${clear}"
}
# }}}
# Prin {{{
prin () {
case "$1" in
*:*)
subtitle=${1%%:*}
output=${1#*: }
string="${bold}${subtitle_color}${subtitle}${clear}"
string+="${colon_color}: ${info_color}${output}"
length=$((${#subtitle} + ${#output} + 1))
;;
*)
string="${info_color}${1}"
length=${#1}
;;
esac
# Print the info
printf "%b%s\n" "${padding}${string}${clear}"
}
# }}}
# Stdout {{{
stdout () {
2016-03-03 05:35:24 +00:00
# Read args early for the separator
stdout_separator_flag="$(awk -F '--stdout_separator ' '{printf $2}' <<< "${args[@]}")"
stdout_separator_flag=${stdout_separator_flag/ '--'*}
[ ! -z "$stdout_separator_flag" ] && \
stdout_separator="$stdout_separator_flag"
2016-02-19 13:05:48 +00:00
for func in "${args[@]}"; do
case "$func" in
"--"*) break ;;
*)
"get$func" 2>/dev/null
eval output="\$$func"
2016-03-03 05:35:24 +00:00
stdout+="${output}${stdout_separator}"
2016-02-19 13:05:48 +00:00
;;
esac
done
2016-03-03 05:35:24 +00:00
printf "%s" "${stdout%%${stdout_separator}}"
2016-02-19 13:05:48 +00:00
exit
}
# }}}
# Underline {{{
getunderline () {
case "$underline" in
"on")
underline=$(printf %"$length"s)
underline=${underline// /$underline_char}
;;
"off") underline="" ;;
esac
}
# }}}
# Colors {{{
colors () {
2016-02-23 05:52:25 +00:00
# Change color of logo based on distro
case "$ascii_distro" in
2016-02-23 06:13:23 +00:00
"Arch"* | "Antergos"*)
2016-02-23 05:52:25 +00:00
setcolors 6 4
;;
"CentOS"*)
setcolors 3 2 4 5 7
;;
2016-03-25 08:34:05 +00:00
"CRUX"* | "Chakra"* | "gNewSense"* | "SailfishOS"* | "Alpine"* | "Ubuntu-GNOME"* | "Qubes"*)
2016-02-23 05:52:25 +00:00
setcolors 4 5 7
;;
"Chrom"*)
setcolors 2 1 3 4 7
ascii_distro="chrome"
;;
"Debian"* | "FreeBSD"* | "Elementary"* | "CrunchBang"* | "Ubuntu"*)
setcolors 7 1 3
;;
2016-02-23 06:13:23 +00:00
"Red"*)
2016-02-23 05:52:25 +00:00
setcolors 7 1 3
ascii_distro="redhat"
;;
"Fedora"* | "Sabayon"* | "Frugalware"* | "Exherbo"*)
setcolors 7 4 1
;;
2016-03-10 03:36:02 +00:00
"Gentoo"* | "Funtoo"* | "SteamOS"*)
2016-02-23 05:52:25 +00:00
setcolors 7 5
;;
"Kali"*)
setcolors 4 8
;;
2016-03-13 11:49:37 +00:00
*"OS X"* )
2016-02-23 05:52:25 +00:00
setcolors 2 3 1 1 5 4
2016-03-13 11:49:37 +00:00
ascii_distro="mac"
2016-02-23 05:52:25 +00:00
;;
"OpenMandriva"*)
setcolors 4 3
;;
"Mageia"*)
setcolors 7 6
;;
"Peppermint"*)
setcolors 7 1
;;
*"Mint"*)
setcolors 7 2
ascii_distro="mint"
;;
"LMDE"* | "Chapeau"*)
setcolors 7 2
;;
"NetBSD"* | "Parabola"* | "Tails"* | "BLAG"*)
setcolors 5 7
;;
"OpenBSD"*)
setcolors 3 3 6 1 8
;;
2016-03-13 11:49:37 +00:00
"OpenSuse"* | "Manjaro"* | "Deepin"*)
2016-02-23 05:52:25 +00:00
setcolors 2 7
;;
2016-03-17 03:16:30 +00:00
"PCLinuxOS"* | "Slackware"* | "KaOS"* | "Kubuntu"* | "Lubuntu"* | "Xubuntu"*)
2016-02-23 10:20:36 +00:00
setcolors 4 7 1
2016-02-23 05:52:25 +00:00
;;
"Scientific"*)
setcolors 4 1 7
;;
"Solus"*)
setcolors 7 8
;;
"Trisquel"* | "NixOS"* | "Zorin"*)
setcolors 4 6
;;
"void"*)
setcolors 2 8
2016-02-23 05:52:25 +00:00
;;
"Windows 10"*)
setcolors 6
ascii_distro="windows10"
;;
"Windows"*)
setcolors 1 2 4 3
;;
2016-02-23 10:20:36 +00:00
"Raspbian"* | *)
setcolors 2 1
;;
2016-02-23 05:52:25 +00:00
esac
# Overwrite distro colors if '$ascii_colors' doesn't
# equal 'distro'.
[ "${ascii_colors[0]}" != "distro" ] && \
setcolors ${ascii_colors[@]}
2015-12-30 10:18:17 +00:00
}
2016-02-23 05:52:25 +00:00
setcolors () {
c1="\033[38;5;${1}m"
c2="\033[38;5;${2}m"
c3="\033[38;5;${3}m"
c4="\033[38;5;${4}m"
c5="\033[38;5;${5}m"
c6="\033[38;5;${6}m"
if [ "${colors[0]}" == "distro" ]; then
title_color="\033[38;5;${1}m"
at_color="\033[38;5;7m"
underline_color="\033[38;5;7m"
subtitle_color="\033[38;5;${2}m"
colon_color="\033[38;5;7m"
info_color="\033[38;5;7m"
# If the second color is white use the first for the subtitle
[ "$2" == 7 ] && subtitle_color="\033[38;5;${1}m"
else
title_color="\033[38;5;${colors[0]}m"
at_color="\033[38;5;${colors[1]}m"
underline_color="\033[38;5;${colors[2]}m"
subtitle_color="\033[38;5;${colors[3]}m"
colon_color="\033[38;5;${colors[4]}m"
info_color="\033[38;5;${colors[5]}m"
fi
2016-01-20 22:49:50 +00:00
}
2016-03-04 02:15:03 +00:00
color () {
printf "%b%s" "\033[38;5;${1}m"
}
2016-02-23 05:52:25 +00:00
# }}}
# Bold {{{
bold () {
case "$bold" in
"on") bold="\033[1m" ;;
"off") bold="" ;;
esac
}
# }}}
# Linebreak {{{
getlinebreak () {
linebreak=" "
}
# }}}
clear="\033[0m"
2015-12-31 00:21:10 +00:00
2015-12-30 10:18:17 +00:00
# }}}
2016-01-29 15:14:29 +00:00
# Other {{{
# Get script directory {{{
getscriptdir () {
# Use $0 to get the script's physical path.
2016-01-30 05:31:22 +00:00
cd "${0%/*}" || exit
2016-01-29 15:14:29 +00:00
script_dir=${0##*/}
# Iterate down a (possible) chain of symlinks.
while [ -L "$script_dir" ]; do
2016-01-30 05:31:22 +00:00
script_dir="$(readlink "$script_dir")"
cd "${script_dir%/*}" || exit
2016-01-29 15:14:29 +00:00
script_dir="${script_dir##*/}"
done
# Final directory
script_dir="$(pwd -P)"
}
# }}}
# Source Config {{{
# Check for $config_file first
getconfig () {
# Check $config_file
2016-01-29 15:14:29 +00:00
if [ -f "$config_file" ]; then
source "$config_file"
return
fi
mkdir -p "$HOME/.config/neofetch/"
2016-01-29 15:14:29 +00:00
2016-02-28 00:44:45 +00:00
# Check $HOME/.config/neofetch and create the
2016-01-29 15:14:29 +00:00
# dir/files if they don't exist.
2016-02-28 00:44:45 +00:00
if [ -f "$HOME/.config/neofetch/config" ]; then
source "$HOME/.config/neofetch/config"
2016-01-29 15:18:27 +00:00
2016-02-28 00:44:45 +00:00
elif [ -f "/usr/share/neofetch/config" ]; then
cp "/usr/share/neofetch/config" "$HOME/.config/neofetch"
source "$HOME/.config/neofetch/config"
2016-01-29 15:18:27 +00:00
2016-02-28 00:44:45 +00:00
elif [ -f "/usr/local/share/neofetch/config" ]; then
cp "/usr/local/share/neofetch/config" "$HOME/.config/neofetch"
source "$HOME/.config/neofetch/config"
2016-01-29 15:14:29 +00:00
else
getscriptdir
2016-02-28 00:44:45 +00:00
cp "$script_dir/config/config" "$HOME/.config/neofetch"
source "$HOME/.config/neofetch/config"
2016-01-29 15:14:29 +00:00
fi
}
# Check the commandline flags early for '--config none/off'
case "$@" in
*"--config off"* | *'--config "off"'* | *"--config 'off'"* | \
*"--config none"* | *'--config "none"'* | *"--config 'none'"* | *"--stdout"*)
config="off"
;;
esac
[ "$config" == "on" ] && getconfig
2016-01-29 15:14:29 +00:00
# }}}
2016-03-02 23:12:21 +00:00
# Progress Bars {{{
bar() {
# Get the values
2016-03-03 04:23:14 +00:00
elapsed=$(($1 * progress_length / $2))
2016-03-02 23:12:21 +00:00
# Create the bar with spaces
prog=$(printf %"$elapsed"s)
total=$(printf %"$((progress_length - elapsed))"s)
2016-03-02 23:12:21 +00:00
# Set the colors and swap the spaces for $progress_char
bar="\033[38;5;${progress_color_elapsed}m${prog// /$progress_char}"
bar+="\033[38;5;${progress_color_total}m${total// /$progress_char}"
printf "%b%s\n" "${bar}${clear}"
}
# }}}
2016-01-29 15:14:29 +00:00
# }}}
# Usage {{{
usage () { cat << EOF
2016-02-28 00:44:45 +00:00
usage: neofetch --option "value" --option "value"
NOTE: There's also a config option for each flag below.
Info:
--disable infoname Allows you to disable an info line from appearing
in the output.
NOTE: You can supply multiple args. eg.
2016-02-28 00:44:45 +00:00
'neofetch --disable cpu gpu disk shell'
--osx_buildversion on/off Hide/Show Mac OS X build version.
2016-03-13 12:12:58 +00:00
--osx_codename on/off Hide/Show Mac OS X codename.
--os_arch on/off Hide/Show Windows architecture.
--speed_type type Change the type of cpu speed to display.
Possible values: current, min, max, bios,
scaling_current, scaling_min, scaling_max
NOTE: This only support Linux with cpufreq.
--cpu_shorthand type Shorten the output of CPU
2016-03-11 02:59:22 +00:00
Possible values: name, speed, tiny, on, off
2016-03-15 07:55:35 +00:00
--cpu_cores on/off Whether or not to display the number of CPU cores
--kernel_shorthand on/off Shorten the output of kernel
--uptime_shorthand on/off Shorten the output of uptime (tiny, on, off)
--gpu_shorthand on/off Shorten the output of GPU (tiny, on, off)
--gtk_shorthand on/off Shorten output of gtk theme/icons
--gtk2 on/off Enable/Disable gtk2 theme/icons output
--gtk3 on/off Enable/Disable gtk3 theme/icons output
--shell_path on/off Enable/Disable showing \$SHELL path
--shell_version on/off Enable/Disable showing \$SHELL version
--battery_num num Which battery to display, default value is 'all'
--battery_shorthand on/off Whether or not each battery gets its own line/title
--ip_host url Url to ping for public IP
--song_shorthand on/off Print the Artist/Title on seperate lines
--birthday_shorthand on/off Shorten the output of birthday
--birthday_time on/off Enable/Disable showing the time in birthday output
--birthday_format format Format the birthday output. (Uses 'date' cmd format)
Text Formatting:
--colors x x x x x x Changes the text colors in this order:
title, @, underline, subtitle, colon, info
--underline_char char Character to use when underlining title
--line_wrap on/off Enable/Disable line wrapping
--bold on/off Enable/Disable bold text
--prompt_height num Set this to your prompt height to fix issues with
the text going off screen at the top
Color Blocks:
--color_blocks on/off Enable/Disable the color blocks
--block_width num Width of color blocks
--block_range start end Range of colors to print as blocks
2016-03-02 23:12:21 +00:00
Progress Bars:
--progress_char char Character to use when drawing progress bars.
2016-03-02 23:41:13 +00:00
--progress_length num Length in spaces to make the progress bars.
2016-03-12 22:14:56 +00:00
--progress_colors num num Colors to make the progress bar.
Set in this order: elapsed, total
2016-03-12 20:58:46 +00:00
--cpu_display mode1 mode2 Which shorthand to use and how CPU usage should be printed
mode1 takes: name, speed, tiny, on, off
mode2 takes: info, bar, infobar, barinfo
--memory_display mode Which way should the memory progress bar be added
Takes bar, infobar, barinfo
--battery_display mode Which way should the battery progress bar be added
Takes bar, infobar, barinfo
--disk_display mode Which way should the disk progress bar be added
Takes bar, infobar, barinfo, perc
2016-03-02 23:12:21 +00:00
Image:
--image type Image source. Where and what image we display.
Possible values: wall, ascii,
/path/to/img, /path/to/dir/, off
2016-02-24 01:19:55 +00:00
--size 20px | --size 20% Size to make the image, takes pixels or a percentage.
--image_backend w3m/iterm2 Which program to use to draw images.
--image_position left/right Where to display the image: (Left/Right)
--crop_mode mode Which crop mode to use
Takes the values: normal, fit, fill
--crop_offset value Change the crop offset for normal mode.
Possible values: northwest, north, northeast,
west, center, east, southwest, south, southeast
--xoffset px How close the image will be to the left edge of the
window. This only works with w3m.
--yoffset px How close the image will be to the top edge of the
window. This only works with w3m.
--gap num Gap between image and text.
NOTE: --gap can take a negative value which will
move the text closer to the left side.
--clean Remove all cropped images
2016-01-27 11:33:22 +00:00
Ascii:
--ascii value Where to get the ascii from, Possible values:
distro, /path/to/ascii
2016-03-05 22:08:59 +00:00
--ascii_colors x x x x x x Colors to print the ascii art
--ascii_distro distro Which Distro's ascii art to print
2016-01-27 11:33:22 +00:00
2016-02-05 23:49:06 +00:00
Stdout:
2016-02-28 00:44:45 +00:00
--stdout info info Launch neofetch in stdout mode which prints the info
2016-02-05 23:49:06 +00:00
in a plain-text format that you can use with
lemonbar etc.
2016-03-05 22:08:59 +00:00
--stdout_separator string String to use as a separator in stdout mode.
2016-02-05 23:49:06 +00:00
Screenshot:
--scrot /path/to/img Take a screenshot, if path is left empty the screen-
shot function will use \$scrot_dir and \$scrot_name.
--scrot_cmd cmd Screenshot program to launch
2016-02-05 23:49:06 +00:00
Other:
--config /path/to/config Specify a path to a custom config file
--config none Launch the script without a config file
--help Print this text and exit
EOF
exit 1
}
# }}}
# Args {{{
2016-01-06 00:18:02 +00:00
while [ "$1" ]; do
2015-12-30 10:18:17 +00:00
case $1 in
# Info
--os_arch) os_arch="$2" ;;
2016-01-28 01:44:06 +00:00
--osx_buildversion) osx_buildversion="$2" ;;
--osx_codename) osx_codename="$2" ;;
2016-03-15 09:15:24 +00:00
--cpu_cores) cpu_cores="$2" ;;
--speed_type) speed_type="$2" ;;
--kernel_shorthand) kernel_shorthand="$2" ;;
--uptime_shorthand) uptime_shorthand="$2" ;;
--cpu_shorthand) cpu_shorthand="$2" ;;
--gpu_shorthand) gpu_shorthand="$2" ;;
--gtk_shorthand) gtk_shorthand="$2" ;;
--gtk2) gtk2="$2" ;;
--gtk3) gtk3="$2" ;;
--shell_path) shell_path="$2" ;;
--shell_version) shell_version="$2" ;;
--battery_num) battery_num="$2" ;;
--battery_shorthand) battery_shorthand="$2" ;;
--ip_host) public_ip_host="$2" ;;
--song_shorthand) song_shorthand="$2" ;;
2016-01-30 11:41:58 +00:00
--birthday_shorthand) birthday_shorthand="$2" ;;
--birthday_time) birthday_time="$2" ;;
--birthday_format) birthday_format="$2" ;;
--disable)
for func in "$@"; do
case "$func" in
"--disable") continue ;;
"--"*) return ;;
*) unset -f "get$func" ;;
esac
done
;;
2015-12-30 10:18:17 +00:00
# Text Colors
2016-02-23 05:52:25 +00:00
--colors)
unset colors
for arg in "$2" "$3" "$4" "$5" "$6" "$7"; do
case "$arg" in
"--"*) break ;;
*) colors+=($arg)
esac
done
colors+=(7 7 7 7 7 7)
;;
2015-12-31 00:21:10 +00:00
# Text Formatting
--underline) underline="$2" ;;
--underline_char) underline_char="$2" ;;
--line_wrap) line_wrap="$2" ;;
--bold) bold="$2" ;;
--prompt_height) prompt_height="$2" ;;
2015-12-30 10:18:17 +00:00
# Color Blocks
--color_blocks) color_blocks="$2" ;;
--block_range) start=$2; end=$3 ;;
2016-01-03 08:55:09 +00:00
--block_width) block_width="$2" ;;
2015-12-30 10:18:17 +00:00
2016-03-02 23:12:21 +00:00
# Progress Bars
--progress_char) progress_char="$2" ;;
--progress_length) progress_length="$2" ;;
2016-03-02 23:12:21 +00:00
--progress_colors)
progress_color_elapsed="$2"
progress_color_total="$3"
;;
2016-03-12 12:01:20 +00:00
--cpu_display)
cpu_shorthand="$2"
2016-03-12 20:58:46 +00:00
cpu_display="$3"
2016-03-12 12:01:20 +00:00
;;
2016-03-12 20:58:46 +00:00
--memory_display) memory_display="$2" ;;
--battery_display) battery_display="$2" ;;
--disk_display) disk_display="$2" ;;
2016-03-02 23:12:21 +00:00
2015-12-30 10:18:17 +00:00
# Image
--image)
image="$2"
case "$2" in "--"* | "") image="ascii" ;; esac
;;
--size) image_size="$2" ;;
--image_backend) image_backend="$2" ;;
--image_position) image_position="$2" ;;
--crop_mode) crop_mode="$2" ;;
--crop_offset) crop_offset="$2" ;;
2015-12-30 10:18:17 +00:00
--xoffset) xoffset="$2" ;;
--yoffset) yoffset="$2" ;;
2015-12-31 00:21:10 +00:00
--gap) gap="$2" ;;
2016-01-31 10:33:02 +00:00
--clean) rm -rf "$thumbnail_dir" || exit ;;
2015-12-30 10:18:17 +00:00
2016-01-27 11:33:22 +00:00
# Ascii
--ascii)
image="ascii"
ascii="$2"
case "$2" in "--"* | "") ascii="distro" ;; esac
;;
--ascii_colors)
unset ascii_colors
for arg in "$2" "$3" "$4" "$5" "$6" "$7"; do
case "$arg" in
"--"*) break ;;
*) ascii_colors+=($arg)
esac
done
ascii_colors+=(7 7 7 7 7 7)
;;
--ascii_distro)
ascii_distro="$2"
case "$2" in "--"* | "") ascii_distro="$distro" ;; esac
;;
2016-01-27 11:33:22 +00:00
--ascii_logo_size) ascii_logo_size="$2" ;;
# Screenshot
2016-03-18 22:37:29 +00:00
--scrot | -s)
scrot="on"
if [ "$2" ]; then
scrot_name="${2##*/}"
scrot_dir="${2/$scrot_name}"
fi
;;
--scrot_cmd) scrot_cmd="$2" ;;
# Stdout
2016-02-05 13:50:45 +00:00
--stdout)
2016-03-17 05:10:16 +00:00
unset info_color colors cpu_display bar prin
stdout_mode="on"
config="off"
case "$2" in
2016-03-14 11:31:40 +00:00
"--"* | "") printf "%s\n" "--stdout requires at least one argument"; exit ;;
2016-03-17 05:10:16 +00:00
*) shift; args=("$@"); stdout ;;
esac
2016-02-05 13:50:45 +00:00
;;
2015-12-30 10:18:17 +00:00
# Other
--config)
case "$2" in
"none" | "off") config="off" ;;
*) config_file="$2"; config="on"; getconfig ;;
esac
;;
2015-12-30 10:18:17 +00:00
--help) usage ;;
esac
2016-01-06 00:18:02 +00:00
shift
2015-12-30 10:18:17 +00:00
done
# }}}
# OS overides {{{
# Overide OS X codename
case "$osx_codename" in
"off") distro=${distro/${codename}/Mac OS X} ;;
esac
2016-03-15 06:15:56 +00:00
case "$osx_buildversion" in
"off") distro=${distro/ ${osx_build}} ;;
esac
# }}}
# Call Functions and Finish Up {{{
2015-12-30 10:18:17 +00:00
# Restore cursor and clear screen on ctrl+c
trap 'printf "\033[?25h"; clear; exit' 2
2016-02-23 05:52:25 +00:00
# Get colors / bold
colors
bold
2016-01-30 06:44:52 +00:00
if [ "$image" != "off" ]; then
# If the script exits for any reason, unhide the cursor.
trap 'printf "\033[?25h"' EXIT
# Clear the scren
clear
2016-01-31 08:23:31 +00:00
# Hide the cursor
printf "\033[?25l"
2016-01-30 06:44:52 +00:00
# Find w3mimgdisplay
[ "$image_backend" == "w3m" ] && \
[ "$image" != "ascii" ] && \
getw3m_img_path
2016-01-30 06:44:52 +00:00
# Get the image
getimage
fi
2015-12-30 10:18:17 +00:00
# Display the image if enabled
if [ "$image" != "off" ] && [ "$image" != "ascii" ]; then
case "$image_backend" in
"w3m")
printf "%b%s\n" "0;1;$xoffset;$yoffset;$image_size;$image_size;;;;;$img\n4;\n3;" |\
$w3m_img_path 2>/dev/null || padding="\033[0C"
;;
"iterm2")
printf "%b%s\a\n" "\033]1337;File=width=${image_size}px;height=${image_size}px;inline=1:$(base64 < "$img")"
;;
esac
fi
2015-12-31 00:21:10 +00:00
2016-01-31 08:23:31 +00:00
# Disable line wrap
[ "$line_wrap" == "off" ] && printf "\033[?7l"
# Move cursor to the top
[ "$image" != "off" ] && printf "\033[0H"
# Print the info
printinfo
if [ "$image" != "off" ]; then
2016-01-31 08:23:31 +00:00
# Get cursor position
2016-03-25 11:13:39 +00:00
info_height="$(IFS=';' read -srdR -p $'\033[6n' ROW COL; printf "%s" "${ROW#*[}")"
2016-01-31 08:23:31 +00:00
# Set cursor position dynamically based on height of ascii/text.
[ "$lines" -lt "$info_height" ] && lines="$info_height"
printf "%b%s" "\033[${lines}H\033[${prompt_height}A"
fi
# Re-enable line wrap
[ "$line_wrap" == "off" ] && printf "%b%s" "\033[?7h"
# If enabled take a screenshot
2016-01-29 14:07:01 +00:00
if [ "$scrot" == "on" ]; then
takescrot
fi
# }}}