2016-01-04 13:09:23 +11:00
#!/usr/bin/env bash
2016-04-12 10:21:11 +10:00
# set -x
2016-02-23 21:15:17 +11:00
# vim: fdm=marker:noai:ts=4:sw=4
2016-01-30 02:14:29 +11:00
#
2016-02-28 11:44:45 +11:00
# Neofetch info about your system
# https://github.com/dylanaraps/neofetch
2015-12-30 21:18:17 +11:00
#
# Created by Dylan Araps
2016-01-05 15:02:24 +11:00
# https://github.com/dylanaraps/
2015-12-30 21:18:17 +11:00
2016-04-01 09:47:48 +11:00
version="${BASH_VERSION/.*}"
2016-03-31 10:35:56 +11:00
SYS_LOCALE="${LANG:-C}"
2016-04-01 09:47:48 +11:00
XDG_CONFIG_HOME="${XDG_CONFIG_HOME:-${HOME}/.config}"
2016-02-24 09:30:11 +11:00
# Speed up script by not using unicode
2016-01-03 17:54:16 +11:00
export LC_ALL=C
2016-02-04 18:42:54 +11:00
export LANG=C
2016-01-06 18:34:34 +11:00
2016-06-13 16:14:03 +10:00
# Set no case match.
shopt -s nocasematch
2016-02-21 08:42:17 +11:00
2016-08-12 17:05:14 +10:00
# Gather Info {{{
2016-01-26 23:06:53 +11:00
# Operating System {{{
2016-08-13 21:28:23 +10:00
getos() {
case "$(uname)" in
"Linux") os="Linux" ;;
"Darwin") os="$(sw_vers -productName)" ;;
2016-10-16 09:48:25 +07:00
*"BSD" | "DragonFly" | "Bitrig") os="BSD" ;;
2016-08-13 21:28:23 +10:00
"CYGWIN"*) os="Windows" ;;
"SunOS") os="Solaris" ;;
*) printf "%s\n" "Unknown OS detected: $(uname)"; exit 1 ;;
esac
}
2015-12-30 21:18:17 +11:00
2016-01-26 23:06:53 +11:00
# }}}
2016-08-14 13:26:30 +10:00
# Model {{{
getmodel() {
case "$os" in
"Linux")
2016-08-27 08:48:43 +10:00
if [ -f /sys/devices/virtual/dmi/id/product_name ] ||\
[ -f /sys/devices/virtual/dmi/id/product_version ]; then
model="$(cat /sys/devices/virtual/dmi/id/product_{name,version} 2>/dev/null)"
model="${model/To Be Filled*}"
elif [ -f /sys/firmware/devicetree/base/model ]; then
model="$(< /sys/firmware/devicetree/base/model)"
elif [ -f /tmp/sysinfo/model ]; then
model="$(< /tmp/sysinfo/model)"
fi
2016-08-14 13:26:30 +10:00
;;
2016-08-14 14:16:25 +10:00
"Mac OS X") model="$(sysctl -n hw.model)" ;;
2016-08-14 13:26:30 +10:00
"iPhone OS")
case "${ios_model:-$(uname -m)}" in
"iPad1,1") model="iPad" ;;
"iPad2,"[1-4]) model="iPad2" ;;
"iPad3,"[1-3]) model="iPad3" ;;
"iPad3,"[4-6]) model="iPad4" ;;
"iPad4,"[1-3]) model="iPad Air" ;;
"iPad5,"[3-4]) model="iPad Air 2" ;;
"iPad6,"[7-8]) model="iPad Pro (12.9 Inch)" ;;
"iPad6,"[3-4]) model="iPad Pro (9.7 Inch)" ;;
"iPad2,"[5-7]) model="iPad mini" ;;
"iPad4,"[4-6]) model="iPad mini 2" ;;
"iPad4,"[7-9]) model="iPad mini 3" ;;
"iPad5,"[1-2]) model="iPad mini 4" ;;
"iPhone1,1") model="iPhone" ;;
"iPhone1,2") model="iPhone 3G" ;;
"iPhone2,1") model="iPhone 3GS" ;;
"iPhone3,"[1-3]) model="iPhone 4" ;;
"iPhone4,1") model="iPhone 4S" ;;
"iPhone5,"[1-2]) model="iPhone 4" ;;
"iPhone5,"[3-4]) model="iPhone 5c" ;;
"iPhone6,"[1-2]) model="iPhone 5s" ;;
"iPhone7,2") model="iPhone 6" ;;
"iPhone7,1") model="iPhone 6 Plus" ;;
"iPhone8,1") model="iPhone 6s" ;;
"iPhone8,2") model="iPhone 6s Plus" ;;
"iPhone8,4") model="iPhone SE" ;;
"iPod1,1") model="iPod touch" ;;
"ipod2,1") model="iPod touch 2G" ;;
"ipod3,1") model="iPod touch 3G" ;;
"ipod4,1") model="iPod touch 4G" ;;
"ipod5,1") model="iPod touch 5G" ;;
"ipod7,1") model="iPod touch 6G" ;;
esac
;;
2016-08-14 15:23:19 +10:00
2016-08-19 10:39:12 +10:00
"BSD")
model="$(sysctl -n hw.vendor hw.product 2>/dev/null)"
;;
2016-08-14 15:23:19 +10:00
"Windows")
model="$(wmic computersystem get manufacturer,model /value)"
model="${model/Manufacturer'='}"
model="${model/Model'='}"
2016-10-02 12:01:22 +11:00
model="${model//*To Be Filled*}"
2016-08-14 15:23:19 +10:00
;;
2016-08-14 17:41:09 +07:00
"Solaris")
model="$(prtconf -b | awk -F':' '/banner-name/ {printf $2}')"
;;
2016-08-14 13:26:30 +10:00
esac
}
# }}}
2016-01-26 23:06:53 +11:00
# Distro {{{
2016-08-12 20:53:04 +10:00
getdistro() {
2016-06-12 16:18:49 +10:00
[ "$distro" ] && return
2016-02-15 12:39:02 +11:00
2016-04-05 00:59:04 +10:00
case "$os" in
"Linux" )
2016-09-18 16:58:01 +07:00
if grep -q 'Microsoft' /proc/version >/dev/null 2>&1 || \
grep -q 'Microsoft' /proc/sys/kernel/osrelease >/dev/null 2>&1; then
case "$distro_shorthand" in
"on") distro="$(lsb_release -sir 2>/dev/null) [Windows 10]" ;;
"tiny") distro="Windows 10" ;;
*) distro="$(lsb_release -sd 2>/dev/null) on Windows 10" ;;
esac
2016-10-02 11:33:31 +11:00
ascii_distro="Windows 10"
2016-09-18 16:58:01 +07:00
elif type -p lsb_release >/dev/null 2>&1; then
2016-08-28 23:11:01 +07:00
case "$distro_shorthand" in
2016-08-31 21:43:53 +07:00
"on") distro="$(lsb_release -sir 2>/dev/null)" ;;
"tiny") distro="$(lsb_release -si 2>/dev/null)" ;;
*) distro="$(lsb_release -sd 2>/dev/null)" ;;
2016-08-28 23:11:01 +07:00
esac
2016-02-16 21:54:21 +11:00
2016-08-29 21:36:57 +07:00
elif type -p guix >/dev/null 2>&1; then
distro="GuixSD"
2016-04-05 00:59:04 +10:00
elif type -p crux >/dev/null 2>&1; then
distro="$(crux)"
2016-08-31 21:43:53 +07:00
case "$distro_shorthand" in
"on") distro="${distro//version}" ;;
"tiny") distro="${distro//version*}" ;;
esac
2016-02-13 21:14:50 +11:00
2016-04-05 00:59:04 +10:00
else
2016-08-31 21:43:53 +07:00
# Workarounds are included in every shorthand option
case "$distro_shorthand" in
"on")
2016-10-01 10:35:52 +10:00
distro="$(awk -F'=' '/^NAME|VERSION_ID=/ {print $2; exit}' /etc/*ease /usr/lib/*ease)"
2016-08-31 21:43:53 +07:00
[ -z "$distro" ] && distro="$(awk -F'=' '/^DISTRIB_ID|DISTRIB_RELEASE=/ {print $2}' /etc/openwrt_release)"
2016-10-02 09:12:48 +07:00
;;
2016-08-31 21:43:53 +07:00
"tiny")
2016-10-01 10:35:52 +10:00
distro="$(awk -F'=' '/^NAME=/ {print $2; exit}' /etc/*ease /usr/lib/*ease)"
2016-08-31 21:43:53 +07:00
[ -z "$distro" ] && distro="$(awk -F'=' '/^TAILS_PRODUCT_NAME=/ {print $2}' /etc/*ease)"
[ -z "$distro" ] && distro="$(awk -F'=' '/^DISTRIB_ID=/ {print $2}' /etc/openwrt_release)"
2016-10-02 09:12:48 +07:00
;;
2016-08-31 21:43:53 +07:00
2016-10-02 09:12:48 +07:00
*)
2016-10-01 10:35:52 +10:00
distro="$(awk -F'=' '/^PRETTY_NAME=/ {print $2; exit}' /etc/*ease /usr/lib/*ease)"
2016-08-31 21:43:53 +07:00
[ -z "$distro" ] && distro="$(awk -F'=' '{print $2}' /etc/*ease)"
[ -z "$distro" ] && distro="$(awk '/BLAG/ {print $1; exit}' /etc/*ease)"
[ -z "$distro" ] && distro="$(awk -F'=' '/^DISTRIB_DESCRIPTION=/ {print $2}' /etc/openwrt_release)"
2016-10-02 09:12:48 +07:00
;;
2016-08-31 21:43:53 +07:00
esac
2016-04-05 00:59:04 +10:00
fi
2016-08-31 21:43:53 +07:00
distro="${distro//\"}"
distro="${distro//\'}"
2016-04-05 00:59:04 +10:00
;;
2016-01-04 09:21:13 +11:00
2016-04-05 00:59:04 +10:00
"Mac OS X")
2016-06-12 15:51:48 +10:00
osx_version="$(sw_vers -productVersion)"
osx_build="$(sw_vers -buildVersion)"
2016-04-05 00:59:04 +10:00
2016-08-14 14:33:36 +10:00
case "$osx_version" in
"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" ;;
"10.12"*) codename="macOS Sierra" ;;
2016-10-15 23:20:25 +11:00
*) codename="macOS" ;;
2016-04-05 00:59:04 +10:00
esac
distro="$codename $osx_version $osx_build"
2016-10-08 12:40:59 +07:00
case "$distro_shorthand" in
"on") distro="${distro/ ${osx_build}}" ;;
"tiny")
case "$osx_version" in
2016-10-17 23:48:30 +11:00
"10."[4-7]*) distro="${distro/${codename}/Mac OS X}" ;;
2016-10-17 23:59:54 +11:00
"10."[8-9]* | "10.1"[0-1]*) distro="${distro/${codename}/OS X}" ;;
2016-10-17 23:48:30 +11:00
"10.12"*) distro="${distro/${codename}/macOS}" ;;
2016-10-08 12:40:59 +07:00
esac
2016-10-17 23:48:30 +11:00
distro="${distro/ ${osx_build}}"
;;
2016-10-08 12:40:59 +07:00
esac
2016-04-05 00:59:04 +10:00
;;
2016-01-18 12:09:37 +11:00
2016-05-07 20:39:00 +10:00
"iPhone OS")
2016-05-08 11:41:45 +10:00
distro="iOS $(sw_vers -productVersion)"
# "uname -m" doesn't print architecture on iOS so we force it off.
os_arch="off"
2016-05-07 20:39:00 +10:00
;;
2016-04-05 00:59:04 +10:00
"BSD")
2016-05-12 20:29:01 +10:00
distro="$(uname -s)"
2016-06-12 15:51:48 +10:00
distro="${distro/DragonFly/DragonFlyBSD}"
2016-05-14 15:19:09 +10:00
# Workaround for PCBSD as uname still displays FreeBSD.
2016-05-14 15:24:18 +10:00
[ -f "/etc/pcbsd-lang" ] && distro="PCBSD"
2016-08-05 16:01:48 -04:00
# Workaround for PacBSD as uname displays FreeBSD.
[ -f "/etc/pacbsd-release" ] && distro="PacBSD"
2016-04-05 00:59:04 +10:00
;;
2016-02-01 08:40:10 +11:00
2016-04-05 00:59:04 +10:00
"Windows")
distro="$(wmic os get Caption /value)"
# Strip crap from the output of wmic
2016-06-12 15:51:48 +10:00
distro="${distro/Caption'='}"
distro="${distro/Microsoft }"
2016-04-05 00:59:04 +10:00
;;
2016-08-02 17:52:01 +07:00
"Solaris")
2016-10-14 19:09:57 +07:00
case "$distro_shorthand" in
"on" | "tiny") distro="$(awk 'NR==1{print $1 " " $2;}' /etc/release)" ;;
*) distro="$(awk 'NR==1{print $1 " " $2 " " $3;}' /etc/release)" ;;
esac
2016-08-02 17:52:01 +07:00
;;
2016-04-05 00:59:04 +10:00
esac
2016-01-04 09:21:13 +11:00
2016-02-01 15:02:42 +11:00
# Get architecture
2016-04-05 00:49:21 +10:00
[ "$os_arch" == "on" ] && \
distro+=" $(uname -m)"
2016-04-05 00:59:04 +10:00
2016-08-19 10:03:33 +10:00
[ "${ascii_distro:-auto}" == "auto" ] && \
ascii_distro="$(trim "$distro")"
2016-01-29 23:54:12 +11:00
}
2016-01-26 23:06:53 +11:00
# }}}
# Title {{{
2016-08-12 20:53:04 +10:00
gettitle() {
2016-08-26 12:07:26 +10:00
title="${USER:-$(whoami || printf "%s" "${HOME/*\/}")}@${HOSTNAME:-$(hostname)}"
2016-01-03 17:54:16 +11:00
}
2015-12-30 21:18:17 +11:00
2016-01-26 23:06:53 +11:00
# }}}
# Kernel {{{
2016-01-03 17:54:16 +11:00
getkernel() {
2016-01-29 10:26:32 +11:00
case "$kernel_shorthand" in
"on") kernel="$(uname -r)" ;;
"off") kernel="$(uname -srm)" ;;
esac
2016-01-03 17:54:16 +11:00
}
2015-12-30 21:18:17 +11:00
2016-01-26 23:06:53 +11:00
# }}}
# Uptime {{{
2016-08-12 20:53:04 +10:00
getuptime() {
2016-10-21 16:06:51 +07:00
# Get uptime in seconds
2016-01-03 17:54:16 +11:00
case "$os" in
2016-03-26 22:46:07 +11:00
"Linux" | "Windows")
2016-10-21 16:06:51 +07:00
seconds="$(< /proc/uptime)"
seconds="${seconds/.*}"
2016-01-04 09:21:13 +11:00
;;
2016-05-12 19:49:08 +10:00
"Mac OS X" | "iPhone OS" | "BSD")
2016-01-04 15:30:14 +11:00
boot="$(sysctl -n kern.boottime)"
2016-02-19 20:47:13 +11:00
boot="${boot/'{ sec = '}"
2016-06-12 15:51:48 +10:00
boot="${boot/,*}"
2016-01-04 15:30:14 +11:00
# Get current date in seconds
2016-06-12 15:51:48 +10:00
now="$(date +%s)"
2016-10-21 16:06:51 +07:00
seconds="$((now - boot))"
;;
2016-04-29 10:05:35 +10:00
2016-10-21 16:06:51 +07:00
"Solaris")
seconds="$(kstat -p unix:0:system_misc:snaptime | awk '{print $2}')"
seconds="${seconds/.*}"
;;
esac
2016-04-29 10:05:35 +10:00
2016-10-21 16:06:51 +07:00
days="$((seconds / 60 / 60 / 24)) days"
hours="$((seconds / 60 / 60 % 24)) hours"
minutes="$((seconds / 60 % 60)) minutes"
2016-04-29 10:27:43 +10:00
2016-10-21 16:06:51 +07:00
case "$days" in
"0 days") unset days ;;
"1 days") days="${days/s}" ;;
esac
2016-04-29 10:27:43 +10:00
2016-10-21 16:06:51 +07:00
case "$hours" in
"0 hours") unset hours ;;
"1 hours") hours="${hours/s}" ;;
esac
2016-08-02 17:52:01 +07:00
2016-10-21 16:06:51 +07:00
case "$minutes" in
"0 minutes") unset minutes ;;
"1 minutes") minutes="${minutes/s}" ;;
2015-12-30 21:18:17 +11:00
esac
2016-01-04 14:31:21 +11:00
2016-10-21 16:06:51 +07:00
uptime="${days:+$days, }${hours:+$hours, }${minutes}"
uptime="${uptime%', '}"
uptime="up ${uptime:-${seconds} seconds}"
2016-01-27 11:53:12 +11:00
# Make the output of uptime smaller.
2016-01-26 12:16:39 +11:00
case "$uptime_shorthand" in
"on")
2016-06-12 15:51:48 +10:00
uptime="${uptime/up }"
uptime="${uptime/minutes/mins}"
uptime="${uptime/minute/min}"
uptime="${uptime/seconds/secs}"
2016-01-26 12:16:39 +11:00
;;
"tiny")
2016-06-12 15:51:48 +10:00
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}"
2016-10-21 10:00:09 +11:00
uptime="${uptime//,}"
2016-01-26 12:16:39 +11:00
;;
esac
2015-12-30 21:18:17 +11:00
}
2016-01-26 23:06:53 +11:00
# }}}
# Package Count {{{
2016-08-12 20:53:04 +10:00
getpackages() {
2016-02-15 23:59:05 +11:00
case "$os" in
2016-05-07 20:48:47 +10:00
"Linux" | "iPhone OS")
2016-04-26 16:26:36 +10:00
type -p pacman >/dev/null 2>&1 && \
2016-02-15 23:59:05 +11:00
packages="$(pacman -Qq --color never | wc -l)"
2016-02-15 22:59:28 +11:00
2016-04-26 16:39:22 +10:00
type -p dpkg >/dev/null 2>&1 && \
2016-06-12 16:12:21 +10:00
packages="$((packages+=$(dpkg --get-selections | grep -cv deinstall$)))"
2016-04-12 11:17:21 +10:00
2016-04-26 16:39:22 +10:00
type -p /sbin/pkgtool >/dev/null 2>&1 && \
2016-06-12 16:12:21 +10:00
packages="$((packages+=$(ls -1 /var/log/packages | wc -l)))"
2016-02-16 15:21:45 +11:00
2016-04-26 16:39:22 +10:00
type -p rpm >/dev/null 2>&1 && \
2016-06-12 16:12:21 +10:00
packages="$((packages+=$(rpm -qa | wc -l)))"
2016-02-15 09:28:51 +11:00
2016-04-26 16:39:22 +10:00
type -p xbps-query >/dev/null 2>&1 && \
2016-06-12 16:12:21 +10:00
packages="$((packages+=$(xbps-query -l | wc -l)))"
2016-01-03 17:54:16 +11:00
2016-04-26 16:39:22 +10:00
type -p pkginfo >/dev/null 2>&1 && \
2016-06-12 16:12:21 +10:00
packages="$((packages+=$(pkginfo -i | wc -l)))"
2016-01-03 17:54:16 +11:00
2016-04-26 16:39:22 +10:00
type -p pisi >/dev/null 2>&1 && \
2016-06-12 16:12:21 +10:00
packages="$((packages+=$(pisi list-installed | wc -l)))"
2016-01-03 17:54:16 +11:00
2016-04-26 16:39:22 +10:00
type -p pkg >/dev/null 2>&1 && \
2016-06-12 16:12:21 +10:00
packages="$((packages+=$(ls -1 /var/db/pkg | wc -l)))"
2015-12-30 21:18:17 +11:00
2016-04-26 16:39:22 +10:00
type -p emerge >/dev/null 2>&1 && \
2016-06-12 16:12:21 +10:00
packages="$((packages+=$(ls -d /var/db/pkg/*/* | wc -l)))"
2015-12-30 21:18:17 +11:00
2016-04-26 16:39:22 +10:00
type -p nix-env >/dev/null 2>&1 && \
2016-06-12 16:12:21 +10:00
packages="$((packages+=$(ls -d -1 /nix/store/*/ | wc -l)))"
2016-01-03 17:54:16 +11:00
2016-08-27 15:42:56 +07:00
type -p guix >/dev/null 2>&1 && \
packages="$((packages+=$(ls -d -1 /gnu/store/*/ | wc -l)))"
2016-04-26 16:39:22 +10:00
type -p apk >/dev/null 2>&1 && \
2016-06-12 16:12:21 +10:00
packages="$((packages+=$(apk info | wc -l)))"
2016-03-09 22:43:52 +11:00
2016-08-26 12:17:58 +10:00
type -p opkg >/dev/null 2>&1 && \
packages="$((packages+=$(opkg list-installed | wc -l)))"
2016-04-26 16:39:22 +10:00
type -p pacman-g2 >/dev/null 2>&1 && \
2016-06-12 16:12:21 +10:00
packages="$((packages+=$(pacman-g2 -Q | wc -l)))"
2016-02-16 16:31:55 +11:00
2016-04-26 16:39:22 +10:00
type -p cave >/dev/null 2>&1 && \
2016-06-12 16:12:21 +10:00
packages="$((packages+=$(ls -d -1 /var/db/paludis/repositories/cross-installed/*/data/* /var/db/paludis/repositories/installed/data/* | wc -l)))"
2016-02-14 19:42:27 +11:00
;;
2016-02-15 23:59:05 +11:00
"Mac OS X")
2016-04-26 17:31:13 +10:00
[ -d "/usr/local/bin" ] && \
2016-06-12 16:12:21 +10:00
packages="$(($(ls -l /usr/local/bin/ | grep -v "\(../Cellar/\|brew\)" | wc -l) - 1))"
2016-01-18 00:30:58 +11:00
2016-04-26 17:31:13 +10:00
type -p port >/dev/null 2>&1 && \
2016-06-12 16:12:21 +10:00
packages="$((packages + $(port installed 2>/dev/null | wc -l) - 1))"
2016-01-18 00:30:58 +11:00
2016-04-26 17:31:13 +10:00
type -p brew >/dev/null 2>&1 && \
2016-06-12 16:12:21 +10:00
packages="$((packages + $(find /usr/local/Cellar -maxdepth 1 2>/dev/null | wc -l) - 1))"
2016-01-18 00:30:58 +11:00
2016-04-26 17:31:13 +10:00
type -p pkgin >/dev/null 2>&1 && \
2016-06-12 16:12:21 +10:00
packages="$((packages + $(pkgin list 2>/dev/null | wc -l)))"
2016-01-03 17:54:16 +11:00
;;
2016-05-12 19:49:08 +10:00
"BSD")
2016-08-11 06:48:34 -04:00
case "$distro" in
# PacBSD has both pacman and pkg, but only pacman is used
"PacBSD"*) packages="$(pacman -Qq --color never | wc -l)" ;;
2016-01-18 16:22:21 +11:00
2016-08-11 06:48:34 -04:00
*)
if type -p pkg_info >/dev/null 2>&1; then
packages="$(pkg_info | wc -l)"
elif type -p pkg >/dev/null 2>&1; then
packages="$(pkg info | wc -l)"
fi
;;
esac
2016-01-18 12:09:37 +11:00
;;
2016-02-15 23:59:05 +11:00
"Windows")
2016-06-12 15:51:48 +10:00
packages="$(cygcheck -cd | wc -l)"
2016-01-27 11:53:12 +11:00
# Count chocolatey packages
2016-04-26 17:31:13 +10:00
[ -d "/cygdrive/c/ProgramData/chocolatey/lib" ] && \
2016-06-12 16:12:21 +10:00
packages="$((packages+=$(ls -1 /cygdrive/c/ProgramData/chocolatey/lib | wc -l)))"
2016-01-05 16:32:34 +11:00
;;
2016-08-02 17:52:01 +07:00
"Solaris")
packages="$(pkg list | wc -l)"
;;
2016-01-03 17:54:16 +11:00
esac
}
2016-01-26 23:06:53 +11:00
# }}}
# Shell {{{
2016-08-12 20:53:04 +10:00
getshell() {
2016-01-29 11:04:35 +11:00
case "$shell_path" in
2016-02-05 11:43:19 +11:00
"on") shell="$SHELL" ;;
"off") shell="${SHELL##*/}" ;;
2016-01-29 11:04:35 +11:00
esac
if [ "$shell_version" == "on" ]; then
2016-02-05 11:43:19 +11:00
shell+=" "
2016-01-29 11:04:35 +11:00
case "$shell" in
*"bash"*)
shell+="$(bash --version | head -n 1)"
2016-06-12 15:51:48 +10:00
shell="${shell/ *, version}"
2016-01-29 11:04:35 +11:00
;;
*"zsh"*)
shell+="$(zsh --version)"
2016-06-12 15:51:48 +10:00
shell="${shell/ zsh}"
2016-01-29 11:04:35 +11:00
;;
2016-01-29 15:40:52 +11:00
*"mksh"* | *"ksh")
shell+="$("$SHELL" -c 'printf "%s" "$KSH_VERSION"')"
2016-06-12 15:51:48 +10:00
shell="${shell/ * KSH}"
2016-01-29 11:04:35 +11:00
;;
2016-01-29 15:40:52 +11:00
*"tcsh"* | *"csh"*)
shell+="$("$SHELL" --version)"
2016-06-12 15:51:48 +10:00
shell="${shell/tcsh}"
shell="${shell/\(*}"
2016-01-29 15:40:52 +11:00
;;
2016-05-20 19:16:53 -06:00
*"fish"*)
shell+="$("$SHELL" -c 'printf "%s" "$FISH_VERSION"')"
;;
2016-01-29 11:04:35 +11:00
esac
2016-06-12 11:11:34 +10:00
shell="${shell/\(*\)}"
2016-01-29 11:04:35 +11:00
fi
2016-01-03 17:54:16 +11:00
}
2016-01-26 23:06:53 +11:00
# }}}
2016-02-10 22:44:23 +11:00
# Desktop Environment {{{
2016-08-12 20:53:04 +10:00
getde() {
2016-03-31 20:26:20 +11:00
case "$os" in
"Mac OS X") de="Aqua" ;;
2016-10-23 09:07:04 +11:00
"Windows")
case "$distro" in
"Windows 8"* | "Windows 10"*) de="Modern UI/Metro" ;;
*) de="Aero" ;;
esac
;;
2016-04-02 02:22:08 +11:00
*)
de="${XDG_CURRENT_DESKTOP/i3}"
2016-06-12 15:51:48 +10:00
de="${de/'X-'}"
2016-04-02 02:22:08 +11:00
;;
2016-03-31 20:26:20 +11:00
esac
2016-04-02 01:51:32 +11:00
2016-04-04 22:30:49 +10:00
if [ -n "$DISPLAY" ] && [ -z "$de" ]; then
2016-05-12 09:01:51 +10:00
de="$(xprop -root | awk '/KDE_SESSION_VERSION|^_MUFFIN|xfce4|xfce5/' 2>/dev/null)"
2016-04-02 01:51:32 +11:00
2016-04-02 01:55:31 +11:00
case "$de" in
"KDE_SESSION_VERSION"*) de="KDE${de/* = }" ;;
2016-05-08 11:30:14 +10:00
*"TDE_FULL_SESSION"*) de="Trinity" ;;
2016-10-02 18:51:34 +11:00
*"MUFFIN"*) de="$(cinnamon --version 2>/dev/null)"; de="${de:-Cinnamon}" ;;
2016-04-02 02:27:25 +11:00
*"xfce4"*) de="XFCE4" ;;
*"xfce5"*) de="XFCE5" ;;
2016-04-02 01:55:31 +11:00
esac
2016-04-02 01:51:32 +11:00
fi
2016-02-10 22:44:23 +11:00
}
# }}}
2016-01-26 23:06:53 +11:00
# Window Manager {{{
2016-08-12 20:53:04 +10:00
getwm() {
2016-02-21 07:08:50 +11:00
if [ -n "$DISPLAY" ] && [ "$os" != "Mac OS X" ]; then
2016-06-12 13:18:16 +10:00
id="$(xprop -root -notype | awk '$1=="_NET_SUPPORTING_WM_CHECK:"{print $5}' 2>/dev/null)"
wm="$(xprop -id "$id" -notype -f _NET_WM_NAME 8t 2>/dev/null)"
2016-06-12 15:51:48 +10:00
wm="${wm/*_NET_WM_NAME = }"
wm="${wm/\"}"
wm="${wm/\"*}"
2016-02-17 16:54:18 +11:00
2016-02-25 11:59:38 +11:00
# Fallback for Wayland wms
case "$wm" in
2016-10-17 18:39:56 +11:00
"xwlc") wm="$(ps -e | grep -m 1 -oE "sway|orbment|velox|orbital")" ;;
2016-02-25 11:59:38 +11:00
esac
2016-01-30 20:02:20 +11:00
else
case "$os" in
2016-02-10 22:44:23 +11:00
"Mac OS X") wm="Quartz Compositor" ;;
2016-10-17 18:39:56 +11:00
"Windows")
wm="$(tasklist | grep -m 1 -o "bugn\|Windawesome\|blackbox\|emerge\|litestep")"
2016-10-17 19:52:31 +11:00
[ "$wm" == "blackbox" ] && wm="bbLean (Blackbox)"
2016-10-17 19:47:48 +11:00
2016-10-17 19:51:00 +11:00
if [ "$wm" ]; then
2016-10-17 19:47:48 +11:00
wm="$wm, Explorer"
else
wm="Explorer"
fi
2016-10-17 18:39:56 +11:00
;;
2016-01-30 20:02:20 +11:00
esac
2016-01-30 12:56:37 +11:00
fi
2016-10-17 18:39:56 +11:00
# Don't uppercase i3
[ "$version" -ge 4 ] && \
[ "$wm" != "i3" ] && \
wm="${wm^}"
2015-12-31 11:21:10 +11:00
}
2015-12-30 21:18:17 +11:00
2016-01-26 23:06:53 +11:00
# }}}
2016-04-01 11:23:23 +11:00
# Window Manager Theme {{{
2016-08-12 20:53:04 +10:00
getwmtheme() {
2016-04-01 11:28:56 +11:00
[ -z "$wm" ] && getwm
2016-04-03 11:57:10 +10:00
[ -z "$de" ] && getde
2016-04-01 11:26:59 +11:00
2016-04-01 11:28:56 +11:00
case "$wm" in
2016-04-01 11:33:14 +11:00
'BudgieWM') wmtheme="$(gsettings get org.gnome.desktop.wm.preferences theme)" ;;
2016-04-03 11:57:10 +10:00
'E16') wmtheme="$(awk -F "= " '/theme.name/ {print $2}' "$HOME/.e16/e_config--0.0.cfg")";;
2016-04-01 14:42:38 +11:00
'Sawfish') wmtheme="$(awk -F ")" '/\(quote default-frame-style/ {print $2}' "$HOME/.sawfish/custom")" ;;
2016-04-01 11:26:59 +11:00
2016-04-01 18:34:06 +11:00
'Cinnamon' | 'Muffin' | 'Mutter (Muffin)')
2016-04-01 11:35:26 +11:00
detheme="$(gsettings get org.cinnamon.theme name)"
wmtheme="$(gsettings get org.cinnamon.desktop.wm.preferences theme)"
2016-04-01 14:50:15 +11:00
wmtheme="$detheme (${wmtheme})"
2016-04-01 11:35:26 +11:00
;;
'Compiz' | 'Mutter'* | 'GNOME Shell' | 'Gala')
if type -p gsettings >/dev/null 2>&1; then
2016-10-02 19:30:56 +11:00
wmtheme="$(gsettings get org.gnome.shell.extensions.user-theme name)"
[ -z "$wmtheme" ] && \
wmtheme="$(gsettings get org.gnome.desktop.wm.preferences theme)"
2016-04-01 11:35:26 +11:00
elif type -p gconftool-2 >/dev/null 2>&1; then
wmtheme="$(gconftool-2 -g /apps/metacity/general/theme)"
fi
2016-04-01 11:26:59 +11:00
;;
2016-04-01 11:36:19 +11:00
2016-04-01 18:46:37 +11:00
'Metacity'*)
if [ "$de" == "Deepin" ]; then
wmtheme="$(gsettings get com.deepin.wrap.gnome.desktop.wm.preferences theme 2>/dev/null)"
else
wmtheme="$(gconftool-2 -g /apps/metacity/general/theme 2>/dev/null)"
fi
2016-04-01 11:36:19 +11:00
;;
2016-04-01 11:39:53 +11:00
2016-04-01 18:27:00 +11:00
'E17' | 'Enlightenment')
2016-04-01 11:41:49 +11:00
if type -p eet >/dev/null 2>&1; then
2016-06-12 14:35:29 +10:00
wmtheme="$(eet -d "$HOME/.e/e/config/standard/e.cfg" config | awk '/value \"file\" string.*.edj/ {print $4}')"
2016-06-12 15:51:48 +10:00
wmtheme="${wmtheme##*/}"
wmtheme="${wmtheme%.*}"
2016-04-01 11:41:49 +11:00
fi
;;
2016-04-01 11:44:20 +11:00
2016-04-01 14:42:38 +11:00
'Fluxbox')
2016-06-12 14:35:29 +10:00
[ -f "$HOME/.fluxbox/init" ] && \
2016-04-01 14:42:38 +11:00
wmtheme="$(awk -F "/" '/styleFile/ {print $NF}' "$HOME/.fluxbox/init")"
;;
2016-04-01 09:40:28 +11:00
'IceWM'*)
2016-06-12 14:35:29 +10:00
[ -f "$HOME/.icewm/theme" ] && \
2016-04-01 14:42:38 +11:00
wmtheme="$(awk -F "[\",/]" '!/#/ {print $2}' "$HOME/.icewm/theme")"
;;
'Openbox')
2016-04-01 18:12:43 +11:00
if [ "$de" == "LXDE" ] && [ -f "${HOME}/.config/openbox/lxde-rc.xml" ]; then
ob_file="lxde-rc"
elif [ -f "${HOME}/.config/openbox/rc.xml" ]; then
ob_file="rc"
fi
wmtheme="$(awk -F "[<,>]" '/<theme/ {getline; print $3}' "$XDG_CONFIG_HOME/openbox/${ob_file}.xml")";
2016-04-01 14:42:38 +11:00
;;
'PekWM')
2016-06-12 14:35:29 +10:00
[ -f "$HOME/.pekwm/config" ] && \
2016-04-01 14:42:38 +11:00
wmtheme="$(awk -F "/" '/Theme/ {gsub(/\"/,""); print $NF}' "$HOME/.pekwm/config")"
;;
'Xfwm4')
[ -f "${HOME}/.config/xfce4/xfconf/xfce-perchannel-xml/xfwm4.xml" ] && \
wmtheme="$(xfconf-query -c xfwm4 -p /general/theme)"
;;
2016-04-01 14:50:15 +11:00
'KWin'*)
kdeconfigdir
2016-06-12 15:51:48 +10:00
kde_config_dir="${kde_config_dir%/}"
2016-04-01 14:50:15 +11:00
if [ -f "$kde_config_dir/share/config/kwinrc" ]; then
wmtheme="$(awk '/PluginLib=kwin3_/{gsub(/PluginLib=kwin3_/,"",$0); print $0; exit}' "$kde_config_dir/share/config/kwinrc")"
2016-04-01 17:38:06 +11:00
elif [ -f "$kde_config_dir/share/config/kdebugrc" ]; then
2016-04-01 14:50:15 +11:00
wmtheme="$(awk '/(decoration)/ {gsub(/\[/,"",$1); print $1; exit}' "$kde_config_dir/share/config/kdebugrc")"
fi
;;
2016-04-01 11:44:20 +11:00
'Quartz Compositor')
2016-06-12 15:51:48 +10:00
wmtheme="$(/usr/libexec/PlistBuddy -c "Print AppleAquaColorVariant" ~/Library/Preferences/.GlobalPreferences.plist)"
2016-04-01 11:44:20 +11:00
if [ -z "$wmtheme" ] || [ "$wmtheme" == "1" ]; then
wmtheme="Blue"
else
wmtheme="Graphite"
fi
;;
2016-04-01 11:47:16 +11:00
2016-10-17 19:55:41 +11:00
*'Explorer')
2016-04-01 14:53:31 +11:00
path="/proc/registry/HKEY_CURRENT_USER/Software/Microsoft"
path+="/Windows/CurrentVersion/Themes/CurrentTheme"
wmtheme="$(head -n1 "$path" 2>/dev/null)"
wmtheme="${wmtheme##*\\}"
wmtheme="${wmtheme%.*}"
;;
2016-10-17 19:47:48 +11:00
'Blackbox' | "bbLean"*)
2016-10-17 19:02:53 +11:00
path="$(wmic process get ExecutablePath | grep "blackbox")"
2016-10-17 19:14:19 +11:00
path="${path//'\'/'/'}"
2016-10-17 19:02:53 +11:00
2016-10-17 19:15:42 +11:00
wmtheme="$(grep "^session\.styleFile:" ${path/\.exe/.rc})"
2016-10-17 19:02:53 +11:00
wmtheme="${wmtheme/'session.styleFile: '}"
2016-10-17 19:15:42 +11:00
wmtheme="${wmtheme##*\\}"
2016-10-17 19:02:53 +11:00
wmtheme="${wmtheme%.*}"
;;
2016-04-01 11:26:59 +11:00
esac
2016-04-01 14:42:38 +11:00
2016-04-01 11:33:14 +11:00
wmtheme="${wmtheme//\'}"
2016-10-15 22:07:12 +11:00
[ "$version" -ge 4 ] && wmtheme="${wmtheme^}"
2016-04-01 11:23:23 +11:00
}
# }}}
2016-01-26 23:06:53 +11:00
# CPU {{{
2016-08-12 20:53:04 +10:00
getcpu() {
2016-05-13 09:06:51 +10:00
# NetBSD emulates the linux /proc filesystem instead of using sysctl for hw
# information so we have to use this block below which temporarily sets the
# OS to 'Linux' for the duration of this function.
2016-05-13 09:02:44 +10:00
case "$distro" in
"NetBSD"*) local os="Linux" ;;
esac
2016-01-04 09:21:13 +11:00
case "$os" in
2016-05-12 19:49:08 +10:00
"Linux" | "Windows")
# Get cpu name
cpu="$(awk -F ': | @' '/model name/ {printf $2; exit}' /proc/cpuinfo)"
2016-10-23 09:45:03 +11:00
speed_dir="/sys/devices/system/cpu/cpu0/cpufreq"
temp_dir="/sys/class/hwmon/hwmon0/temp1_input"
2016-05-12 19:49:08 +10:00
# Get cpu speed
2016-10-23 09:45:03 +11:00
if [ -d "$speed_dir" ]; then
2016-05-12 19:49:08 +10:00
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
2016-10-02 11:40:00 +11:00
# Fallback to cpuinfo_max_freq if $speed_type fails
2016-10-23 09:45:03 +11:00
read -t 1 -r speed < "${speed_dir}/${speed_type}" || \
read -t 1 -r speed < "${speed_dir}/cpuinfo_max_freq"
2016-05-12 19:49:08 +10:00
2016-06-12 15:51:48 +10:00
speed="$((speed / 100000))"
2016-05-12 19:49:08 +10:00
else
2016-06-12 15:51:48 +10:00
speed="$(awk -F ': |\\.' '/cpu MHz/ {printf $2; exit}' /proc/cpuinfo)"
speed="$((speed / 100))"
2016-05-12 19:49:08 +10:00
fi
2016-10-23 09:45:03 +11:00
# Get cpu temp
if [ "$cpu_temp" == "on" ] && [ -f "$temp_dir" ]; then
temp="$(< "$temp_dir")"
temp="$((temp * 100 / 10000))"
temp="[${temp/${temp: -1}}.${temp: -1}°C]"
fi
2016-10-21 16:26:34 +11:00
# Show/hide hyperthreaded cores
2016-10-21 16:38:02 +11:00
case "$cpu_cores" in
"logical" | "on") cores="$(grep -c ^processor /proc/cpuinfo)" ;;
"physical") cores="$(grep "^core id" /proc/cpuinfo | sort -u | wc -l)" ;;
2016-10-21 16:26:34 +11:00
esac
2016-05-12 19:49:08 +10:00
# Fix for speeds under 1ghz
if [ -z "${speed:1}" ]; then
2016-10-02 09:12:48 +07:00
speed="0.${speed}"
2016-05-12 19:49:08 +10:00
else
2016-10-02 09:12:48 +07:00
speed="${speed:0:1}.${speed:1}"
2016-05-12 19:49:08 +10:00
fi
2016-10-23 09:45:03 +11:00
cpu="$cpu @ ${speed}GHz $temp"
2016-05-12 19:49:08 +10:00
;;
2016-01-04 09:21:13 +11:00
"Mac OS X")
cpu="$(sysctl -n machdep.cpu.brand_string)"
2016-10-21 16:26:34 +11:00
# Show/hide hyperthreaded cores
2016-10-21 16:38:02 +11:00
case "$cpu_cores" in
"logical" | "on") cores="$(sysctl -n hw.logicalcpu_max)" ;;
"physical") cores="$(sysctl -n hw.physicalcpu_max)" ;;
2016-10-21 16:26:34 +11:00
esac
2016-01-04 09:21:13 +11:00
;;
2016-05-09 01:17:18 +10:00
"iPhone OS")
2016-08-14 13:26:30 +10:00
case "${ios_model:-$(uname -m)}" in
2016-05-08 14:44:15 +10:00
"iPhone1,1" | "iPhone1,2" | "iPod1,1")
cpu="Samsung S5L8900 @ 412MHz"
cores="1"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPhone2,1")
cpu="Samsung S5PC100 @ 600MHz"
cores="1"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPhone3,1" | "iPhone3,2" | "iPhone3,3" | "iPod4,1")
cpu="Apple A4 @ 800MHz"
cores="1"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPhone4,1" | "iPod5,1")
cpu="Apple A5 @ 800MHz"
cores="2"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPhone5,1" | "iPhone5,2" | "iPhone5,3" | "iPhone5,4")
cpu="Apple A6 @ 1.3GHz"
cores="2"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPhone6,1" | "iPhone6,2")
cpu="Apple A7 @ 1.3GHz"
cores="2"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPhone7,1" | "iPhone7,2")
cpu="Apple A8 @ 1.4GHz"
cores="2"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPhone8,1" | "iPhone8,2" | "iPhone8,4")
cpu="Apple A9 @ 1.85GHz"
cores="2"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPod2,1")
cpu="Samsung S5L8720 @ 533MHz"
cores="1"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPod3,1")
cpu="Samsung S5L8922 @ 600MHz"
cores="1"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPod7,1")
cpu="Apple A8 @ 1.1GHz"
cores="2"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPad1,1")
cpu="Apple A4 @ 1GHz"
cores="1"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPad2,1" | "iPad2,2" | "iPad2,3" | "iPad2,4" | "iPad2,5" | "iPad2,6" | "iPad2,7")
cpu="Apple A5 @ 1GHz"
cores="2"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPad3,1" | "iPad3,2" | "iPad3,3")
cpu="Apple A5X @ 1GHz"
cores="2"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPad3,4" | "iPad3,5" | "iPad3,6")
cpu="Apple A6X @ 1.4GHz"
cores="2"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPad4,1" | "iPad4,2" | "iPad4,3")
cpu="Apple A7 @ 1.4GHz"
cores="2"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPad4,4" | "iPad4,5" | "iPad4,6" | "iPad4,7" | "iPad4,8" | "iPad4,9")
cpu="Apple A7 @ 1.4GHz"
cores="2"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPad5,1" | "iPad5,2")
cpu="Apple A8 @ 1.5GHz"
cores="2"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPad5,3" | "iPad5,4")
cpu="Apple A8X @ 1.5GHz"
cores="3"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPad6,3" | "iPad6,4")
cpu="Apple A9X @ 2.16GHz"
cores="2"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
"iPad6,7" | "iPad6,8")
cpu="Apple A9X @ 2.26GHz"
cores="2"
2016-05-09 01:17:18 +10:00
;;
2016-05-08 14:44:15 +10:00
esac
2016-05-08 13:32:44 +10:00
;;
2016-05-12 19:49:08 +10:00
"BSD")
# Get cpu name
cpu="$(sysctl -n hw.model)"
2016-06-12 15:51:48 +10:00
cpu="${cpu/[0-9]\.*}"
cpu="${cpu/ @*}"
2016-01-19 17:33:41 +11:00
2016-05-12 19:49:08 +10:00
# Get cpu speed
2016-06-12 15:51:48 +10:00
speed="$(sysctl -n hw.cpuspeed)"
[ -z "$speed" ] && speed="$(sysctl -n hw.clockrate)"
speed="$((speed / 100))"
2016-04-04 21:18:17 +10:00
2016-05-12 19:49:08 +10:00
# Get cpu cores
2016-06-12 15:51:48 +10:00
cores="$(sysctl -n hw.ncpu)"
2016-01-19 17:36:10 +11:00
2016-04-04 21:25:42 +10:00
# Fix for speeds under 1ghz
if [ -z "${speed:1}" ]; then
2016-10-02 09:12:48 +07:00
speed="0.${speed}"
2016-04-04 21:25:42 +10:00
else
2016-10-02 09:12:48 +07:00
speed="${speed:0:1}.${speed:1}"
2016-04-04 21:25:42 +10:00
fi
2016-01-19 17:36:10 +11:00
cpu="$cpu @ ${speed}GHz"
2016-01-18 17:37:00 +11:00
;;
2016-08-02 17:52:01 +07:00
"Solaris")
# Get cpuname
cpu="$(psrinfo -pv | tail -1)"
cpu="${cpu/[0-9]\.*}"
cpu="${cpu/ @*}"
# Get cpu speed
2016-08-12 23:46:46 +10:00
speed="$(psrinfo -v | awk '/operates at/ {print $6}')"
2016-08-02 17:52:01 +07:00
speed="$((speed / 100))"
2016-10-21 20:27:35 +11:00
# Show/hide hyperthreaded cores
case "$cpu_cores" in
"logical" | "on") cores="$(kstat -m cpu_info | grep -c "chip_id")" ;;
"physical") cores="$(psrinfo -p)" ;;
esac
2016-08-02 17:52:01 +07:00
# Fix for speeds under 1ghz
if [ -z "${speed:1}" ]; then
2016-10-02 09:12:48 +07:00
speed="0.${speed}"
2016-08-02 17:52:01 +07:00
else
2016-10-02 09:12:48 +07:00
speed="${speed:0:1}.${speed:1}"
2016-08-02 17:52:01 +07:00
fi
cpu="$cpu @ ${speed}GHz"
;;
2015-12-30 23:58:20 +11:00
esac
2016-01-03 17:54:16 +11:00
# Remove uneeded patterns from cpu output
# This is faster than sed/gsub
2016-06-12 15:51:48 +10:00
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//Dual-Core}"
cpu="${cpu//Quad-Core}"
cpu="${cpu//with Radeon HD Graphics}"
2016-03-12 23:01:20 +11:00
2016-03-15 18:55:35 +11:00
# Add cpu cores to output
2016-10-21 16:38:02 +11:00
[ "$cpu_cores" != "off" ] && [ "$cores" ] && \
2016-07-29 21:35:32 +10:00
cpu="${cpu/@/(${cores}) @}"
2016-03-15 18:55:35 +11:00
2016-10-23 09:45:03 +11:00
# Remove speed from output
[ "$cpu_speed" == "off" ] && \
cpu="${cpu/@ *GHz}"
2016-03-12 23:01:20 +11:00
# Make the output of cpu shorter
case "$cpu_shorthand" in
2016-06-12 15:51:48 +10:00
"name") cpu="${cpu/@*}" ;;
"speed") cpu="${cpu#*@ }" ;;
2016-03-12 23:01:20 +11:00
"on" | "tiny")
2016-06-12 15:51:48 +10:00
cpu="${cpu/Intel }"
cpu="${cpu/Core }"
cpu="${cpu/Core? Duo }"
cpu="${cpu/AMD }"
2016-03-12 23:01:20 +11:00
case "$cpu_shorthand" in
2016-06-12 15:51:48 +10:00
"tiny") cpu="${cpu/@*}" ;;
2016-03-12 23:01:20 +11:00
esac
;;
esac
2015-12-30 23:58:20 +11:00
}
2015-12-30 21:18:17 +11:00
2016-01-26 23:06:53 +11:00
# }}}
2016-06-13 20:22:38 +10:00
# CPU Usage {{{
2016-08-12 20:53:04 +10:00
getcpu_usage() {
2016-06-13 20:22:38 +10:00
case "$os" in
2016-06-13 21:21:32 +10:00
"Windows")
cpu_usage="$(wmic cpu get loadpercentage /value)"
cpu_usage="${cpu_usage/LoadPercentage'='}"
cpu_usage="${cpu_usage//[[:space:]]}"
;;
2016-08-02 17:52:01 +07:00
"Linux" | "Mac OS X" | "iPhone OS" | "BSD" | "Solaris")
2016-06-13 20:22:38 +10:00
# Get cores if unset
if [ -z "$cores" ]; then
case "$os" in
"Linux") cores="$(awk -F ': ' '/siblings/ {printf $2; exit}' /proc/cpuinfo)" ;;
2016-06-13 21:21:32 +10:00
"Mac OS X" | "BSD") cores="$(sysctl -n hw.ncpu)" ;;
2016-08-02 17:52:01 +07:00
"Solaris") cores="$(kstat -m cpu_info | grep "chip_id" | wc -l | tr -d ' ')"
2016-06-13 20:22:38 +10:00
esac
fi
2016-06-13 22:33:34 +10:00
cpu_usage="$(ps aux | awk 'BEGIN {sum=0} {sum+=$3 }; END {print sum}')"
2016-06-13 20:22:38 +10:00
cpu_usage="$((${cpu_usage/\.*} / ${cores:-1}))"
;;
esac
# Print the bar
case "$cpu_display" in
"bar") cpu_usage="$(bar $cpu_usage 100)" ;;
"infobar") cpu_usage="${cpu_usage}% $(bar $cpu_usage 100)" ;;
"barinfo") cpu_usage="$(bar $cpu_usage 100) ${cpu_usage}%" ;;
2016-09-03 14:46:59 +07:00
*) cpu_usage="${cpu_usage}%" ;;
2016-06-13 20:22:38 +10:00
esac
}
# }}}
2016-01-26 23:06:53 +11:00
# GPU {{{
2016-08-12 20:53:04 +10:00
getgpu() {
2016-10-02 09:12:48 +07:00
case "$os" in
"Linux")
2016-02-12 00:00:41 +11:00
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-03-26 23:36:37 +11:00
gpu="$(PATH="/sbin:$PATH" lspci | grep -F "VGA")"
2016-06-12 15:51:48 +10:00
gpu="${gpu//??':'??'.'?}"
2016-01-31 12:52:28 +11:00
# Count the number of GPUs
2016-02-03 09:26:47 +11:00
count="$(printf "%s" "$gpu" | uniq -c)"
2016-06-12 15:51:48 +10:00
count="${count/ VGA*}"
count="${count/ 3D*}"
2016-01-31 12:52:28 +11:00
# 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
2016-06-12 15:51:48 +10:00
gpu="${gpu/* VGA compatible controller: }"
gpu="${gpu/* 3D controller: }"
gpu="${gpu/(rev*)}"
2016-01-21 07:20:42 +11:00
case "$gpu" in
intel*)
2016-03-30 09:44:46 +11:00
gpu="Intel Integrated Graphics"
2016-01-21 07:20:42 +11:00
;;
advanced*)
2016-06-12 15:51:48 +10:00
gpu="${gpu/Advanced Micro Devices, Inc\. }"
gpu="${gpu/'[AMD/ATI]' }"
gpu="${gpu/Tahiti PRO}"
gpu="${gpu/XTX}"
gpu="${gpu/ OEM}"
gpu="${gpu/ \[}"
gpu="${gpu/\]}"
2016-10-05 09:29:54 +11:00
gpu="${gpu/*Radeon/Radeon}"
2016-01-21 07:20:42 +11:00
2016-01-26 12:58:46 +11:00
brand="AMD "
2016-01-21 07:20:42 +11:00
;;
nvidia*)
2016-06-12 15:51:48 +10:00
gpu="${gpu/NVIDIA Corporation }"
gpu="${gpu/G????M }"
gpu="${gpu/G???? }"
gpu="${gpu/\[}"
gpu="${gpu/\] }"
2016-01-21 07:20:42 +11:00
2016-03-26 19:39:55 -04:00
brand="NVIDIA "
2016-01-26 12:58:46 +11:00
;;
*virtualbox*)
gpu="VirtualBox Graphics Adapter"
2016-01-21 07:20:42 +11:00
;;
esac
2016-01-26 12:58:46 +11:00
gpu="${brand}${gpu}"
2016-01-19 11:55:45 +11:00
;;
"Mac OS X")
2016-03-30 14:13:40 +11:00
# Use cache if it exists
2016-03-30 19:24:03 +11:00
if [ -f "/Library/Caches/neofetch/gpu" ]; then
source "/Library/Caches/neofetch/gpu"
2016-03-30 14:13:40 +11:00
else
2016-06-12 15:51:48 +10:00
gpu="$(system_profiler SPDisplaysDataType | awk -F': ' '/^\ *Chipset Model:/ {printf $2 ", "}')"
gpu="${gpu//'/ $'}"
gpu="${gpu%,*}"
2016-03-30 19:24:03 +11:00
cache "gpu" "$gpu" "/Library/Caches/"
2016-03-30 14:13:40 +11:00
fi
2016-01-19 11:55:45 +11:00
;;
2016-05-08 13:32:44 +10:00
"iPhone OS")
2016-06-12 15:51:48 +10:00
ios_model="${ios_model:-"$(uname -m)"}"
2016-05-09 01:17:18 +10:00
case "$ios_model" in
"iPhone1,1" | "iPhone1,2")
gpu="PowerVR MBX Lite 3D"
;;
"iPhone2,1" | "iPhone3,1" | "iPhone3,2" | "iPhone3,3" | "iPod3,1" | "iPod4,1" | "iPad1,1")
gpu="PowerVR SGX535"
;;
2016-05-08 14:44:15 +10:00
"iPhone4,1" | "iPad2,1" | "iPad2,2" | "iPad2,3" | "iPad2,4" | "iPad2,5" | "iPad2,6" | "iPad2,7" | "iPod5,1")
gpu="PowerVR SGX543MP2"
2016-05-09 01:17:18 +10:00
;;
"iPhone5,1" | "iPhone5,2" | "iPhone5,3" | "iPhone5,4")
gpu="PowerVR SGX543MP3"
;;
2016-05-08 14:44:15 +10:00
"iPhone6,1" | "iPhone6,2" | "iPad4,1" | "iPad4,2" | "iPad4,3" | "iPad4,4" | "iPad4,5" | "iPad4,6" | "iPad4,7" | "iPad4,8" | "iPad4,9")
gpu="PowerVR G6430"
2016-05-09 01:17:18 +10:00
;;
"iPhone7,1" | "iPhone7,2" | "iPod7,1" | "iPad5,1" | "iPad5,2")
gpu="PowerVR GX6450"
;;
"iPhone8,1" | "iPhone8,2" | "iPhone8,4")
gpu="PowerVR GT7600"
;;
"iPod1,1" | "iPod2,1")
gpu="PowerVR MBX Lite"
;;
"iPad3,1" | "iPad3,2" | "iPad3,3")
gpu="PowerVR SGX534MP4"
;;
"iPad3,4" | "iPad3,5" | "iPad3,6")
gpu="PowerVR SGX554MP4"
;;
"iPad5,3" | "iPad5,4")
gpu="PowerVR GXA6850"
;;
"iPad6,3" | "iPad6,4" | "iPad6,7" | "iPad6,8")
gpu="PowerVR 7XT"
;;
2016-05-08 14:44:15 +10:00
esac
2016-05-08 13:32:44 +10:00
;;
2016-08-02 17:52:01 +07:00
"BSD" | "Solaris")
2016-01-19 11:55:45 +11:00
case "$distro" in
2016-02-01 14:56:53 +11:00
"FreeBSD"*)
2016-06-12 15:51:48 +10:00
gpu="$(pciconf -lv 2>/dev/null | grep -B 4 "VGA" | grep "device")"
gpu="${gpu/*device*= }"
gpu="${gpu//\'}"
2016-01-19 11:55:45 +11:00
;;
2016-05-06 03:39:28 +10:00
2016-05-06 03:44:09 +10:00
*)
2016-06-12 15:51:48 +10:00
gpu="$(glxinfo | grep -F 'OpenGL renderer string')"
gpu="${gpu/'OpenGL renderer string: '}"
2016-05-06 03:39:28 +10:00
;;
2016-01-19 11:55:45 +11:00
esac
;;
"Windows")
2016-06-12 15:51:48 +10:00
gpu="$(wmic path Win32_VideoController get caption /value)"
gpu="${gpu/Caption'='}"
2016-01-19 11:55:45 +11:00
;;
esac
2016-01-19 13:52:33 +11:00
2016-03-11 20:48:06 +11:00
case "$gpu_shorthand" in
"on" | "tiny")
2016-06-12 15:51:48 +10:00
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/\/*}"
2016-03-11 20:48:06 +11:00
case "$gpu_shorthand" in
"tiny")
2016-06-12 15:51:48 +10:00
gpu="${gpu/Graphics }"
gpu="${gpu/GeForce }"
gpu="${gpu/Radeon }"
2016-03-11 20:48:06 +11:00
;;
esac
;;
esac
2016-01-31 12:52:28 +11:00
2016-10-02 18:26:50 +11:00
if [ "$gpu_brand" == "off" ]; then
gpu="${gpu/AMD}"
gpu="${gpu/NVIDIA}"
gpu="${gpu/Intel}"
fi
2016-01-31 12:52:28 +11:00
gpu="${gpu}${count}"
2016-01-19 11:55:45 +11:00
}
2016-01-26 23:06:53 +11:00
# }}}
# Memory {{{
2016-08-12 20:53:04 +10:00
getmemory() {
2016-01-04 09:21:13 +11:00
case "$os" in
2016-03-28 09:41:53 +11:00
"Linux" | "Windows")
2016-10-23 11:03:46 +11:00
# MemUsed = Memtotal + Shmem - MemFree - Buffers - Cached - SReclaimable
# Source: https://github.com/KittyKatt/screenFetch/issues/386#issuecomment-249312716
while IFS=":" read -r a b; do
case "$a" in
"MemTotal") memused="$((memused+=${b/kB}))"; memtotal="${b/kB}" ;;
"Shmem") memused="$((memused+=${b/kB}))" ;;
"MemFree" | "Buffers" | "Cached" | "SReclaimable") memused="$((memused-=${b/kB}))" ;;
esac
done < /proc/meminfo
2016-05-06 18:35:09 +10:00
2016-06-12 15:51:48 +10:00
memused="$((memused / 1024))"
2016-10-23 11:03:46 +11:00
memtotal="$((memtotal / 1024))"
2016-01-04 09:21:13 +11:00
;;
2016-05-07 21:14:46 +10:00
"Mac OS X" | "iPhone OS")
2016-06-12 17:13:26 +10:00
memtotal="$(($(sysctl -n hw.memsize) / 1024 / 1024))"
2016-06-12 15:51:48 +10:00
memwired="$(vm_stat | awk '/wired/ { print $4 }')"
memactive="$(vm_stat | awk '/active / { printf $3 }')"
memcompressed="$(vm_stat | awk '/occupied/ { printf $5 }')"
memused="$(((${memwired//.} + ${memactive//.} + ${memcompressed//.}) * 4 / 1024))"
2016-01-03 17:54:16 +11:00
;;
2016-05-12 19:49:08 +10:00
"BSD")
2016-01-18 17:45:32 +11:00
case "$distro" in
2016-06-12 17:06:31 +10:00
"NetBSD"*) memfree="$(($(awk -F ':|kB' '/MemFree:/ {printf $2}' /proc/meminfo) / 1024))" ;;
*) memfree="$(($(vmstat | awk 'END{printf $5}') / 1024))" ;;
2016-01-18 17:45:32 +11:00
esac
2016-01-18 17:17:32 +11:00
2016-10-16 09:01:16 +03:00
case "$distro" in
"NetBSD"*) memtotal="$(($(sysctl -n hw.physmem64) / 1024 / 1024))" ;;
*) memtotal="$(($(sysctl -n hw.physmem) / 1024 / 1024))" ;;
esac
2016-06-12 15:51:48 +10:00
memused="$((memtotal - memfree))"
2016-01-18 12:09:37 +11:00
;;
2016-08-02 17:52:01 +07:00
"Solaris")
memtotal="$(prtconf | grep Memory | head -1 | awk 'BEGIN {FS=" "} {print $3}')"
memfree="$(($(sar -r 1 1 | tail -1 | awk 'BEGIN {FS=" "} {print $2}') / 1024))"
memused="$((memtotal - memfree))"
;;
2016-01-03 17:54:16 +11:00
esac
2016-03-27 20:28:43 +11:00
memory="${memused}MB / ${memtotal}MB"
2016-03-03 11:00:47 +11:00
2016-03-07 23:15:54 +11:00
# Progress bars
2016-03-13 07:58:46 +11:00
case "$memory_display" in
2016-03-13 00:00:02 +11:00
"bar") memory="$(bar "${memused}" "${memtotal}")" ;;
"infobar") memory="${memory} $(bar "${memused}" "${memtotal}")" ;;
"barinfo") memory="$(bar "${memused}" "${memtotal}") ${memory}" ;;
esac
2016-01-03 17:54:16 +11:00
}
2015-12-31 15:42:58 +11:00
2016-01-26 23:06:53 +11:00
# }}}
# Song {{{
2016-08-12 20:53:04 +10:00
getsong() {
2016-03-24 19:31:10 +01:00
if mpc version >/dev/null 2>&1; then
2016-02-16 14:50:20 +11:00
song="$(mpc current 2>/dev/null)"
2016-06-12 15:51:48 +10:00
state="$(mpc | awk -F '\\[|\\]' '/\[/ {printf $2}' 2>/dev/null)"
2016-01-24 22:59:35 +11:00
2016-04-02 01:39:20 +11:00
elif [ -n "$(ps x | awk '!(/awk/) && /cmus/')" ]; then
2016-06-05 09:07:47 +10:00
IFS=$'\n'
2016-10-22 23:14:54 +11:00
song=($(cmus-remote -Q | grep "tag artist \|tag title \|status" 2>/dev/null | sort))
state="${song[0]/status }"
2016-06-12 15:51:48 +10:00
artist="${song[1]/tag artist }"
title="${song[2]/tag title }"
2016-10-22 23:14:54 +11:00
song="${artist/tag title } - ${title/tag artist }"
2016-01-24 22:59:35 +11:00
2016-02-16 00:31:28 +11:00
elif pgrep "mocp" >/dev/null 2>&1; then
2016-02-16 14:50:20 +11:00
song="$(mocp -Q "%artist - %song" 2>/dev/null)"
state="$(mocp -Q "%state" 2>/dev/null)"
2016-02-16 00:12:15 +11:00
2016-03-29 10:04:59 +11:00
elif [ -n "$(ps x | awk '!(/awk/) && /spotify/')" ]; then
2016-03-04 12:32:06 +11:00
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 18:48:41 +11:00
awk -F '"' '/artist|title/ {printf $2 " - "}'
2016-03-04 12:32:06 +11:00
)"
2016-06-12 15:51:48 +10:00
song="${song% - }"
song="${song/'('*}"
song="${song//'['*}"
2016-03-04 12:32:06 +11:00
;;
2016-03-13 09:30:53 +11:00
"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')"
;;
2016-03-04 12:32:06 +11:00
esac
2016-03-13 09:30:53 +11:00
2016-06-01 21:04:22 +10:00
elif [ -n "$(ps x | awk '!(/awk/ || /Helper/) && /Google Play Music Desktop Player/')" ] && type -p gpmdp-remote >/dev/null 2>&1; then
song="$(gpmdp-remote current)"
state="$(gpmdp-remote status)"
2016-03-25 09:54:32 +11:00
2016-10-17 16:53:30 +11:00
elif [ -n "$(ps x | awk '!(/awk/ || /Helper/ || /Cache/) && /iTunes.app/')" ]; then
2016-05-28 15:24:40 +10:00
song="$(osascript -e 'tell application "iTunes" to artist of current track as string & " - " & name of current track as string')"
2016-03-12 18:16:22 +11:00
state="$(osascript -e 'tell application "iTunes" to player state as string')"
2016-03-12 19:11:17 +11:00
2016-09-04 19:06:28 +07:00
elif [ -n "$(ps x | awk '!(/awk/) && /rhythmbox/')" ]; then
song="$(rhythmbox-client --print-playing)"
# Well, what can you expect? It's dbus after all.
state="$(dbus-send --print-reply --dest=org.mpris.MediaPlayer2.rhythmbox /org/mpris/MediaPlayer2 \
org.freedesktop.DBus.Properties.Get string:'org.mpris.MediaPlayer2.Player' string: 'PlayBackStatus' |\
awk -F 'string "' '{printf $2}')"
state="${state//\"}"
2016-09-04 19:28:08 +07:00
elif [ -n "$(ps x | awk '!(/awk/) && /banshee/')" ]; then
artist="$(banshee --query-artist | awk -F':' '{print $2}')"
title="$(banshee --query-title | awk -F':' '{print $2}')"
song="$artist - $title"
state="$(banshee --query-current-state | awk -F':' '{print $2}')"
2016-09-07 23:02:45 +07:00
elif [ -n "$(ps x | awk '!(/awk/) && /amarok/')" ]; then
artist="$(qdbus org.kde.amarok /Player GetMetadata | awk -F':' '/^artist/ {print $2}')"
title="$(qdbus org.kde.amarok /Player GetMetadata | awk -F':' '/title/ {print $2}')"
song="$artist - $title"
2016-09-11 23:37:23 +07:00
elif [ -n "$(ps x | awk '!(/awk/) && /deadbeef/')" ]; then
song="$(deadbeef --nowplaying '%a - %t')"
2016-10-22 15:11:52 +11:00
elif [ -n "$(ps x | awk '!(/awk/) && /audacious/')" ]; then
song="$(audtool current-song)"
2016-01-20 21:24:29 +11:00
else
2016-03-26 23:36:37 +11:00
song="Not Playing"
2016-01-20 21:24:04 +11:00
fi
2016-02-16 14:50:20 +11:00
case "$state" in
2016-09-04 19:06:28 +07:00
"paused" | "PAUSE" | "Paused")
2016-02-16 14:50:20 +11:00
song="Paused"
;;
2016-09-04 19:06:28 +07:00
"stopped" | "STOP" | "Stopped")
2016-02-16 14:50:20 +11:00
song="Stopped"
;;
esac
2016-02-19 11:26:24 +11:00
2016-02-21 08:38:07 +11:00
# Display Artist and Title on seperate lines.
2016-08-19 23:01:18 +10:00
if [ "$song_shorthand" == "on" ]; then
2016-02-19 11:26:24 +11:00
artist="${song/ -*}"
2016-06-12 15:51:48 +10:00
song="${song/$artist - }"
2016-02-19 11:26:24 +11:00
if [ "$song" != "$artist" ]; then
2016-04-02 11:44:08 +11:00
prin "Artist" "$artist"
prin "Song" "$song"
2016-02-19 11:26:24 +11:00
else
2016-04-02 11:44:08 +11:00
prin "$subtitle" "$song"
2016-02-19 11:26:24 +11:00
fi
unset song
fi
2016-01-03 17:54:16 +11:00
}
2016-01-26 23:06:53 +11:00
# }}}
# Resolution {{{
2016-08-12 20:53:04 +10:00
getresolution() {
2016-01-04 14:31:21 +11:00
case "$os" in
2016-08-02 17:52:01 +07:00
"Linux" | "BSD" | "Solaris")
2016-03-26 08:51:39 +11:00
if type -p xrandr >/dev/null 2>&1; then
case "$refresh_rate" in
2016-06-24 11:48:18 +10:00
"on") resolution="$(xrandr --nograb --current | awk 'match($0,/[0-9]*\.[0-9]*\*/) {printf $1 " @ " substr($0,RSTART,RLENGTH) "Hz, "}')" ;;
2016-06-24 11:44:22 +10:00
"off") resolution="$(xrandr --nograb --current | awk '/\*/ {printf $1 ", "}')" ;;
2016-03-26 12:13:31 +11:00
esac
2016-06-12 15:51:48 +10:00
resolution="${resolution//\*}"
2016-06-25 10:56:23 +10:00
resolution="${resolution//\.[0-9][0-9]}"
2016-03-26 07:59:24 +11:00
2016-03-26 11:49:43 +11:00
elif type -p xdpyinfo >/dev/null 2>&1; then
2016-06-12 15:51:48 +10:00
resolution="$(xdpyinfo 2>/dev/null | awk '/dimensions:/ {printf $2}')"
2016-03-26 07:59:24 +11:00
fi
2016-01-04 14:31:21 +11:00
;;
"Mac OS X")
2016-03-27 19:50:09 +11:00
if type -p screenresolution >/dev/null 2>&1; then
2016-06-12 15:51:48 +10:00
resolution="$(screenresolution get 2>&1 | awk '/Display/ {printf $6 "Hz, "}')"
resolution="${resolution//x??@/ @ }"
2016-03-27 19:50:09 +11:00
else
2016-06-12 15:51:48 +10:00
resolution="$(system_profiler SPDisplaysDataType |\
awk '/Resolution:/ {printf $2"x"$4" @ "$6"Hz, "}')"
2016-03-27 19:50:09 +11:00
fi
2016-03-27 20:13:32 +11:00
2016-10-16 00:39:07 +11:00
scale_factor="$(/usr/libexec/PlistBuddy -c "Print DisplayAnyUserSets:0:0:Resolution" /Library/Preferences/com.apple.windowserver.plist)"
2016-10-16 00:45:27 +11:00
[ "${scale_factor%.*}" == "2" ] && \
2016-10-16 00:39:07 +11:00
resolution="${resolution// @/@2x @}"
2016-06-16 17:09:24 +10:00
if [ "$refresh_rate" == "off" ]; then
2016-06-15 21:02:33 +10:00
resolution="${resolution// @ [0-9][0-9]Hz}"
resolution="${resolution// @ [0-9][0-9][0-9]Hz}"
2016-06-15 20:18:57 +10:00
fi
2016-06-15 21:02:33 +10:00
[[ "$resolution" =~ "0Hz" ]] && \
resolution="${resolution// @ 0Hz}"
2016-01-04 14:31:21 +11:00
;;
2016-01-18 17:24:08 +11:00
2016-02-21 21:01:46 +11:00
"Windows")
2016-06-12 15:51:48 +10:00
width="$(wmic path Win32_VideoController get CurrentHorizontalResolution /value 2>/dev/null)"
width="${width/CurrentHorizontalResolution'='/}"
2016-02-21 21:48:49 +11:00
2016-06-12 15:51:48 +10:00
height="$(wmic path Win32_VideoController get CurrentVerticalResolution /value 2>/dev/null)"
height="${height/CurrentVerticalResolution'='/}"
2016-02-21 21:48:49 +11:00
2016-06-12 16:18:49 +10:00
[ "$width" ] && \
2016-03-25 22:20:19 +11:00
resolution="${width}x${height}"
2016-02-21 21:01:46 +11:00
;;
2016-01-30 00:34:48 +11:00
esac
2016-03-18 16:28:26 +11:00
2016-06-12 15:51:48 +10:00
resolution="${resolution%,*}"
2016-01-04 14:31:21 +11:00
}
2016-01-26 23:06:53 +11:00
# }}}
2016-02-16 10:49:21 +11:00
# Theme/Icons/Font {{{
2016-01-26 23:06:53 +11:00
2016-08-12 20:53:04 +10:00
getstyle() {
2016-02-09 02:21:12 +11:00
# Fix weird output when the function
# is run multiple times.
2016-02-19 23:18:02 +11:00
unset gtk2theme gtk3theme theme path
2016-02-09 02:21:12 +11:00
2016-01-13 16:36:07 +11:00
case "$1" in
2016-01-26 12:48:40 +11:00
theme)
name="gtk-theme-name"
gsettings="gtk-theme"
2016-02-08 23:29:48 +11:00
gconf="gtk_theme"
2016-10-13 23:47:35 +11:00
xfconf="/Net/ThemeName"
2016-02-16 10:19:28 +11:00
kde="widgetStyle"
2016-01-26 12:48:40 +11:00
;;
icons)
name="gtk-icon-theme-name"
gsettings="icon-theme"
2016-02-08 23:29:48 +11:00
gconf="icon_theme"
2016-10-13 23:47:35 +11:00
xfconf="/Net/IconThemeName"
2016-02-16 10:19:28 +11:00
kde="Theme"
2016-01-26 12:48:40 +11:00
;;
font)
name="gtk-font-name"
gsettings="font-name"
2016-02-08 23:29:48 +11:00
gconf="font_theme"
2016-10-13 23:47:35 +11:00
xfconf="/Gtk/FontName"
2016-02-16 10:19:28 +11:00
kde="font"
2016-01-26 12:48:40 +11:00
;;
2016-01-13 16:36:07 +11:00
esac
2016-02-21 08:38:07 +11:00
if [ -n "$DISPLAY" ] && [ "$os" != "Mac OS X" ]; then
2016-04-02 01:59:46 +11:00
# Get DE if user has disabled the function.
[ -z "$de" ] && getde
case "$de" in
2016-02-19 23:10:09 +11:00
"KDE"*)
2016-04-01 14:50:15 +11:00
kdeconfigdir
2016-02-16 10:31:13 +11:00
2016-02-19 23:10:09 +11:00
if [ -f "${kde_config_dir}/share/config/kdeglobals" ]; then
kde_config_file="${kde_config_dir}/share/config/kdeglobals"
2016-02-16 10:31:13 +11:00
2016-06-12 15:51:48 +10:00
theme="$(grep "^[^#]*$kde" "$kde_config_file")"
theme="${theme/${kde}*=}"
2016-10-15 22:07:12 +11:00
[ "$version" -ge 4 ] && theme="${theme^}"
2016-02-16 10:49:21 +11:00
2016-02-19 23:10:09 +11:00
gtk_shorthand="on"
return
fi
;;
2016-02-16 10:19:28 +11:00
2016-03-06 09:14:44 +11:00
*"Cinnamon")
2016-02-19 23:10:09 +11:00
if type -p gsettings >/dev/null 2>&1; then
2016-06-12 15:51:48 +10:00
gtk3theme="$(gsettings get org.cinnamon.desktop.interface "$gsettings")"
gtk2theme="${gtk3theme}"
2016-02-19 23:10:09 +11:00
fi
;;
2016-01-25 17:26:15 +11:00
2016-02-19 23:10:09 +11:00
"Gnome"* | "Unity"* | "Budgie")
if type -p gsettings >/dev/null 2>&1; then
2016-06-12 15:51:48 +10:00
gtk3theme="$(gsettings get org.gnome.desktop.interface "$gsettings")"
gtk2theme="${gtk3theme}"
2016-02-19 23:10:09 +11:00
elif type -p gconftool-2 >/dev/null 2>&1; then
2016-06-12 15:51:48 +10:00
gtk2theme="$(gconftool-2 -g /desktop/gnome/interface/"$gconf")"
2016-02-19 23:10:09 +11:00
fi
;;
"Mate"*)
2016-06-12 15:51:48 +10:00
gtk3theme="$(gsettings get org.mate.interface "$gsettings")"
gtk2theme="${gtk3theme}"
2016-02-19 23:10:09 +11:00
;;
2016-01-27 11:53:12 +11:00
2016-02-19 23:10:09 +11:00
"Xfce"*)
2016-03-29 23:14:35 +11:00
type -p xfconf-query >/dev/null 2>&1 && \
2016-10-13 23:47:35 +11:00
gtk2theme="$(xfconf-query -c xsettings -p "$xfconf")"
2016-02-19 23:10:09 +11:00
;;
esac
2016-01-13 12:26:40 +11:00
2016-02-19 23:10:09 +11:00
# Check for gtk2 theme
if [ -z "$gtk2theme" ]; then
2016-03-26 15:04:59 -04:00
if [ -f "${GTK2_RC_FILES:-$HOME/.gtkrc-2.0}" ]; then
2016-06-12 15:51:48 +10:00
gtk2theme="$(grep "^[^#]*$name" "${GTK2_RC_FILES:-$HOME/.gtkrc-2.0}")"
2016-01-28 11:34:41 +11:00
2016-03-16 17:12:21 +11:00
elif [ -f "/usr/share/gtk-2.0/gtkrc" ]; then
2016-06-12 15:51:48 +10:00
gtk2theme="$(grep "^[^#]*$name" /usr/share/gtk-2.0/gtkrc)"
2016-03-16 17:27:45 +11:00
elif [ -f "/etc/gtk-2.0/gtkrc" ]; then
2016-06-12 15:51:48 +10:00
gtk2theme="$(grep "^[^#]*$name" /etc/gtk-2.0/gtkrc)"
2016-02-08 23:29:48 +11:00
fi
2016-01-25 17:26:15 +11:00
2016-06-12 15:51:48 +10:00
gtk2theme="${gtk2theme/${name}*=}"
2016-01-27 11:53:12 +11:00
fi
2016-02-19 23:10:09 +11:00
# Check for gtk3 theme
if [ -z "$gtk3theme" ]; then
2016-04-01 09:47:48 +11:00
if [ -f "$XDG_CONFIG_HOME/gtk-3.0/settings.ini" ]; then
2016-06-12 15:51:48 +10:00
gtk3theme="$(grep "^[^#]*$name" "$XDG_CONFIG_HOME/gtk-3.0/settings.ini")"
2016-01-13 12:26:40 +11:00
2016-02-19 23:10:09 +11:00
elif type -p gsettings >/dev/null 2>&1; then
gtk3theme="$(gsettings get org.gnome.desktop.interface $gsettings)"
2016-01-28 11:34:41 +11:00
2016-03-16 17:12:21 +11:00
elif [ -f "/usr/share/gtk-3.0/settings.ini" ]; then
2016-06-12 15:51:48 +10:00
gtk3theme="$(grep "^[^#]*$name" /usr/share/gtk-3.0/settings.ini)"
2016-03-16 17:27:45 +11:00
elif [ -f "/etc/gtk-3.0/settings.ini" ]; then
2016-06-12 15:51:48 +10:00
gtk3theme="$(grep "^[^#]*$name" /etc/gtk-3.0/settings.ini)"
2016-02-19 23:10:09 +11:00
fi
2016-01-25 17:26:15 +11:00
2016-06-12 15:51:48 +10:00
gtk3theme="${gtk3theme/${name}*=}"
2016-01-27 11:53:12 +11:00
fi
2016-01-24 10:38:46 +11:00
2016-06-12 11:41:25 +10:00
# Remove quotes
gtk2theme=${gtk2theme//\"}
gtk2theme=${gtk2theme//\'}
gtk3theme=${gtk3theme//\"}
gtk3theme=${gtk3theme//\'}
2016-02-21 08:44:22 +11:00
# Uppercase the first letter of each gtk theme
2016-10-15 22:07:12 +11:00
if [ "$version" -ge 4 ]; then
gtk2theme="${gtk2theme^}"
gtk3theme="${gtk3theme^}"
fi
2016-02-21 08:44:22 +11:00
2016-02-19 23:10:09 +11:00
# Toggle visibility of gtk themes.
[ "$gtk2" == "off" ] && unset gtk2theme
[ "$gtk3" == "off" ] && unset gtk3theme
2016-02-09 00:47:51 +11:00
2016-10-22 19:59:25 +11:00
# Trim whitespace
gtk2theme="$(trim "$gtk2theme")"
gtk3theme="$(trim "$gtk3theme")"
2016-02-19 23:10:09 +11:00
# Format the string based on which themes exist
if [ "$gtk2theme" ] && [ "$gtk2theme" == "$gtk3theme" ]; then
gtk3theme+=" [GTK2/3]"
unset gtk2theme
2016-01-25 17:26:15 +11:00
2016-02-19 23:10:09 +11:00
elif [ "$gtk2theme" ] && [ "$gtk3theme" ]; then
gtk2theme+=" [GTK2], "
gtk3theme+=" [GTK3] "
else
[ "$gtk2theme" ] && gtk2theme+=" [GTK2] "
[ "$gtk3theme" ] && gtk3theme+=" [GTK3] "
fi
2016-01-13 12:26:40 +11:00
2016-02-19 23:10:09 +11:00
# Final string
theme="${gtk2theme}${gtk3theme}"
2016-01-25 10:36:42 +11:00
2016-02-19 23:10:09 +11:00
# Make the output shorter by removing "[GTKX]" from the string
if [ "$gtk_shorthand" == "on" ]; then
2016-06-12 15:51:48 +10:00
theme="${theme/ '[GTK2]'}"
theme="${theme/ '[GTK3]'}"
theme="${theme/ '[GTK2/3]'}"
2016-02-19 23:10:09 +11:00
fi
2016-01-13 12:26:40 +11:00
fi
}
2016-08-12 20:53:04 +10:00
gettheme() {
2016-02-16 10:49:21 +11:00
getstyle theme
2016-01-13 16:36:07 +11:00
}
2016-01-13 12:26:40 +11:00
2016-08-12 20:53:04 +10:00
geticons() {
2016-02-16 10:49:21 +11:00
getstyle icons
icons="$theme"
2016-01-13 12:26:40 +11:00
}
2016-08-12 20:53:04 +10:00
getfont() {
2016-02-16 10:49:21 +11:00
getstyle font
font="$theme"
2016-01-26 12:48:40 +11:00
}
2016-01-26 23:06:53 +11:00
# }}}
2016-05-16 21:35:29 +10:00
# Terminal Emulator {{{
2016-08-12 20:53:04 +10:00
getterm() {
2016-05-28 10:27:58 +10:00
# Check $PPID for terminal emulator.
2016-05-28 11:38:41 +10:00
case "$os" in
"Mac OS X")
2016-10-15 23:20:25 +11:00
# Workaround for macOS systems that
2016-05-28 11:38:41 +10:00
# don't support the block below.
case "$TERM_PROGRAM" in
"iTerm.app") term="iTerm2" ;;
"Terminal.app") term="Apple Terminal" ;;
*) term="${TERM_PROGRAM/\.app}" ;;
esac
return
;;
2016-05-18 15:51:25 +10:00
2016-05-28 11:38:41 +10:00
"Windows")
parent="$(ps -p ${1:-$PPID} | awk '{printf $2}')"
2016-06-12 15:51:48 +10:00
parent="${parent/'PPID'}"
2016-05-16 22:41:40 +10:00
2016-05-28 11:38:41 +10:00
name="$(ps -p $parent | awk '{printf $8}')"
2016-06-12 15:51:48 +10:00
name="${name/'COMMAND'}"
name="${name/*\/}"
2016-05-28 11:38:41 +10:00
;;
2016-05-28 10:14:45 +10:00
2016-05-28 11:38:41 +10:00
*)
parent="$(ps -p ${1:-$PPID} -o ppid=)"
name="$(ps -p $parent -o comm=)"
;;
esac
case "${name// }" in
2016-10-03 17:20:20 +11:00
"${SHELL/*\/}" | *"sh" | "tmux"* | "screen") getterm "$parent" ;;
2016-10-21 18:37:59 +11:00
"login"* | *"Login"* | "init") term="$(tty)" ;;
2016-10-21 21:48:17 +11:00
"ruby" | "1" | "systemd" | "sshd"* | "python"* | "USER"*"PID"*) unset term ;;
2016-06-02 21:14:19 +10:00
"gnome-terminal-") term="gnome-terminal" ;;
2016-10-18 08:23:03 +11:00
*) term="${name##*/}" ;;
2016-05-28 11:38:41 +10:00
esac
2016-10-15 21:45:19 +11:00
2016-10-15 22:07:12 +11:00
[ "$version" -ge 4 ] && term="${term^}"
2016-05-16 21:35:29 +10:00
}
# }}}
# Terminal Emulator Font {{{
2016-08-12 20:53:04 +10:00
gettermfont() {
2016-05-16 21:35:29 +10:00
[ -z "$term" ] && getterm
case "$term" in
2016-05-17 06:54:57 +10:00
"urxvt" | "urxvtd" | "xterm")
2016-05-21 00:33:48 +10:00
termfont="$(grep -i "${term/d}\*font" <<< $(xrdb -query))"
2016-06-12 15:51:48 +10:00
termfont="${termfont/*font: }"
2016-05-17 00:30:11 +10:00
2016-05-17 00:38:07 +10:00
# Xresources has two different font syntax, this checks which
# one is in use and formats it accordingly.
2016-05-17 00:30:11 +10:00
case "$termfont" in
"xft:"*)
2016-06-12 15:51:48 +10:00
termfont="${termfont/xft:}"
termfont="${termfont/:*}"
2016-05-17 00:30:11 +10:00
;;
2016-05-17 00:38:07 +10:00
"-"*) termfont="$(awk -F '\\-' '{printf $3}' <<< "$termfont")" ;;
2016-05-17 00:30:11 +10:00
esac
2016-05-16 21:35:29 +10:00
;;
"xfce4-terminal")
2016-05-17 00:30:11 +10:00
termfont="$(awk -F '=' '!/^($|\/\/)/ && /FontName/ {printf $2}' "${XDG_CONFIG_HOME}/xfce4/terminal/terminalrc")"
2016-05-16 21:35:29 +10:00
;;
2016-05-16 21:52:22 +10:00
"termite")
2016-10-03 17:09:01 +11:00
termfont="$(awk -F '= ' '!/^($|#|;)/ && /font/ {printf $2; exit}' "${XDG_CONFIG_HOME}/termite/config")"
2016-05-16 21:52:22 +10:00
;;
2016-05-18 16:39:05 +10:00
"mintty")
termfont="$(awk -F '=' '!/^($|#)/ && /Font/ {printf $2; exit}' "${HOME}/.minttyrc")"
;;
2016-05-23 12:35:47 +10:00
"Apple_Terminal")
termfont="$(osascript -e 'tell application "Terminal" to font name of window frontmost')"
;;
2016-06-16 12:14:05 +02:00
"terminology")
2016-06-16 16:11:00 +02:00
termfont="$(strings ${XDG_CONFIG_HOME}/terminology/config/standard/base.cfg | awk '/^font\.name$/{print a}{a=$0}')"
2016-06-16 12:14:05 +02:00
termfont="${termfont/.pcf}"
termfont="${termfont/:*}"
;;
2016-05-16 21:35:29 +10:00
esac
2016-10-15 21:45:19 +11:00
2016-10-15 22:07:12 +11:00
[ "$version" -ge 4 ] && termfont="${termfont^}"
2016-05-16 21:35:29 +10:00
}
# }}}
2016-01-26 23:06:53 +11:00
# Disk Usage {{{
2016-08-12 20:53:04 +10:00
getdisk() {
2016-01-26 22:52:05 +11:00
# df flags
case "$os" in
2016-08-26 12:07:26 +10:00
"Linux" | "iPhone OS" | "Windows" | "Solaris")
df_flags="-h -l --total"
df_dir="total"
case "$distro" in
"OpenWRT"*) df_flags="-h"; df_dir="rootfs" ;;
esac
;;
2016-05-12 19:49:08 +10:00
"Mac OS X" | "BSD")
2016-03-26 23:36:37 +11:00
case "$distro" in
2016-10-17 08:07:04 +11:00
"FreeBSD"* | *"OS X"* | "Mac"* )
2016-08-26 13:03:22 +10:00
df_flags="-l -H /"
df_dir="/"
;;
2016-03-27 15:21:11 +11:00
*) return ;;
2016-01-26 22:52:05 +11:00
esac
;;
esac
2016-01-26 21:25:28 +11:00
2016-01-26 22:52:05 +11:00
# Get the disk info
2016-08-26 12:07:26 +10:00
disk="$(df $df_flags 2>/dev/null | awk -v dir="$df_dir" '$0 ~ dir {print $2 ":" $3 ":" $5}')"
2016-01-26 22:52:05 +11:00
# Format the output
2016-06-12 15:51:48 +10:00
disk_used="${disk#*:}"
disk_used="${disk_used%%:*}"
disk_total="${disk%%:*}"
disk_total_per="${disk#*:*:}"
2016-01-26 21:25:28 +11:00
2016-01-26 22:52:05 +11:00
# Put it all together
disk="${disk_used} / ${disk_total} (${disk_total_per})"
2016-03-03 11:52:39 +11:00
2016-03-12 23:43:16 +11:00
# Add info bar
2016-06-12 15:51:48 +10:00
disk_used="${disk_used/G}"
disk_total="${disk_total/G}"
2016-03-14 21:21:43 +11:00
2016-06-12 17:06:31 +10:00
# Convert Terabytes to Gigabytes.
if [ "$disk_display" != "off" ]; then
disk_used="${disk_used/\.}"
disk_total="${disk_total/\.}"
2016-03-14 21:21:43 +11:00
2016-06-14 17:02:14 +10:00
[ "${disk_used: -1}" == "T" ] && \
2016-06-12 17:06:31 +10:00
disk_used="$((${disk_used/T} * 100))"
2016-06-14 17:02:14 +10:00
[ "${disk_total: -1}" == "T" ] && \
2016-06-12 17:06:31 +10:00
disk_total="$((${disk_total/T} * 100))"
fi
2016-03-13 07:58:46 +11:00
case "$disk_display" in
2016-03-14 21:39:02 +11:00
"bar") disk="$(bar "${disk_used/'.'*}" "${disk_total/'.'*}")" ;;
"infobar") disk+=" $(bar "${disk_used/'.'*}" "${disk_total/'.'*}")" ;;
"barinfo") disk="$(bar "${disk_used/'.'*}" "${disk_total/'.'*}") $disk" ;;
2016-03-26 01:02:01 +11:00
"perc") disk="$disk_total_per $(bar "${disk_used/'.'*}" "${disk_total/'.'*}")" ;;
2016-03-12 23:43:16 +11:00
esac
2016-01-26 21:25:28 +11:00
}
2016-01-26 23:06:53 +11:00
# }}}
2016-02-02 01:56:33 +11:00
# Battery Usage {{{
2016-08-12 20:53:04 +10:00
getbattery() {
2016-02-02 01:56:33 +11:00
case "$os" in
"Linux")
2016-02-26 19:09:22 +11:00
if [ "$(ls /sys/class/power_supply/)" ]; then
2016-02-02 09:09:31 +11:00
# Set the index to the battery number.
case "$battery_num" in
"all") battery_num="*" index=0 ;;
*) index="$battery_num" ;;
esac
2016-10-02 20:45:56 +11:00
batteries=("$(cat /sys/class/power_supply/BAT$battery_num/capacity)")
battery_state=("$(cat /sys/class/power_supply/BAT${battery_num}/status)")
2016-03-26 00:18:16 +11:00
2016-02-02 01:56:33 +11:00
# Get the subtitle and reassign it so it doesn't change.
title="$subtitle"
2016-02-02 12:01:50 +11:00
# If shorthand is on, print each value on the same line
2016-08-19 23:01:18 +10:00
if [ "$battery_shorthand" == "on" ]; then
2016-06-12 15:51:48 +10:00
battery="${batteries[*]}"
battery="${battery// /%, }"
2016-02-02 12:01:50 +11:00
battery="${battery}%"
else
2016-03-03 11:18:28 +11:00
if [ "${#batteries[@]}" -gt 1 ]; then
2016-03-13 08:37:33 +11:00
unset battery
2016-03-03 11:18:28 +11:00
# Print each battery on a separate line.
for bat in "${batteries[@]}"; do
2016-03-13 08:48:50 +11:00
case "$battery_display" in
2016-06-12 14:35:29 +10:00
"bar") prin "${title}${index:-0}" "$(bar "${bat/'%'}" 100)" ;;
2016-05-15 09:03:58 +10:00
"infobar") prin "${title}${index:-0}" "${bat}% $(bar "${bat/'%'}" 100)" ;;
"barinfo") prin "${title}${index:-0}" "$(bar "${bat/'%'}" 100) ${bat}%" ;;
*) prin "${title}${index:-0}" "${bat}%" ;;
2016-03-13 08:48:50 +11:00
esac
2016-06-12 15:51:48 +10:00
index="$((index+=1))"
2016-03-03 11:18:28 +11:00
done
2016-02-02 12:01:50 +11:00
return
fi
2016-03-26 00:18:16 +11:00
battery="${batteries[0]}%"
2016-02-02 01:56:33 +11:00
fi
fi
;;
2016-02-23 19:21:30 +11:00
2016-02-23 11:24:38 +02:00
"BSD")
2016-02-23 19:21:30 +11:00
case "$distro" in
2016-05-12 19:49:08 +10:00
"FreeBSD"* | "DragonFly"*)
2016-06-12 15:51:48 +10:00
battery="$(acpiconf -i 0 | awk -F ':\t' '/Remaining capacity/ {print $2}')"
battery_state="$(acpiconf -i 0 | awk -F ':\t\t\t' '/State/ {print $2}')"
2016-02-23 19:21:30 +11:00
;;
2016-02-27 20:25:39 +11:00
"NetBSD"*)
2016-06-12 15:51:48 +10:00
battery="$(envstat | awk '\\(|\\)' '/charge:/ {print $2}')"
2016-05-13 09:14:02 +10:00
battery="${battery/\.*/%}"
2016-02-27 20:25:39 +11:00
;;
2016-02-23 11:21:16 +02:00
2016-10-16 09:48:25 +07:00
"OpenBSD"* | "Bitrig"*)
2016-09-02 21:06:03 +07:00
battery0full="$(sysctl -n hw.sensors.acpibat0.watthour0)"
battery0full="${battery0full/ Wh*}"
2016-02-23 11:21:16 +02:00
2016-09-02 21:06:03 +07:00
battery0now="$(sysctl -n hw.sensors.acpibat0.watthour3)"
battery0now="${battery0now/ Wh*}"
2016-02-23 11:24:38 +02:00
2016-09-02 21:06:03 +07:00
[ "$battery0full" ] && \
battery="$((100 * ${battery0now/\.} / ${battery0full/\.}))%"
2016-10-02 09:12:48 +07:00
;;
2016-09-02 21:06:03 +07:00
esac
2016-10-02 09:12:48 +07:00
;;
2016-02-03 09:26:47 +11:00
"Mac OS X")
battery="$(pmset -g batt | grep -o '[0-9]*%')"
2016-03-26 00:24:18 +11:00
battery_state="$(pmset -g batt | awk 'NR==2 {print $3}')"
2016-02-03 09:26:47 +11:00
;;
"Windows")
2016-02-04 13:41:16 +11:00
battery="$(wmic Path Win32_Battery get EstimatedChargeRemaining /value)"
2016-06-12 15:51:48 +10:00
battery="${battery/EstimatedChargeRemaining'='}"
2016-06-12 16:18:49 +10:00
[ "$battery" ] && \
2016-03-27 15:05:43 +11:00
battery+="%"
2016-02-03 09:26:47 +11:00
;;
2016-02-02 01:56:33 +11:00
esac
2016-03-03 11:09:40 +11:00
2016-03-26 00:24:18 +11:00
case "$battery_state" in
2016-03-26 01:24:08 +11:00
"charging"*) battery+=" Charging" ;;
2016-03-26 00:18:16 +11:00
esac
2016-03-13 07:58:46 +11:00
case "$battery_display" in
2016-06-12 14:35:29 +10:00
"bar") battery="$(bar "${battery/'%'*}" 100)" ;;
2016-03-26 01:26:42 +11:00
"infobar") battery="${battery} $(bar "${battery/'%'*}" 100)" ;;
"barinfo") battery="$(bar "${battery/'%'*}" 100) ${battery}" ;;
2016-03-13 00:05:48 +11:00
esac
2016-02-02 01:56:33 +11:00
}
# }}}
2016-02-09 09:36:43 +11:00
# IP Address {{{
2016-08-12 20:53:04 +10:00
getlocalip() {
2016-02-09 09:36:43 +11:00
case "$os" in
"Linux")
localip="$(ip route get 1 | awk '{print $NF;exit}')"
;;
2016-05-07 21:20:03 +10:00
"Mac OS X" | "iPhone OS")
2016-02-09 10:48:37 +11:00
localip="$(ipconfig getifaddr en0)"
[ -z "$localip" ] && localip="$(ipconfig getifaddr en1)"
;;
2016-08-02 17:52:01 +07:00
"BSD" | "Solaris")
2016-02-09 18:32:01 +11:00
localip="$(ifconfig | awk '/broadcast/ {print $2}')"
2016-02-09 17:53:52 +11:00
;;
2016-02-09 09:36:43 +11:00
"Windows")
localip="$(ipconfig | awk -F ': ' '/IPv4 Address/ {printf $2}')"
;;
esac
}
2016-08-12 20:53:04 +10:00
getpublicip() {
2016-03-19 13:38:48 +11:00
if type -p dig >/dev/null 2>&1; then
2016-03-31 19:37:18 +11:00
publicip="$(dig +time=1 +tries=1 +short myip.opendns.com @resolver1.opendns.com 2>/dev/null)"
fi
2016-03-19 13:38:48 +11:00
2016-03-31 19:37:18 +11:00
if [ -z "$publicip" ] && type -p curl >/dev/null 2>&1; then
2016-03-31 19:43:11 +11:00
publicip="$(curl --max-time 10 -w '\n' "$public_ip_host" 2>/dev/null)"
2016-03-31 19:37:18 +11:00
fi
2016-02-09 17:20:19 +11:00
2016-03-31 19:37:18 +11:00
if [ -z "$publicip" ] && type -p wget >/dev/null 2>&1; then
2016-03-31 19:43:11 +11:00
publicip="$(wget -T 10 -qO- "$public_ip_host" 2>/dev/null; printf "%s")"
2016-02-09 17:20:19 +11:00
fi
}
2016-02-09 09:36:43 +11:00
# }}}
2016-02-25 16:11:53 +11:00
# Logged In Users {{{
2016-08-12 20:53:04 +10:00
getusers() {
2016-02-25 16:11:53 +11:00
users="$(who | awk '!seen[$1]++ {printf $1 ", "}')"
2016-06-12 15:51:48 +10:00
users="${users%\,*}"
2016-02-25 16:11:53 +11:00
}
# }}}
2016-01-30 22:10:28 +11:00
# Birthday {{{
2016-08-12 20:53:04 +10:00
getbirthday() {
2016-01-30 22:10:28 +11:00
case "$os" in
2016-05-07 11:29:55 +10:00
"linux" | "iPhone OS")
birthday="$(ls -alct --full-time / | awk '/lost\+found|private/ {printf $6 " " $7}')"
2016-03-26 14:22:10 +11:00
date_cmd="$(date -d"$birthday" "$birthday_format")"
2016-01-30 22:10:28 +11:00
;;
2016-01-30 23:51:12 +11:00
"Mac OS X")
2016-03-12 10:17:26 +11:00
birthday="$(ls -lUT /var/log/install.log | awk '{printf $6 " " $7 " " $9 " " $8}')"
# Split the string into Date + time
2016-06-12 15:51:48 +10:00
time="${birthday/*???? }"
birthday="${birthday/$time}"
2016-03-12 10:17:26 +11:00
case "${time/:*}" in
2016-04-03 12:01:25 +10:00
0? | 10 | 11) time+=" AM" ;;
*) time+=" PM" ;;
2016-03-12 10:17:26 +11:00
esac
birthday+="$time"
birthday_shorthand="on"
2016-01-31 10:31:29 +11:00
;;
2016-05-12 19:49:08 +10:00
"BSD")
2016-01-31 10:38:20 +11:00
case "$distro" in
2016-10-16 09:48:25 +07:00
"OpenBSD"* | "Bitrig"*)
2016-01-31 10:38:20 +11:00
birthday="$(ls -alctT / | awk '/lost\+found/ {printf $6 " " $7 " " $9 " " $8}')"
2016-01-31 10:45:56 +11:00
birthday_shorthand="on"
2016-01-31 10:38:20 +11:00
;;
2016-02-01 14:56:53 +11:00
"FreeBSD"*)
2016-01-31 10:38:20 +11:00
birthday="$(ls -alctT /etc/hostid | awk '{printf $6 " " $7 " " $9 " " $8}')"
2016-03-27 15:04:44 +11:00
date_cmd="$(date -j -f "%b %d %Y" "$birthday" "$birthday_format")"
2016-01-31 10:38:20 +11:00
;;
2016-05-12 19:49:08 +10:00
"NetBSD"* | "DragonFly"*)
2016-01-31 11:02:32 +11:00
birthday="$(ls -alctT /etc/defaults/rc.conf | awk '{printf $6 " " $7 " " $9 " " $8}')"
birthday_shorthand="on"
;;
2016-01-31 10:38:20 +11:00
esac
2016-01-30 22:10:28 +11:00
;;
2016-01-31 11:10:13 +11:00
"Windows")
birthday="$(ls -alct --full-time /cygdrive/c/Windows/explorer.exe | awk '{printf $8 " " $9}')"
2016-03-27 15:04:44 +11:00
date_cmd="$(date -d"$birthday" "$birthday_format")"
2016-01-31 11:10:13 +11:00
;;
2016-08-02 17:52:01 +07:00
"Solaris")
birthday="$(ls -alct --full-time /var/sadm/system/logs/install_log | awk '{printf $6 " " $7}')"
date_cmd="$(date -d"$birthday" "$birthday_format")"
;;
2016-01-30 22:10:28 +11:00
esac
2016-01-30 22:41:58 +11:00
# Strip seconds from time output
2016-06-12 15:51:48 +10:00
birthday="${birthday/:?? / }"
2016-01-30 22:41:58 +11:00
# Pretty output
2016-03-06 10:01:57 +11:00
[ "$birthday_shorthand" == "off" ] && \
2016-06-12 15:51:48 +10:00
birthday="${date_cmd//+( )/ }"
2016-01-30 22:41:58 +11:00
# Toggle showing the time
2016-02-01 11:44:03 +11:00
[ "$birthday_time" == "off" ] && \
2016-06-12 15:51:48 +10:00
birthday="${birthday/??:??*}"
2016-01-30 22:10:28 +11:00
}
# }}}
2016-01-26 23:06:53 +11:00
# Terminal colors {{{
2016-08-12 20:53:04 +10:00
getcols() {
2016-01-03 17:54:16 +11:00
if [ "$color_blocks" == "on" ]; then
2016-05-28 09:53:35 +10:00
# Convert the width to space chars.
2016-10-16 10:44:05 +11:00
block_width="$(printf "%${block_width}s")"
block_width="${block_width// /█}"
2016-05-28 09:53:35 +10:00
# Generate the string.
2016-01-03 17:54:16 +11:00
while [ $start -le $end ]; do
2016-03-31 19:57:57 +11:00
case "$start" in
2016-10-16 10:44:05 +11:00
[0-6]) blocks+="${reset}\033[3${start}m\033[4${start}m${block_width}" ;;
7) blocks+="${reset}\033[3${start}m\033[4${start}m${block_width}" ;;
*) blocks2+="\033[38;5;${start}m\033[48;5;${start}m${block_width}" ;;
2016-03-31 19:57:57 +11:00
esac
2016-06-12 15:51:48 +10:00
start="$((start+=1))"
2016-01-03 17:54:16 +11:00
done
2016-05-28 09:53:35 +10:00
# Convert height into spaces.
2016-05-29 10:03:18 +10:00
spaces="$(printf "%${block_height}s")"
# Convert the spaces into rows of blocks.
2016-08-14 11:04:25 +10:00
[ "$blocks" ] && cols+="${spaces// /${blocks}${reset}nl}"
[ "$blocks2" ] && cols+="${spaces// /${blocks2}${reset}nl}"
2016-05-28 09:53:35 +10:00
2016-05-29 10:03:18 +10:00
# Add newlines to the string.
2016-06-12 15:51:48 +10:00
cols="${cols%%'nl'}"
2016-10-21 18:35:17 +11:00
cols="${cols//nl/\\n${padding}${zws}}"
2015-12-31 15:42:58 +11:00
fi
}
2015-12-30 21:18:17 +11:00
2016-03-03 10:37:18 +11:00
# }}}
2016-01-07 14:37:24 +11:00
2016-01-03 17:54:16 +11:00
# }}}
2015-12-30 21:18:17 +11:00
2016-01-03 17:54:16 +11:00
# Images {{{
2015-12-30 21:18:17 +11:00
2016-01-26 23:06:53 +11:00
# Wallpaper {{{
2016-08-12 20:53:04 +10:00
getwallpaper() {
2016-01-05 18:19:38 +11:00
case "$os" in
2016-05-12 19:49:08 +10:00
"Linux" | "BSD")
2016-01-24 11:05:08 +11:00
if type -p feh >/dev/null 2>&1 && [ -f "$HOME/.fehbg" ]; then
2016-01-20 21:35:32 +11:00
img="$(awk -F\' '/feh/ {printf $2}' "$HOME/.fehbg")"
2016-01-24 22:59:35 +11:00
2016-01-20 21:35:32 +11:00
elif type -p nitrogen >/dev/null 2>&1; then
2016-04-01 09:47:48 +11:00
img="$(awk -F'=' '/file/ {printf $2;exit;}' "$XDG_CONFIG_HOME/nitrogen/bg-saved.cfg")"
2016-01-24 22:59:35 +11:00
2016-01-24 11:03:29 +11:00
elif type -p gsettings >/dev/null 2>&1; then
2016-04-02 01:59:46 +11:00
# Get DE if user has disabled the function.
[ -z "$de" ] && getde
case "$de" in
2016-02-09 21:12:09 +11:00
"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-06-12 15:51:48 +10:00
img="${img/'file://'}"
img="${img//\'}"
2016-10-03 10:03:41 +11:00
img="${img//\%20/ }"
2016-01-20 21:35:32 +11:00
fi
2016-01-05 18:19:38 +11:00
;;
2016-01-18 08:37:37 +11:00
"Mac OS X")
2016-03-29 11:40:30 +11:00
img="$(osascript -e 'tell application "System Events" to picture of current desktop')"
2016-01-18 08:37:37 +11:00
;;
2016-01-05 18:50:06 +11:00
"Windows")
case "$distro" in
"Windows XP")
2016-01-06 12:03:29 +11:00
img="/cygdrive/c/Documents and Settings/${USER}"
img+="/Local Settings/Application Data/Microsoft"
img+="/Wallpaper1.bmp"
2016-01-05 18:50:06 +11:00
;;
2016-01-05 18:19:38 +11:00
2016-01-05 18:50:06 +11:00
"Windows"*)
2016-01-06 12:03:29 +11:00
img="$APPDATA/Microsoft/Windows/Themes"
img+="/TranscodedWallpaper.jpg"
2016-01-05 18:50:06 +11:00
;;
esac
2016-01-05 18:19:38 +11:00
;;
esac
2016-02-09 21:30:41 +11:00
# If img is an xml file don't use it.
[ "${img/*\./}" == "xml" ] && img=""
2016-04-24 14:14:35 +10:00
2016-04-24 14:16:38 +10:00
# Error msg
2016-10-22 01:27:39 +11:00
[ -z "$img" ] && err "Image: Wallpaper detection failed, falling back to ascii mode."
2016-01-05 18:19:38 +11:00
}
2016-01-26 23:06:53 +11:00
# }}}
2016-01-27 22:33:22 +11:00
# Ascii {{{
2016-08-12 20:53:04 +10:00
getascii() {
2016-02-28 17:02:05 +11:00
if [ ! -f "$ascii" ] || [ "$ascii" == "distro" ]; then
2016-04-24 14:14:35 +10:00
# Error message
2016-04-24 14:22:26 +10:00
[ "$ascii" != "distro" ] && \
2016-10-22 01:27:39 +11:00
[ ! -f "$ascii" ] && err "Ascii: Ascii file not found, using distro ascii"
2016-04-24 14:14:35 +10:00
2016-01-29 09:45:35 +11:00
# Lowercase the distro name
2016-02-24 09:30:11 +11:00
if [ "$version" -le 3 ]; then
2016-06-12 15:51:48 +10:00
ascii="$(tr '[:upper:]' '[:lower:]' <<< "$ascii_distro")"
2016-02-24 09:30:11 +11:00
else
2016-06-12 15:51:48 +10:00
ascii="${ascii_distro,,}"
2016-02-24 09:30:11 +11:00
fi
2016-01-29 02:03:15 +11:00
2016-10-05 08:15:20 +11:00
if [ "$ascii_logo_size" == "small" ]; then
2016-02-28 13:07:10 +11:00
ascii="${ascii/ *}_small"
2016-10-05 08:15:20 +11:00
prompt_loc="3"
fi
2016-02-28 13:07:10 +11:00
2016-02-28 11:44:45 +11:00
if [ -f "/usr/share/neofetch/ascii/distro/${ascii/ *}" ]; then
ascii="/usr/share/neofetch/ascii/distro/${ascii/ *}"
2016-02-17 10:23:52 +11:00
2016-02-28 11:44:45 +11:00
elif [ -f "/usr/local/share/neofetch/ascii/distro/${ascii/ *}" ]; then
ascii="/usr/local/share/neofetch/ascii/distro/${ascii/ *}"
2016-02-17 10:23:52 +11:00
2016-01-29 09:45:35 +11:00
else
2016-05-15 09:10:37 +10:00
getscriptdir 2>/dev/null
2016-01-29 09:45:35 +11:00
2016-02-24 21:15:30 +11:00
# If the ascii file doesn't exist fallback to text mode.
2016-01-30 02:14:29 +11:00
if [ ! -f "$script_dir/ascii/distro/${ascii/ *}" ]; then
2016-01-29 09:45:35 +11:00
padding="\033[0C"
2016-01-29 11:06:26 +11:00
image="off"
2016-10-22 01:27:39 +11:00
err "Ascii: Ascii file not found, falling back to text mode."
2016-01-29 09:45:35 +11:00
return
fi
2016-01-29 17:56:39 +11:00
2016-01-30 02:14:29 +11:00
ascii="$script_dir/ascii/distro/${ascii/ *}"
2016-01-29 09:45:35 +11:00
fi
2016-01-28 20:04:47 +11:00
fi
2016-08-04 08:34:52 +10:00
# Eval colors
print="$(eval printf "$(<"$ascii")")"
2016-02-10 10:20:51 +11:00
# Set locale to get correct padding
2016-02-10 22:54:07 +11:00
export LC_ALL="$SYS_LOCALE"
2016-02-10 10:20:51 +11:00
2016-02-24 21:15:30 +11:00
# Turn the file into a variable and strip escape codes.
2016-06-12 15:51:48 +10:00
ascii_strip="$(<"$ascii")"
ascii_strip="${ascii_strip//\$\{??\}}"
ascii_strip="${ascii_strip//'\\'/ }"
ascii_strip="${ascii_strip//'\'}"
2016-05-18 17:07:55 +10:00
2016-08-26 11:10:55 +10:00
# Get lines/columns of the ascii file in pure bash.
ascii_length=0
lines=1
while IFS='\n' read -r line 2>/dev/null; do
[ ${#line} -gt "$ascii_length" ] && ascii_length=${#line}
lines=$((lines+=1))
done <<< "$ascii_strip"
2016-01-28 00:26:35 +11:00
2016-03-29 18:04:36 +11:00
padding="\033[$((ascii_length + gap))C"
2016-01-28 20:04:47 +11:00
printf "%b%s" "$print"
2016-02-10 10:20:51 +11:00
export LC_ALL=C
2016-01-27 22:33:22 +11:00
}
2016-01-26 23:06:53 +11:00
# }}}
# Image {{{
2016-08-12 20:53:04 +10:00
getimage() {
2016-01-29 00:00:08 +11:00
# Fallback to ascii mode if imagemagick isn't installed.
2016-02-20 10:39:33 +11:00
type -p convert >/dev/null 2>&1 || image="ascii"
2016-01-29 00:00:08 +11:00
2016-01-08 13:29:24 +11:00
case "$image" in
2016-02-20 10:39:33 +11:00
"wall") getwallpaper ;;
"ascii") getascii; return ;;
2016-03-25 21:22:58 +11:00
*)
2016-06-10 19:46:00 +10:00
if [ -d "$image" ]; then
2016-06-10 23:10:54 +10:00
files=("${image%/}"/*.{png,jpg,jpeg})
2016-05-17 00:06:59 -05:00
img="$(printf "%s" "${files[RANDOM % (${#files[@]} - 1)]}")"
2016-03-25 21:22:58 +11:00
else
img="$image"
fi
;;
2016-01-08 13:29:24 +11:00
esac
2016-01-03 17:54:16 +11:00
2016-02-18 14:19:41 +11:00
# Get terminal width and height
2016-10-21 21:25:43 +11:00
if type -p xdotool >/dev/null 2>&1 && \
[ "$image_backend" != "iterm2" ]; then
current_window="$(xdotool getactivewindow)"
eval "$(xdotool getwindowgeometry --shell "$current_window")"
term_height="$HEIGHT"
term_width="$WIDTH"
elif type -p xwininfo >/dev/null 2>&1 && \
type -p xdpyinfo >/dev/null 2>&1 || \
type -p xprop >/dev/null 2>&1 && \
[ "$image_backend" != "iterm2" ]; then
if type -p xdpyinfo >/dev/null 2>&1; then
current_window="$(xdpyinfo | grep focus | grep -E -o 0x[0-9a-f]+)"
elif type -p xprop >/dev/null 2>&1; then
current_window="$(xprop -root | awk '/_NET_ACTIVE_WINDOW\(WINDOW\)/{print $NF}')"
fi
2016-06-10 17:58:24 +10:00
2016-10-21 21:25:43 +11:00
term_size="$(xwininfo -id "$current_window" | awk -F ': ' '/Width|Height/ {printf $2 " "}')"
term_width="${term_size/ *}"
term_height="${term_size/${term_width}}"
2016-06-10 17:58:24 +10:00
2016-02-21 11:32:02 +11:00
else
2016-10-21 21:25:43 +11:00
if [ -n "$TMUX" ]; then
printf "%b%s" "\033Ptmux;\033\033[14t\033\033[c\033\\"
read_flags="-d c"
2016-02-18 14:19:41 +11:00
2016-10-21 21:25:43 +11:00
elif [ "$image_backend" == "tycat" ]; then
printf "%b%s" "\033}qs\000"
2016-01-20 21:46:20 +11:00
2016-10-21 21:25:43 +11:00
else
printf "%b%s" "\033[14t\033[c"
read_flags="-d c"
fi
2016-02-21 14:37:17 +11:00
2016-10-21 21:25:43 +11:00
# The escape code above prints the output AFTER the prompt so this
builtin read -s -t 1 ${read_flags} -r term_size
# Split the string
if [ "$image_backend" == "tycat" ]; then
term_size=(${term_size//;/ })
term_width="$((term_size[2] * term_size[0]))"
term_height="$((term_size[3] * term_size[1]))"
else
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/*';'}"
fi
[ "${#term_size}" -le 5 ] && no_esc="1"
2016-06-10 17:58:24 +10:00
fi
2016-02-21 15:35:13 +11:00
# If $img isn't a file or the terminal doesn't support xterm escape sequences,
# fallback to ascii mode.
2016-10-21 21:25:43 +11:00
if [ ! -f "$img" ] || ([ "$no_esc" == 1 ] && [ "$image_backend" != "tycat" ]); then
2016-02-21 15:35:13 +11:00
image="ascii"
getascii
2016-04-24 14:14:35 +10:00
# Error messages
2016-10-22 01:27:39 +11:00
[ ! -f "$img" ] && err "Image: \$img, isn't a file, falling back to ascii mode."
[ "${#term_size}" -le 5 ] && err "Image: Your terminal doesn't support \\\033[14t, falling back to ascii mode."
2016-04-24 14:14:35 +10:00
2016-02-21 15:35:13 +11:00
return
2016-10-01 12:57:54 +10:00
else
clear
2016-10-21 18:35:17 +11:00
zws=" "
2016-02-21 15:35:13 +11:00
fi
2016-05-27 14:56:09 +10:00
# Get terminal lines and columns
2016-08-19 10:29:27 +10:00
term_blocks="$(stty size)"
columns="${term_blocks/* }"
lines="${term_blocks/ *}"
2016-02-01 11:05:46 +11:00
2016-02-18 14:19:41 +11:00
# Calculate font size
2016-06-12 15:51:48 +10:00
font_width="$((term_width / columns))"
2016-08-04 09:20:42 +10:00
font_height="$((term_height / lines))"
2016-02-18 14:19:41 +11:00
2016-02-01 08:53:00 +11:00
# Image size is half of the terminal
2016-02-20 13:35:07 +11:00
case "$image_size" in
"auto")
2016-06-12 15:51:48 +10:00
image_size="$((columns * font_width / 2))"
term_height="$((term_height - term_height / 4))"
2016-02-01 08:53:00 +11:00
2016-02-21 08:53:30 +11:00
[ "$term_height" -lt "$image_size" ] && \
image_size="$term_height"
2016-02-20 13:35:07 +11:00
;;
*"%")
2016-06-12 15:51:48 +10:00
percent="${image_size/\%}"
image_size="$((percent * term_width / 100))"
2016-02-20 13:35:07 +11:00
[ "$((percent * term_height / 50))" -lt "$image_size" ] && \
2016-06-12 15:51:48 +10:00
image_size="$((percent * term_height / 100))"
2016-02-20 13:35:07 +11:00
;;
2016-04-12 15:50:19 +10:00
2016-05-27 14:56:09 +10:00
"none")
# Get image size so that we can do a better crop
2016-06-12 15:51:48 +10:00
size="$(identify -format "%w %h" "$img")"
width="${size%% *}"
height="${size##* }"
2016-05-27 14:56:09 +10:00
crop_mode="none"
;;
2016-06-12 15:51:48 +10:00
*) image_size="${image_size/px}" ;;
2016-02-20 13:35:07 +11:00
esac
2016-02-18 14:19:41 +11:00
2016-05-27 14:56:09 +10:00
# Fallback if width / height are empty.
2016-06-12 15:51:48 +10:00
width="${width:-$image_size}"
height="${height:-$image_size}"
2016-05-27 14:56:09 +10:00
2016-06-13 19:08:03 +10:00
# Padding is half the terminal width + gap
padding="\033[$((width / font_width + gap + xoffset/font_width))C"
2016-02-01 08:53:00 +11:00
2016-01-31 16:25:11 +11:00
# Make the directory if it doesn't exist
2016-01-31 21:33:02 +11:00
mkdir -p "$thumbnail_dir"
2016-01-31 16:25:11 +11:00
2016-02-20 10:39:33 +11:00
# Check to see if the image has a file extension, if it doesn't
# then add one.
2016-01-24 11:17:48 +11:00
case "${img##*/}" in
2016-05-27 15:13:37 +10:00
*"."*) imgname="$crop_mode-$crop_offset-$width-$height-${img##*/}" ;;
*) imgname="$crop_mode-$crop_offset-$width-$height-${img##*/}.jpg" ;;
2016-01-24 11:17:48 +11:00
esac
2016-01-03 17:54:16 +11:00
# Check to see if the thumbnail exists before we do any cropping.
2016-01-31 21:33:02 +11:00
if [ ! -f "$thumbnail_dir/$imgname" ]; then
2016-01-03 17:54:16 +11:00
# Get image size so that we can do a better crop
2016-05-27 15:13:37 +10:00
if [ -z "$size" ]; then
2016-06-12 15:51:48 +10:00
size="$(identify -format "%w %h" "$img")"
og_width="${size%% *}"
og_height="${size##* }"
2016-01-03 17:54:16 +11:00
2016-05-28 14:07:19 +10:00
# This checks to see if height is geater than width
# so we can do a better crop of portrait images.
2016-06-12 15:51:48 +10:00
size="$og_height"
[ "$og_height" -gt "$og_width" ] && size="$og_width"
2016-05-28 14:07:19 +10:00
fi
2016-01-03 17:54:16 +11:00
case "$crop_mode" in
fit)
2016-06-12 15:51:48 +10:00
c="$(convert "$img" \
2016-01-06 12:03:29 +11:00
-colorspace srgb \
2016-06-12 15:51:48 +10:00
-format "%[pixel:p{0,0}]" info:)"
2016-01-06 12:03:29 +11:00
2016-01-03 17:54:16 +11:00
convert \
"$img" \
-trim +repage \
-gravity south \
-background "$c" \
-extent "$size"x"$size" \
2016-05-27 14:56:09 +10:00
-scale "$width"x"$height" \
2016-01-31 21:33:02 +11:00
"$thumbnail_dir/$imgname"
2016-01-03 17:54:16 +11:00
;;
fill)
convert \
"$img" \
-trim +repage \
2016-05-27 14:56:09 +10:00
-scale "$width"x"$height"^ \
-extent "$width"x"$height" \
2016-01-31 21:33:02 +11:00
"$thumbnail_dir/$imgname"
2016-01-03 17:54:16 +11:00
;;
2016-05-27 14:56:09 +10:00
none) cp "$img" "$thumbnail_dir/$imgname" ;;
2016-01-03 17:54:16 +11:00
*)
convert \
"$img" \
-gravity $crop_offset \
-crop "$size"x"$size"+0+0 \
2016-01-06 12:49:21 +11:00
-quality 95 \
2016-05-27 14:56:09 +10:00
-scale "$width"x"$height" \
2016-01-31 21:33:02 +11:00
"$thumbnail_dir/$imgname"
2016-01-03 17:54:16 +11:00
;;
esac
fi
# The final image
2016-01-31 21:33:02 +11:00
img="$thumbnail_dir/$imgname"
2015-12-30 21:18:17 +11:00
}
# }}}
2016-01-30 17:44:52 +11:00
# Find w3m-img {{{
# Find w3mimgdisplay automatically
2016-08-12 20:53:04 +10:00
getw3m_img_path() {
2016-01-30 17:44:52 +11:00
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"
2016-10-22 01:27:39 +11:00
err "Image: w3m-img wasn't found on your system, falling back to ascii mode."
2016-01-30 17:44:52 +11:00
fi
}
# }}}
2016-08-13 19:42:31 +10:00
# Display image {{{
displayimage() {
if [ "$image" != "ascii" ]; then
case "$image_backend" in
"w3m")
2016-10-03 18:08:47 +11:00
# Add a tiny delay to fix issues with images not
# appearing in specific terminal emulators.
2016-10-03 17:59:56 +11:00
sleep 0.05
2016-08-13 19:42:31 +10:00
printf "%b%s\n" "0;1;$xoffset;$yoffset;$width;$height;;;;;$img\n4;\n3;" |\
2016-10-22 01:14:02 +11:00
$w3m_img_path -bg "$background_color" 2>/dev/null || padding="\033[0C"
2016-08-13 19:42:31 +10:00
;;
"iterm2")
printf "%b%s\a\n" "\033]1337;File=width=${width}px;height=${height}px;inline=1:$(base64 < "$img")"
;;
"tycat")
tycat "$img"
;;
esac
fi
}
# }}}
# Get image backend {{{
getimagebackend() {
if [ -n "$ITERM_PROFILE" ]; then
image_backend="iterm2"
elif [ "$(tycat 2>/dev/null)" ]; then
image_backend="tycat"
else
image_backend="w3m"
fi
}
# }}}
2016-10-02 19:29:13 +11:00
# Screenshot {{{
takescrot() {
$scrot_cmd "${scrot_dir}${scrot_name}"
2016-10-02 20:23:02 +11:00
[ "$scrot_upload" == "on" ] && scrot_upload
2016-10-02 19:29:13 +11:00
}
# }}}
# Screenshot Upload {{{
scrot_upload() {
2016-10-02 22:03:17 +11:00
if ! type -p curl >/dev/null 2>&1; then
printf "%s\n" "[!] Install curl to upload images"
return
fi
2016-10-02 19:29:13 +11:00
image_file="${scrot_dir}${scrot_name}"
2016-10-02 20:23:02 +11:00
printf "%s\n" "Uploading image..."
2016-10-02 19:29:13 +11:00
case "$image_host" in
"teknik")
2016-10-02 21:57:52 +11:00
image_url="$(curl -sf -F file="@${image_file}" "https://api.teknik.io/v1/Upload")"
2016-10-02 20:23:02 +11:00
image_url="$(awk -F 'url:|,' '{printf $2}' <<< "${image_url//\"}")"
2016-10-02 19:29:13 +11:00
;;
2016-10-02 21:57:52 +11:00
"imgur")
2016-10-02 23:46:22 +11:00
image_url="$(curl -sH "Authorization: Client-ID $imgur_client_id" -F image="@${image_file}" "https://api.imgur.com/3/upload")"
2016-10-02 21:57:52 +11:00
image_url="$(awk -F 'id:|,' '{printf $2}' <<< "${image_url//\"}")"
2016-10-02 22:46:51 +11:00
[ "$image_url" ] && image_url="https://i.imgur.com/${image_url}.png"
2016-10-02 21:57:52 +11:00
;;
2016-10-02 19:29:13 +11:00
esac
2016-10-02 22:46:51 +11:00
if [ "$image_url" ]; then
printf "%s\n" "$image_url"
else
printf "%s\n" "[!] Image failed to upload"
fi
2016-10-02 19:29:13 +11:00
}
# }}}
2016-01-26 23:06:53 +11:00
# }}}
2016-01-03 17:54:16 +11:00
# Text Formatting {{{
2015-12-30 21:18:17 +11:00
2016-01-26 23:06:53 +11:00
# Info {{{
2016-08-12 20:53:04 +10:00
info() {
2016-02-02 01:56:33 +11:00
# $1 is the subtitle
subtitle="$1"
2016-01-21 08:58:50 +11:00
# Call the function and update variable
if [ -z "$2" ]; then
2016-01-26 14:48:39 +11:00
"get$1" 2>/dev/null
2016-01-21 08:58:50 +11:00
eval output="\$${1}"
2016-02-01 18:50:10 +11:00
2016-01-21 08:58:50 +11:00
else
2016-01-26 14:48:39 +11:00
"get$2" 2>/dev/null
2016-01-21 08:58:50 +11:00
eval output="\$${2}"
fi
2016-02-01 18:50:10 +11:00
# If the output is empty, don't print anything
[ -z "$output" ] && return
2016-06-12 11:06:35 +10:00
# Trim whitespace
output="$(trim "$output")"
2016-01-21 08:58:50 +11:00
case "$1" in
title)
2016-05-14 10:54:53 +10:00
string="${title_color}${bold}${output}"
string="${string/@/${at_color}@${title_color}${bold}}"
2016-06-12 15:51:48 +10:00
length="${#output}"
2016-01-21 08:58:50 +11:00
;;
underline)
string="${underline_color}${output}"
;;
*)
2016-08-14 11:04:25 +10:00
string="${subtitle_color}${bold}${subtitle}${reset}"
2016-01-21 08:58:50 +11:00
string+="${colon_color}: ${info_color}${output}"
2016-06-12 15:51:48 +10:00
length="$((${#subtitle} + ${#output} + 2))"
2016-01-21 08:58:50 +11:00
;;
esac
2016-02-05 16:29:11 +11:00
# If there's no subtitle don't print one
2016-06-12 15:51:48 +10:00
[ -z "$2" ] && string="${string/*: }"
2016-02-05 16:29:11 +11:00
2016-02-02 01:56:33 +11:00
# Print the string
2016-10-21 18:35:17 +11:00
printf "%b%s\n" "${padding}${zws}${string}${reset} "
2016-10-01 12:28:21 +10:00
# Calculate info height
2016-10-01 12:30:59 +10:00
info_height="$((info_height+=1))"
2016-10-04 21:29:06 +11:00
# Fix rendering issues with w3m and lines that
# wrap to the next line by adding a max line
# length.
if [ "$image" != "off" ] && [ "$image" != "ascii" ] && [ "$1" != "cols" ]; then
padding_num="${padding/\\033\[}"
output="$(printf "%.$((columns - ${padding_num/C} - gap - ${#subtitle}))s" "$output")"
fi
2016-01-21 08:58:50 +11:00
}
2016-01-26 23:06:53 +11:00
# }}}
# Prin {{{
2016-08-12 20:53:04 +10:00
prin() {
2016-08-02 23:44:10 +10:00
string="$1${2:+: $2}"
2016-01-21 08:58:50 +11:00
2016-08-02 23:50:05 +10:00
# If $2 doesn't exist we format $1 as info
if [ -z "$2" ]; then
subtitle_color="$info_color"
bold=
fi
2016-08-02 23:44:10 +10:00
# Format the output
2016-08-14 10:55:01 +10:00
string="${string/:/${reset}${colon_color}:${info_color}}"
2016-08-02 23:44:10 +10:00
string="${subtitle_color}${bold}${string}"
2016-06-12 11:06:35 +10:00
# Trim whitespace
string="$(trim "$string")"
2016-02-06 01:04:41 +11:00
# Print the info
2016-10-21 18:35:17 +11:00
printf "%b%s\n" "${padding}${zws}${string}${reset} "
2016-10-01 12:28:21 +10:00
# Calculate info height
2016-10-01 12:30:59 +10:00
info_height="$((info_height+=1))"
2016-10-04 21:29:06 +11:00
# Fix rendering issues with w3m and lines that
# wrap to the next line by adding a max line
# length.
if [ "$image" != "off" ] && [ "$image" != "ascii" ]; then
padding_num="${padding/\\033\[}"
string="$(printf "%.$((columns - ${padding_num/C} - gap))s" "$string")"
fi
2016-01-21 08:58:50 +11:00
}
2016-01-26 23:06:53 +11:00
# }}}
# Underline {{{
2016-08-12 20:53:04 +10:00
getunderline() {
2016-04-02 12:52:21 +11:00
case "$underline_enabled" in
2016-02-06 10:25:12 +11:00
"on")
2016-06-12 15:51:48 +10:00
underline="$(printf %"$length"s)"
underline="${underline// /$underline_char}"
2016-10-02 09:12:48 +07:00
;;
2016-02-06 10:25:12 +11:00
"off") underline="" ;;
esac
2016-01-03 17:54:16 +11:00
}
2016-01-26 23:06:53 +11:00
# }}}
# Colors {{{
2016-08-12 20:53:04 +10:00
colors() {
2016-08-14 11:04:25 +10:00
# Reset colors/bold
reset="\033[0m"
2016-02-23 16:52:25 +11:00
# Change color of logo based on distro
case "$ascii_distro" in
2016-02-23 17:13:23 +11:00
"Arch"* | "Antergos"*)
2016-02-23 16:52:25 +11:00
setcolors 6 4
;;
"CentOS"*)
setcolors 3 2 4 5 7
;;
2016-03-25 19:34:05 +11:00
"CRUX"* | "Chakra"* | "gNewSense"* | "SailfishOS"* | "Alpine"* | "Ubuntu-GNOME"* | "Qubes"*)
2016-05-14 19:34:32 +05:30
setcolors 4 5 7 6
2016-02-23 16:52:25 +11:00
;;
"Chrom"*)
setcolors 2 1 3 4 7
ascii_distro="chrome"
;;
2016-08-12 00:02:33 +07:00
"Debian"* | "Ubuntu"* | "DragonFly"* | "PacBSD"* | "Oracle"*)
2016-06-01 17:43:44 +10:00
setcolors 1 7 3
2016-02-23 16:52:25 +11:00
;;
2016-05-14 15:44:05 +10:00
"FreeBSD"* | "PCBSD"*)
2016-05-12 20:21:27 +10:00
setcolors 1 7 3
2016-06-01 17:43:44 +10:00
ascii_distro="freebsd"
2016-02-23 16:52:25 +11:00
;;
2016-02-23 17:13:23 +11:00
"Red"*)
2016-06-01 17:43:44 +10:00
setcolors 1 7 3
2016-02-23 16:52:25 +11:00
ascii_distro="redhat"
;;
2016-08-19 22:47:46 +10:00
"Kogaion"* | "Elementary"* | "GalliumOS"* | "Rosa"* | "OpenWrt"*)
2016-05-06 10:21:15 +10:00
setcolors 4 7
2016-05-06 03:24:48 +10:00
;;
2016-02-23 16:52:25 +11:00
"Fedora"* | "Sabayon"* | "Frugalware"* | "Exherbo"*)
2016-06-01 17:43:44 +10:00
setcolors 4 7 1
2016-02-23 16:52:25 +11:00
;;
2016-06-01 17:43:44 +10:00
"Gentoo"* | "Funtoo"* | "SteamOS"* | "Devuan"*)
2016-06-01 17:19:40 +10:00
setcolors 5 7
;;
2016-04-21 09:05:11 +10:00
"KDE"*)
setcolors 2 7
ascii_distro="kde"
;;
2016-02-23 16:52:25 +11:00
"Kali"*)
setcolors 4 8
;;
2016-08-14 14:33:36 +10:00
*"OS X"* | *"iOS"* | "Mac" | *"macOS"*)
2016-02-23 16:52:25 +11:00
setcolors 2 3 1 1 5 4
2016-03-13 22:49:37 +11:00
ascii_distro="mac"
2016-02-23 16:52:25 +11:00
;;
"OpenMandriva"*)
setcolors 4 3
;;
2016-10-22 15:19:56 +11:00
"Mageia"* | "Porteus"*)
2016-06-01 17:43:44 +10:00
setcolors 6 7
2016-02-23 16:52:25 +11:00
;;
"Peppermint"*)
2016-06-01 17:43:44 +10:00
setcolors 1 7
2016-02-23 16:52:25 +11:00
;;
*"Mint"*)
2016-06-01 17:43:44 +10:00
setcolors 2 7
2016-02-23 16:52:25 +11:00
ascii_distro="mint"
;;
2016-10-16 09:48:25 +07:00
"LMDE"* | "Chapeau"* | "Bitrig"*)
2016-06-01 17:43:44 +10:00
setcolors 2 7
2016-02-23 16:52:25 +11:00
;;
"NetBSD"* | "Parabola"* | "Tails"* | "BLAG"*)
setcolors 5 7
;;
2016-08-27 15:42:56 +07:00
"OpenBSD"* | "GuixSD"*)
2016-04-25 11:59:29 +10:00
setcolors 3 7 6 1 8
2016-02-23 16:52:25 +11:00
;;
2016-03-13 22:49:37 +11:00
"OpenSuse"* | "Manjaro"* | "Deepin"*)
2016-02-23 16:52:25 +11:00
setcolors 2 7
;;
2016-08-12 09:26:59 +10:00
"PCLinuxOS"* | "Slackware"* | "KaOS"* | "Kubuntu"* | "Lubuntu"* | "Xubuntu"* | "OpenIndiana"*)
2016-02-23 21:20:36 +11:00
setcolors 4 7 1
2016-02-23 16:52:25 +11:00
;;
2016-03-26 22:32:31 +11:00
"Puppy"* | "Quirky Werewolf"* | "Precise Puppy"*)
setcolors 4
ascii_distro="puppy"
;;
2016-10-16 09:38:56 +11:00
"Sparky"*)
setcolors 1 7
ascii_distro="sparky"
;;
2016-02-23 16:52:25 +11:00
"Scientific"*)
setcolors 4 1 7
;;
"Solus"*)
2016-10-01 18:16:10 +03:00
setcolors 7 4 0
2016-02-23 16:52:25 +11:00
;;
"Trisquel"* | "NixOS"* | "Zorin"*)
setcolors 4 6
;;
2016-03-26 15:22:24 +11:00
"Travis")
2016-08-05 10:37:13 +10:00
setcolors 1 2 3 4 5 6
2016-03-26 15:22:24 +11:00
;;
2016-02-23 16:52:25 +11:00
"void"*)
2016-03-03 09:40:16 +11:00
setcolors 2 8
2016-02-23 16:52:25 +11:00
;;
2016-10-02 11:33:31 +11:00
"Windows 8"* | "Windows 10"*)
2016-02-23 16:52:25 +11:00
setcolors 6
ascii_distro="windows10"
;;
"Windows"*)
setcolors 1 2 4 3
;;
2016-02-23 17:24:12 +11:00
2016-02-23 21:20:36 +11:00
"Raspbian"* | *)
2016-02-23 17:24:12 +11:00
setcolors 2 1
;;
2016-02-23 16:52:25 +11:00
esac
2016-02-23 20:06:35 +11:00
# Overwrite distro colors if '$ascii_colors' doesn't
# equal 'distro'.
[ "${ascii_colors[0]}" != "distro" ] && \
setcolors ${ascii_colors[@]}
2015-12-30 21:18:17 +11:00
}
2016-08-12 20:53:04 +10:00
setcolors() {
2016-06-12 14:35:29 +10:00
c1="$(color "$1")${ascii_bold}"
c2="$(color "$2")${ascii_bold}"
c3="$(color "$3")${ascii_bold}"
c4="$(color "$4")${ascii_bold}"
c5="$(color "$5")${ascii_bold}"
c6="$(color "$6")${ascii_bold}"
2016-03-29 19:54:09 +11:00
2016-02-23 16:52:25 +11:00
if [ "${colors[0]}" == "distro" ]; then
2016-03-29 21:04:31 +11:00
title_color="$c1"
2016-08-14 11:04:25 +10:00
at_color="$reset"
underline_color="$reset"
2016-03-29 21:04:31 +11:00
subtitle_color="$c2"
2016-08-14 11:04:25 +10:00
colon_color="$reset"
info_color="$reset"
2016-02-23 16:52:25 +11:00
# If the second color is white use the first for the subtitle
2016-08-14 11:04:25 +10:00
[ "$2" == 7 ] && subtitle_color="$(color "$1")"
[ "$1" == 7 ] && title_color="$reset"
2016-02-23 16:52:25 +11:00
else
2016-06-12 14:35:29 +10:00
title_color="$(color "${colors[0]}")"
at_color="$(color "${colors[1]}")"
underline_color="$(color "${colors[2]}")"
subtitle_color="$(color "${colors[3]}")"
colon_color="$(color "${colors[4]}")"
info_color="$(color "${colors[5]}")"
2016-02-23 16:52:25 +11:00
fi
2016-03-27 20:46:05 +11:00
2016-03-29 23:02:23 +11:00
if [ "$progress_color_elapsed" == "distro" ]; then
2016-04-24 11:10:57 +10:00
progress_color_elapsed="$(color fg)"
2016-03-29 23:02:23 +11:00
else
2016-06-12 14:35:29 +10:00
progress_color_elapsed="$(color "$progress_color_elapsed")"
2016-03-27 20:49:06 +11:00
fi
2016-03-27 20:46:05 +11:00
2016-03-29 23:31:08 +11:00
case "$progress_color_total $1" in
distro\ [736]) progress_color_total="$c2" ;;
distro\ [0-9]) progress_color_total="$c1" ;;
2016-06-12 14:35:29 +10:00
*) progress_color_total="$(color "$progress_color_total")" ;;
2016-03-29 23:31:08 +11:00
esac
2016-01-21 09:49:50 +11:00
}
2016-08-12 20:53:04 +10:00
color() {
2016-04-24 09:34:02 +10:00
case "$1" in
2016-08-14 11:04:25 +10:00
[0-7]) printf "%b%s" "${reset}\033[3${1}m" ;;
"fg") printf "%b%s" "$reset" ;;
2016-04-24 09:34:02 +10:00
*) printf "%b%s" "\033[38;5;${1}m" ;;
esac
2016-03-04 13:15:03 +11:00
}
2016-01-26 23:06:53 +11:00
# }}}
# Bold {{{
2016-08-12 20:53:04 +10:00
bold() {
2016-05-15 01:13:33 +10:00
case "$ascii_bold" in
"on") ascii_bold="\033[1m" ;;
"off") ascii_bold="" ;;
esac
2016-02-01 13:19:09 +11:00
case "$bold" in
"on") bold="\033[1m" ;;
"off") bold="" ;;
esac
2016-01-03 17:54:16 +11:00
}
2016-01-26 23:06:53 +11:00
# }}}
2016-01-29 23:54:12 +11:00
# Linebreak {{{
2016-08-12 20:53:04 +10:00
getlinebreak() {
2016-10-02 09:12:48 +07:00
linebreak=" "
2016-10-22 10:11:18 +11:00
# Calculate info height
info_height="$((info_height+=1))"
2016-01-29 23:54:12 +11:00
}
# }}}
2016-01-26 23:06:53 +11:00
2016-06-12 11:06:35 +10:00
# Trim whitespace {{{
2016-06-12 11:57:10 +10:00
# When a string is passed to 'echo' all trailing and leading
# whitespace is removed and inside the string multiple spaces are
# condensed into single spaces.
#
# The 'set -f/+f' is here so that 'echo' doesn't cause any expansion
# of special characters.
#
# The whitespace trim doesn't work with multiline strings so we use
# '${1//[[:space:]]/ }' to remove newlines beofre we trim the whitespace.
2016-06-12 11:06:35 +10:00
trim() {
set -f
2016-06-12 11:57:10 +10:00
builtin echo -E ${1//[[:space:]]/ }
2016-06-12 11:06:35 +10:00
set +f
}
# }}}
2015-12-30 21:18:17 +11:00
# }}}
2016-01-30 02:14:29 +11:00
# Other {{{
2016-08-12 11:20:32 +10:00
# Error {{{
2016-08-12 20:53:04 +10:00
err() {
2016-08-14 13:13:21 +10:00
err+="$(color 1)[!]\033[0m $1
2016-08-12 16:45:36 +10:00
"
2016-08-12 11:20:32 +10:00
}
# }}}
2016-10-15 09:08:12 +07:00
# Check for old flags {{{
checkoldflags() {
2016-10-22 01:27:39 +11:00
[ -n "$osx_buildversion" ] && err "Config: \$osx_buildversion is deprecated, use \$distro_shorthand instead."
[ -n "$osx_codename" ] && err "Config: \$osx_codename is deprecated, use \$distro_shorthand instead."
[ -n "$progress_char" ] && err "Config: \$progress_char is deprecated, use \$progress_char_elapsed and \$progress_char_total instead."
[ "$cpu_cores" == "on" ] && err "Config: \$cpu_cores='on' is deprecated, use \$cpu_cores='logical|physical|off' instead."
2016-10-15 09:08:12 +07:00
}
# }}}
2016-01-30 02:14:29 +11:00
# Get script directory {{{
2016-08-12 20:53:04 +10:00
getscriptdir() {
2016-08-12 09:47:09 +10:00
[ "$script_dir" ] && return
2016-01-30 02:14:29 +11:00
# Use $0 to get the script's physical path.
2016-01-30 16:31:22 +11:00
cd "${0%/*}" || exit
2016-06-12 15:51:48 +10:00
script_dir="${0##*/}"
2016-01-30 02:14:29 +11:00
# Iterate down a (possible) chain of symlinks.
while [ -L "$script_dir" ]; do
2016-01-30 16:31:22 +11:00
script_dir="$(readlink "$script_dir")"
cd "${script_dir%/*}" || exit
2016-01-30 02:14:29 +11:00
script_dir="${script_dir##*/}"
done
# Final directory
script_dir="$(pwd -P)"
}
2016-08-12 11:20:32 +10:00
# }}}
# Source default config {{{
2016-08-12 20:53:04 +10:00
getdefaultconfig() {
2016-08-12 11:20:32 +10:00
if [ -f "/usr/share/neofetch/config" ]; then
default_config="/usr/share/neofetch/config"
elif [ -f "/usr/local/share/neofetch/config" ]; then
default_config="/usr/local/share/neofetch/config"
else
getscriptdir
default_config="${script_dir}/config/config"
fi
2016-08-12 11:38:32 +10:00
if source "$default_config"; then
2016-10-22 01:27:39 +11:00
err "Config: Sourced default config ($default_config)"
2016-08-12 11:20:32 +10:00
else
2016-10-22 01:27:39 +11:00
err "Config: Default config not found, continuing..."
2016-08-12 11:20:32 +10:00
fi
}
2016-01-30 02:14:29 +11:00
# }}}
2016-08-13 19:42:31 +10:00
# Source config {{{
2016-01-30 02:14:29 +11:00
2016-08-12 20:53:04 +10:00
getuserconfig() {
2016-01-30 12:05:53 +11:00
# Check $config_file
2016-01-30 02:14:29 +11:00
if [ -f "$config_file" ]; then
source "$config_file"
2016-10-22 01:27:39 +11:00
err "Config: Sourced user config ($config_file)"
2016-01-30 02:14:29 +11:00
return
fi
2016-04-01 09:47:48 +11:00
mkdir -p "$XDG_CONFIG_HOME/neofetch/"
2016-01-30 02:14:29 +11:00
2016-04-01 09:47:48 +11:00
# Check $XDG_CONFIG_HOME/neofetch and create the
2016-01-30 02:14:29 +11:00
# dir/files if they don't exist.
2016-04-01 09:47:48 +11:00
if [ -f "$XDG_CONFIG_HOME/neofetch/config" ]; then
2016-08-12 11:25:59 +10:00
config_file="$XDG_CONFIG_HOME/neofetch/config"
2016-01-30 02:18:27 +11:00
2016-02-28 11:44:45 +11:00
elif [ -f "/usr/share/neofetch/config" ]; then
2016-04-01 09:47:48 +11:00
cp "/usr/share/neofetch/config" "$XDG_CONFIG_HOME/neofetch"
2016-08-12 11:25:59 +10:00
config_file="$XDG_CONFIG_HOME/neofetch/config"
2016-01-30 02:18:27 +11:00
2016-02-28 11:44:45 +11:00
elif [ -f "/usr/local/share/neofetch/config" ]; then
2016-04-01 09:47:48 +11:00
cp "/usr/local/share/neofetch/config" "$XDG_CONFIG_HOME/neofetch"
2016-08-12 11:25:59 +10:00
config_file="$XDG_CONFIG_HOME/neofetch/config"
2016-02-08 22:02:49 +11:00
2016-01-30 02:14:29 +11:00
else
getscriptdir
2016-04-01 09:47:48 +11:00
cp "$script_dir/config/config" "$XDG_CONFIG_HOME/neofetch"
2016-08-12 11:25:59 +10:00
config_file="$XDG_CONFIG_HOME/neofetch/config"
2016-01-30 02:14:29 +11:00
fi
2016-08-12 11:25:59 +10:00
source "$config_file"
2016-10-22 01:27:39 +11:00
err "Config: Sourced user config ($config_file)"
2016-01-30 02:14:29 +11:00
}
2016-01-30 11:30:21 +11:00
2016-08-12 09:47:09 +10:00
# }}}
2016-08-13 19:42:31 +10:00
# Progress bars {{{
2016-03-03 10:12:21 +11:00
bar() {
# Get the values
2016-06-12 15:51:48 +10:00
elapsed="$(($1 * progress_length / $2))"
2016-03-03 10:12:21 +11:00
# Create the bar with spaces
2016-06-12 15:51:48 +10:00
prog="$(printf %"$elapsed"s)"
total="$(printf %"$((progress_length - elapsed))"s)"
2016-03-03 10:12:21 +11:00
# Set the colors and swap the spaces for $progress_char
2016-04-24 18:30:57 +10:00
bar+="${progress_color_elapsed}${prog// /$progress_char_elapsed}"
bar+="${progress_color_total}${total// /$progress_char_total}"
# Borders
if [ "$progress_border" == "on" ]; then
bar+="$(color fg)]"
bar="$(color fg)[$bar"
fi
2016-06-13 21:59:54 +10:00
printf "%b%s\n" "${bar}${info_color}"
2016-03-03 10:12:21 +11:00
}
# }}}
2016-01-30 02:14:29 +11:00
2016-03-30 14:00:13 +11:00
# Cache {{{
2016-08-12 20:53:04 +10:00
cache() {
2016-03-30 19:24:03 +11:00
mkdir -p "$3/neofetch"
echo "${1/*-}=\"$2\"" > "$3/neofetch/${1/*-}"
2016-03-30 14:00:13 +11:00
}
# }}}
2016-03-28 09:41:53 +11:00
2016-08-13 19:42:31 +10:00
# KDE config directory {{{
2016-04-01 14:50:15 +11:00
2016-08-12 20:53:04 +10:00
kdeconfigdir() {
2016-04-01 17:38:06 +11:00
if [ -n "$KDE_CONFIG_DIR" ]; then
kde_config_dir="$KDE_CONFIG_DIR"
elif type -p kde5-config >/dev/null 2>&1; then
2016-06-12 15:51:48 +10:00
kde_config_dir="$(kde5-config --localprefix)"
2016-04-01 14:50:15 +11:00
elif type -p kde4-config >/dev/null 2>&1; then
2016-06-12 15:51:48 +10:00
kde_config_dir="$(kde4-config --localprefix)"
2016-04-01 14:50:15 +11:00
elif type -p kde-config >/dev/null 2>&1; then
2016-06-12 15:51:48 +10:00
kde_config_dir="$(kde-config --localprefix)"
2016-04-01 14:50:15 +11:00
fi
}
# }}}
2016-08-13 19:42:31 +10:00
# Dynamic prompt location {{{
dynamicprompt() {
# Calculate image height in terminal cells.
2016-10-22 01:05:47 +11:00
if [ "$image" != "ascii" ]; then
2016-10-22 20:25:41 +11:00
lines="$((height / font_height))"
cursor_yoffset="$((${yoffset:-1} / font_height))"
2016-10-22 09:51:58 +11:00
else
2016-10-22 10:11:18 +11:00
cursor_yoffset="0 - 2"
2016-10-22 01:05:47 +11:00
fi
2016-08-13 19:42:31 +10:00
# If the info is higher than the ascii/image place the prompt
# based on the info height instead of the ascii/image height.
2016-10-01 12:28:21 +10:00
if [ "${lines:-0}" -lt "${info_height:-0}" ]; then
2016-10-22 10:15:47 +11:00
lines="-2"
2016-10-01 12:28:21 +10:00
else
2016-10-22 01:35:28 +11:00
lines="$((lines - info_height + cursor_yoffset))"
2016-10-01 12:28:21 +10:00
fi
2016-08-13 19:42:31 +10:00
# Set the prompt location
2016-10-22 10:15:47 +11:00
if [ "$lines" -lt 0 ]; then
2016-10-22 10:20:14 +11:00
printf "\033[${lines/-}A"
2016-10-22 10:15:47 +11:00
else
printf "\033[${lines}B"
fi
2016-10-03 21:47:29 +11:00
2016-10-22 00:42:34 +11:00
# Add some padding
2016-10-22 20:25:41 +11:00
printf "\n\n"
2016-08-13 19:42:31 +10:00
}
# }}}
2016-10-02 23:58:08 +11:00
# Scrot args {{{
scrot_args() {
scrot="on"
case "$2" in
2016-10-04 08:48:33 +11:00
"-"* | "") ;;
2016-10-02 23:58:08 +11:00
*)
scrot_name="${2##*/}"
scrot_dir="${2/$scrot_name}"
;;
esac
}
# }}}
2016-06-13 21:59:54 +10:00
# }}}
2016-01-03 17:54:16 +11:00
# Usage {{{
2016-08-12 20:53:04 +10:00
usage() { cat << EOF
2016-01-06 09:40:54 +11:00
2016-02-28 11:44:45 +11:00
usage: neofetch --option "value" --option "value"
2016-01-06 09:40:54 +11:00
2016-02-21 17:07:14 +11:00
NOTE: There's also a config option for each flag below.
2016-01-06 09:40:54 +11:00
Info:
2016-02-03 19:15:42 +11:00
--disable infoname Allows you to disable an info line from appearing
in the output.
NOTE: You can supply multiple args. eg.
2016-02-28 11:44:45 +11:00
'neofetch --disable cpu gpu disk shell'
2016-10-07 17:23:16 +07:00
--os_arch on/off Hide/Show OS architecture.
2016-02-03 19:15:42 +11:00
--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.
2016-03-11 08:27:00 +11:00
--cpu_shorthand type Shorten the output of CPU
2016-03-11 13:59:22 +11:00
Possible values: name, speed, tiny, on, off
2016-10-21 16:38:02 +11:00
--cpu_cores type Whether or not to display the number of CPU cores
2016-10-21 16:40:58 +11:00
Takes: logical, physical, off
2016-10-23 09:45:03 +11:00
NOTE: 'physical' doesn't work on BSD.
--cpu_speed on/off Hide/Show cpu speed.
--cpu_temp on/off Hide/Show cpu temperature.
NOTE This only works on linux.
2016-08-31 21:43:53 +07:00
--distro_shorthand on/off Shorten the output of distro (tiny, on, off)
2016-10-15 23:20:25 +11:00
NOTE: This is only possible on Linux, macOS, and Solaris
2016-02-03 19:15:42 +11:00
--kernel_shorthand on/off Shorten the output of kernel
--uptime_shorthand on/off Shorten the output of uptime (tiny, on, off)
2016-03-18 16:28:26 +11:00
--refresh_rate on/off Whether to display the refresh rate of each monitor
2016-03-26 11:34:35 +11:00
Unsupported on Windows
2016-03-11 20:48:06 +11:00
--gpu_shorthand on/off Shorten the output of GPU (tiny, on, off)
2016-10-02 18:26:50 +11:00
--gpu_brand on/off Enable/Disable GPU brand in output. (AMD/NVIDIA/Intel)
2016-02-03 19:15:42 +11:00
--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
2016-02-09 17:26:44 +11:00
--ip_host url Url to ping for public IP
2016-02-19 11:26:24 +11:00
--song_shorthand on/off Print the Artist/Title on seperate lines
2016-02-03 19:15:42 +11:00
--birthday_shorthand on/off Shorten the output of birthday
2016-02-07 16:41:34 +11:00
--birthday_time on/off Enable/Disable showing the time in birthday output
2016-03-06 09:56:46 +11:00
--birthday_format format Format the birthday output. (Uses 'date' cmd format)
2016-01-19 13:49:30 +11:00
2016-01-06 09:40:54 +11:00
Text Formatting:
2016-03-05 09:30:53 +11:00
--colors x x x x x x Changes the text colors in this order:
title, @, underline, subtitle, colon, info
2016-04-29 17:41:21 +10:00
--underline on/off enable/disable the underline.
2016-03-05 09:30:53 +11:00
--underline_char char Character to use when underlining title
2016-02-03 19:15:42 +11:00
--bold on/off Enable/Disable bold text
2016-01-06 09:40:54 +11:00
Color Blocks:
2016-02-03 19:15:42 +11:00
--color_blocks on/off Enable/Disable the color blocks
2016-05-28 09:53:35 +10:00
--block_width num Width of color blocks in spaces
--block_height num Height of color blocks in lines
2016-02-03 19:15:42 +11:00
--block_range start end Range of colors to print as blocks
2016-03-03 10:12:21 +11:00
Progress Bars:
2016-04-29 17:41:21 +10:00
--progress_char 'elapsed char' 'total char'
Characters to use when drawing progress bars.
--progress_border on/off Whether or not to surround the bar with '[]'
2016-03-03 10:41:13 +11:00
--progress_length num Length in spaces to make the progress bars.
2016-03-13 09:14:56 +11:00
--progress_colors num num Colors to make the progress bar.
Set in this order: elapsed, total
2016-06-13 21:42:53 +10:00
--cpu_display mode Progress bar mode.
Takes: bar, infobar, barinfo, off
--memory_display mode Progress bar mode.
Takes: bar, infobar, barinfo, off
--battery_display mode Progress bar mode.
Takes: bar, infobar, barinfo, off
--disk_display mode Progress bar mode.
Takes: bar, infobar, barinfo, off
2016-03-03 10:12:21 +11:00
2016-01-06 09:40:54 +11:00
Image:
2016-02-03 19:15:42 +11:00
--image type Image source. Where and what image we display.
2016-03-25 21:22:58 +11:00
Possible values: wall, ascii,
/path/to/img, /path/to/dir/, off
2016-05-27 15:23:02 +10:00
--size 00px | --size 00% How to size the image.
Possible values: auto, 00px, 00%, none
2016-02-03 19:15:42 +11:00
--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.
2016-10-22 01:14:02 +11:00
--bg_color color Background color to display behind transparent image.
This only works with w3m.
2016-02-03 19:15:42 +11:00
--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-06 09:40:54 +11:00
2016-01-27 22:33:22 +11:00
Ascii:
2016-02-03 19:15:42 +11:00
--ascii value Where to get the ascii from, Possible values:
distro, /path/to/ascii
2016-03-06 09:08:59 +11:00
--ascii_colors x x x x x x Colors to print the ascii art
2016-02-28 13:38:01 -06:00
--ascii_distro distro Which Distro's ascii art to print
2016-04-29 17:41:21 +10:00
--ascii_logo_size Size of ascii logo.
Supported distros: Arch, Gentoo, Crux, OpenBSD.
2016-05-15 01:13:33 +10:00
--ascii_bold on/off Whether or not to bold the ascii logo.
2016-10-03 21:51:42 +11:00
--logo | -L Hide the info text and only show the ascii logo.
2016-01-27 22:33:22 +11:00
2016-01-08 16:08:00 +11:00
Screenshot:
2016-10-02 20:28:35 +11:00
--scrot | -s /path/to/img Take a screenshot, if path is left empty the screen-
2016-02-03 19:15:42 +11:00
shot function will use \$scrot_dir and \$scrot_name.
2016-10-04 08:26:31 +11:00
--upload | -su /pth/t/img Same as --scrot but uploads the scrot to a website.
2016-10-02 22:49:30 +11:00
--image_host Website to upload scrots to. Takes: imgur, teknik
2016-02-03 19:15:42 +11:00
--scrot_cmd cmd Screenshot program to launch
2016-01-08 16:08:00 +11:00
2016-01-06 09:40:54 +11:00
Other:
2016-02-03 19:15:42 +11:00
--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
2016-05-30 15:14:16 +10:00
--version Show neofetch version
2016-04-29 17:45:51 +10:00
--test Launch the script with all functions / options enabled.
This should only be used for testing purposes, ie Travis.CI.
-v Display error messages.
-vv Display a verbose log for error reporting.
2016-01-06 09:40:54 +11:00
EOF
exit 1
2016-01-03 17:54:16 +11:00
}
# }}}
2016-01-04 10:20:36 +11:00
# Args {{{
2016-08-14 13:13:21 +10:00
getargs() {
# Check the commandline flags early for '--config none/off'
case "$@" in
*"--config off"* | *'--config "off"'* | *"--config 'off'"* | \
2016-08-19 23:01:18 +10:00
*"--config none"* | *'--config "none"'* | *"--config 'none'"*)
2016-08-14 13:13:21 +10:00
config="off"
2016-02-04 12:50:50 +11:00
;;
2016-01-19 13:49:30 +11:00
2016-10-04 08:48:33 +11:00
*"--config -"*) ;;
2016-08-14 13:13:21 +10:00
*"--config"*) config="off" ;;
esac
2016-02-14 20:39:35 +11:00
2016-08-14 13:13:21 +10:00
[ "${config:-on}" == "on" ] && getuserconfig 2>/dev/null
while [ "$1" ]; do
case $1 in
# Info
--os_arch) os_arch="$2" ;;
--cpu_cores) cpu_cores="$2" ;;
2016-10-23 09:45:03 +11:00
--cpu_speed) cpu_speed="$2" ;;
--cpu_temp) cpu_temp="$2" ;;
2016-08-14 13:13:21 +10:00
--speed_type) speed_type="$2" ;;
2016-08-28 23:11:01 +07:00
--distro_shorthand) distro_shorthand="$2" ;;
2016-08-14 13:13:21 +10:00
--kernel_shorthand) kernel_shorthand="$2" ;;
--uptime_shorthand) uptime_shorthand="$2" ;;
--cpu_shorthand) cpu_shorthand="$2" ;;
--gpu_shorthand) gpu_shorthand="$2" ;;
2016-10-02 18:26:50 +11:00
--gpu_brand) gpu_brand="$2" ;;
2016-08-14 13:13:21 +10:00
--refresh_rate) refresh_rate="$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" ;;
--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 ;;
2016-10-04 08:48:33 +11:00
"-"*) return ;;
2016-08-14 13:13:21 +10:00
*) unset -f "get$func" ;;
esac
done
;;
2016-01-27 22:33:22 +11:00
2016-08-14 13:13:21 +10:00
# Text Colors
--colors)
unset colors
for arg in "$2" "$3" "$4" "$5" "$6" "$7"; do
case "$arg" in
2016-10-04 08:48:33 +11:00
"-"*) break ;;
2016-08-14 13:13:21 +10:00
*) colors+=($arg)
esac
done
colors+=(7 7 7 7 7 7)
;;
2016-02-28 13:07:10 +11:00
2016-08-14 13:13:21 +10:00
# Text Formatting
--underline) underline_enabled="$2" ;;
--underline_char) underline_char="$2" ;;
--bold) bold="$2" ;;
# Color Blocks
--color_blocks) color_blocks="$2" ;;
--block_range) start="$2"; end="$3" ;;
--block_width) block_width="$2" ;;
--block_height) block_height="$2" ;;
# Progress Bars
--progress_char)
progress_char_elapsed="$2"
progress_char_total="$3"
;;
--progress_border) progress_border="$2" ;;
--progress_length) progress_length="$2" ;;
--progress_colors)
progress_color_elapsed="$2"
progress_color_total="$3"
;;
--cpu_display) cpu_display="$2" ;;
--memory_display) memory_display="$2" ;;
--battery_display) battery_display="$2" ;;
--disk_display) disk_display="$2" ;;
# Image
--image)
image="$2"
2016-10-04 08:48:33 +11:00
case "$2" in "-"* | "") image="ascii" ;; esac
2016-08-14 13:13:21 +10:00
;;
2016-01-08 16:08:00 +11:00
2016-10-03 18:13:16 +11:00
--image_size | --size) image_size="$2" ;;
2016-08-14 13:13:21 +10:00
--crop_mode) crop_mode="$2" ;;
--crop_offset) crop_offset="$2" ;;
--xoffset) xoffset="$2" ;;
--yoffset) yoffset="$2" ;;
2016-10-22 01:14:02 +11:00
--background_color | --bg_color) background_color="$2" ;;
2016-08-14 13:13:21 +10:00
--gap) gap="$2" ;;
--clean)
rm -rf "$thumbnail_dir"
rm -rf "/Library/Caches/neofetch/"
exit
;;
2016-02-05 16:29:11 +11:00
2016-08-14 13:13:21 +10:00
# Ascii
--ascii)
image="ascii"
ascii="$2"
2016-10-04 08:48:33 +11:00
case "$2" in "-"* | "") ascii="distro" ;; esac
2016-08-14 13:13:21 +10:00
;;
2016-03-26 14:13:02 +11:00
2016-08-14 13:13:21 +10:00
--ascii_colors)
unset ascii_colors
for arg in "$2" "$3" "$4" "$5" "$6" "$7"; do
case "$arg" in
2016-10-04 08:48:33 +11:00
"-"*) break ;;
2016-08-14 13:13:21 +10:00
*) ascii_colors+=($arg)
esac
done
ascii_colors+=(7 7 7 7 7 7)
;;
2016-08-12 10:41:52 +10:00
2016-08-14 13:13:21 +10:00
--ascii_distro)
ascii_distro="$2"
2016-10-04 08:48:33 +11:00
case "$2" in "-"* | "") ascii_distro="$distro" ;; esac
2016-08-14 13:13:21 +10:00
;;
--ascii_logo_size) ascii_logo_size="$2" ;;
--ascii_bold) ascii_bold="$2" ;;
2016-10-03 21:51:42 +11:00
--logo | -L)
image="ascii"
printinfo() { info linebreak; }
;;
2016-08-14 13:13:21 +10:00
# Screenshot
--scrot | -s)
2016-10-02 23:58:08 +11:00
scrot_args "$@"
2016-08-14 13:13:21 +10:00
;;
2016-10-02 20:23:02 +11:00
--upload | -su)
scrot_upload="on"
2016-10-02 23:58:08 +11:00
scrot_args "$@"
2016-10-02 20:23:02 +11:00
;;
2016-10-02 23:58:08 +11:00
2016-10-02 20:28:35 +11:00
--image_host) image_host="$2" ;;
2016-08-14 13:13:21 +10:00
--scrot_cmd) scrot_cmd="$2" ;;
# Other
--config)
case "$2" in
"none" | "off") config="off" ;;
*) config_file="$2"; config="on"; getuserconfig 2>/dev/null ;;
esac
;;
--test)
2016-08-14 14:16:25 +10:00
info=(title underline model distro kernel uptime packages shell resolution de wm wmtheme theme icons cpu cpu_usage gpu memory font disk battery song localip publicip users birthday term termfont)
2016-08-14 13:13:21 +10:00
2016-08-14 13:14:18 +10:00
refresh_rate="on"
shell_version="on"
cpu_display="infobar"
memory_display="infobar"
disk_display="infobar"
2016-10-23 09:51:16 +11:00
cpu_temp="on"
2016-08-14 13:13:21 +10:00
printinfo() {
if [ "$TRAVIS_OS_NAME" ]; then
info linebreak
info linebreak
fi
2016-03-29 18:25:11 +11:00
2016-08-14 13:13:21 +10:00
for func in "${info[@]}"; do
info "$(tr '[:lower:]' '[:upper:]' <<< "$func")" "$func"
done
2016-08-12 10:33:21 +10:00
2016-08-14 13:13:21 +10:00
info linebreak
info cols
info linebreak
printf "%b%s" "\033[$(tput lines)H"
}
;;
-v) verbose="on" ;;
-vv) set -x; verbose="on" ;;
--help) usage ;;
2016-10-02 14:17:51 +11:00
--version) printf "%s\n" "Neofetch 1.9"; exit ;;
2016-08-14 13:13:21 +10:00
esac
2015-12-30 21:18:17 +11:00
2016-08-14 13:13:21 +10:00
shift
done
}
2015-12-30 21:18:17 +11:00
# }}}
2016-01-04 09:21:13 +11:00
# Call Functions and Finish Up {{{
2015-12-30 21:18:17 +11:00
2016-08-12 20:53:04 +10:00
main() {
2016-08-19 10:05:45 +10:00
getos
2016-08-14 13:13:21 +10:00
getdefaultconfig 2>/dev/null
2016-10-15 09:08:12 +07:00
checkoldflags
2016-08-14 13:13:21 +10:00
getargs "$@"
2016-08-19 10:09:35 +10:00
getdistro
# Get colors and bold
bold
colors
2016-08-13 21:28:23 +10:00
2016-08-12 20:36:48 +10:00
# Restore cursor and clear screen on ctrl+c
trap 'printf "\033[?25h"; clear; exit' 2
2016-01-21 10:56:55 +11:00
2016-08-12 20:36:48 +10:00
# If the script exits for any reason, unhide the cursor.
trap 'printf "\033[?25h"' EXIT
2016-04-13 15:31:53 +10:00
2016-08-13 18:39:06 +10:00
# Hide the cursor and disable line wrap
printf "\033[?25l\033[?7l"
2016-01-30 17:44:52 +11:00
2016-08-13 19:42:31 +10:00
# Display the image
2016-08-12 20:36:48 +10:00
if [ "$image" != "off" ]; then
2016-08-13 19:42:31 +10:00
getimagebackend
2016-08-12 20:36:48 +10:00
# Find w3mimgdisplay
[ "$image_backend" == "w3m" ] && \
[ "$image" != "ascii" ] && \
getw3m_img_path
2016-08-13 19:42:31 +10:00
# Get the image src
2016-08-12 20:36:48 +10:00
getimage
2016-08-13 19:42:31 +10:00
# Display the image if enabled
displayimage
2015-12-30 21:18:17 +11:00
2016-10-21 21:45:32 +11:00
# Set cursor position next to ascii art
printf "\033[$((${lines:-4} - ${prompt_loc:-4}))A"
2016-10-01 11:42:18 +10:00
2016-10-21 21:45:32 +11:00
# Reset horizontal cursor position
printf "\033[9999999D"
fi
2016-10-01 11:42:18 +10:00
2016-08-12 20:36:48 +10:00
# Print the info
printinfo
2016-10-21 21:45:32 +11:00
[ "$image" != "off" ] && dynamicprompt
2016-01-29 11:35:04 +11:00
2016-10-22 00:06:51 +11:00
# w3m-img: Draw the image a second time to fix
# rendering issues in specific terminal emulators.
[ "$image_backend" == "w3m" ] && displayimage
2016-08-12 20:36:48 +10:00
# Re-enable line wrap
printf "%b%s" "\033[?7h"
2016-01-17 17:17:13 +11:00
2016-08-12 20:36:48 +10:00
[ "$scrot" == "on" ] && takescrot
2016-08-04 09:20:42 +10:00
2016-08-12 20:36:48 +10:00
# Show error messages
2016-08-14 13:13:21 +10:00
[ "$verbose" == "on" ] && printf "%b%s" "$err"
2016-01-29 10:11:34 +11:00
2016-08-13 19:28:21 +10:00
# Reset exit status of the tests above
2016-08-12 20:36:48 +10:00
printf "%s"
}
2016-01-08 16:08:00 +11:00
2016-08-14 13:13:21 +10:00
main "$@"
2016-04-24 14:14:35 +10:00
2016-01-03 17:54:16 +11:00
# }}}