distribution/packages/jelos/sources/scripts/brightness
fewtarius 6780f3ad3f
Revert "Merge pull request #2141 from fewtarius/dev"
This reverts commit 2e21c362e7, reversing
changes made to a8a0a59e43.
2023-10-03 19:53:21 +00:00

88 lines
1.8 KiB
Bash
Executable file

#!/bin/bash
# SPDX-License-Identifier: GPL-2.0-or-later
# Copyright (C) 2020-present Fewtarius
## Load minimal distribution settings to improve
## performance.
. /etc/profile.d/001-functions
BRIGHTNESS_DEV="$(find /sys/class/backlight/*/ -name brightness -print -quit)"
BRIGHTNESS_PATH="${BRIGHTNESS_DEV%/brightness}"
BRIGHTNESS_TABLE=($(get_setting brightness_table))
if [ -z $BRIGHTNESS_TABLE ]; then
BRIGHTNESS_TABLE="0 0.04 0.08 0.13 0.19 0.25 0.33 0.42 0.54 0.71 1"
set_setting brightness_table "$BRIGHTNESS_TABLE"
fi
NUM_STEPS=${#BRIGHTNESS_TABLE[@]}
MAX=$(<$(find /sys/class/backlight/*/ -name max_brightness -print -quit))
compute() {
echo "${BRIGHTNESS_TABLE[$NEXT]} * $MAX" | bc -l
}
if [ ! -f "${BRIGHTNESS_DEV}" ]
then
echo "ERROR: There is no BRIGHTNESS object to manage."
exit 1
fi
getBrightness() {
echo $(<${BRIGHTNESS_DEV})
}
setBrightness() {
echo "${1}" > ${BRIGHTNESS_DEV}
set_setting system.brightness "${2}"
}
stepUp() {
CURRENT=$(get_setting system.brightness)
NEXT=$(( ${CURRENT} + 1 ))
if (( ${NEXT} >= $NUM_STEPS ))
then
NEXT=$(( $NUM_STEPS - 1 ))
fi
BRIGHTNESS=$(printf '%.0f' "$(compute)")
if (($BRIGHTNESS > $MAX ))
then
BRIGHTNESS=$MAX
fi
setBrightness ${BRIGHTNESS} ${NEXT}
}
stepDown() {
CURRENT=$(get_setting system.brightness)
NEXT=$(( ${CURRENT} - 1 ))
if (( ${NEXT} < 0 ))
then
NEXT=0
fi
BRIGHTNESS=$(printf '%.0f' "$(compute)")
setBrightness ${BRIGHTNESS} ${NEXT}
}
case ${1} in
"up")
stepUp
;;
"down")
stepDown
;;
"device")
echo ${BRIGHTNESS_DEV}
;;
"path")
echo ${BRIGHTNESS_PATH}
;;
"set")
NEXT=${2}
setBrightness "$(printf '%.0f' "$(compute)")" ${2}
;;
*)
echo $(getBrightness)
;;
esac