aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xgammatrip.sh124
1 files changed, 103 insertions, 21 deletions
diff --git a/gammatrip.sh b/gammatrip.sh
index 2b81a09..ef17f54 100755
--- a/gammatrip.sh
+++ b/gammatrip.sh
@@ -1,61 +1,143 @@
#!/bin/bash
-# gammatrip.sh by B. Watson, licensed under the WTFPL.
+# gammatrip.sh by B. Watson <yalhcru@gmail.com>.
+# Licensed under the WTFPL. See http://www.wtfpl.net/txt/copying/ for details.
+# Developed on Slackware 14.2, should work on most modern Linux distros.
+
# Randomly change gamma in X, crude simulation of an acid trip.
-# It's also similar to the Atari 400/800/XL/XE "Atrract Mode"
+# It's also similar to the Atari 400/800/XL/XE "Attract Mode".
+# Runs until killed via ^C or closing its terminal window, at which time
+# it restores the original gamma setting, then exits.
+
+#### User-tweakable knobs. If you don't feel like editing the script,
+# just put them on the command line, in front of the command:
+# $ DELAY=0.5 MAX=150 MIN=0 gammatrip.sh
-#### user-tweakable knobs:
+# XRandR output to use. Leaving this blank means to use the
+# first output listed by the xrandr command. Usual values are
+# e.g. VGA-1 or DVI-1.
+OUTPUT=
-# seconds to sleep between gamma changes
+# Seconds to sleep between gamma changes. Decimal point allowed, so
+# long as your system's sleep command allows it.
DELAY=${DELAY:-3}
-# max gamma for each individual color. lower number here means darker
+# Max gamma for each individual color. Lower number here means darker
# colors on average. Units are 1/100ths of xrandr's --gamma floats,
# MAX=100 means 1.0. Maximum value for MAX is 999.
MAX=${MAX:-100}
-# minimum gamma for each color. don't set higher than MAX!
-# same units as MAX.
+# Minimum gamma for each color. Don't set higher than MAX!
+# Same units as MAX.
MIN=${MIN:-30}
-#### end of user-tweakable knobs.
+# VERBOSE=y to see the commands as they're executed, anything else
+# means don't display them.
+VERBOSE=y
+
+#### End of user-tweakable knobs.
+printmsg() {
+ [ "$VERBOSE" = "y" ] && echo "$@"
+}
+
+errmsg() {
+ echo "$SELF:" "$@" 1>&2
+}
+
+# Check knobs for sane(ish) settings, set up signal handlers,
+# guess the active XRandR output if not provided. Get original
+# gamma setting, so we can restore it later.
init() {
- trap cleanup SIGINT SIGABRT SIGHUP SIGTERM
+ SELF="$( basename $0 )"
+ err=0
+
+ if [ "$MAX" -ge 1000 ]; then
+ errmsg "You can't set MAX >= 1000"
+ err=1
+ fi
+
+ if [ "$MIN" -ge "$MAX" ]; then
+ errmsg "You can't set MIN >= MAX"
+ err=1
+ fi
+
+ if [ "$#" != "0" ]; then
+ errmsg "No arguments accepted."
+ errmsg "Edit script or set MIN/MAX/OUTPUT/DELAY/VERBOSE in environment."
+ err=1
+ fi
+
+ if [ -z "$DISPLAY" ]; then
+ errmsg "DISPLAY not set (are you running X?)"
+ err=1
+ fi
+
+ [ "$err" -gt 0 ] && exit "$err"
+
+ # SIGINT is ^C, SIGHUP is what we get when our xterm is closed.
+ # SIGABRT is ^\, I hardly ever remember it exists. Trapping it here
+ # doesn't work: ^\ sends the abort signal to the active child
+ # process (usually sleep). Oh well. The other signals are 'just in case'.
+ trap cleanup SIGINT SIGABRT SIGHUP SIGTERM SIGHUP
+
OUTPUT="${OUTPUT:-$( xrandr | grep ' connected' | cut -d' ' -f1 )}"
- echo "Using output '$OUTPUT'"
+
+ if [ -z "$OUTPUT" ]; then
+ errmsg "Invalid OUTPUT in environment, or XRandR not supported."
+ exit 1
+ fi
+
+ # Try to save the old gamma, for cleanup() to restore. Not thoroughly
+ # tested (works on my system).
+ OLDGAMMA="$( xrandr --verbose | sed -n '/^'$OUTPUT' /,/^[A-Z]/s/.*Gamma: *//p' )"
+
+ # If the above command fails:
+ OLDGAMMA="${OLDGAMMA:-1.0:1.0:1.0}"
+
+ printmsg "Using output '$OUTPUT', old gamma '$OLDGAMMA'. Have a nice trip!"
}
+# Called when we get a signal we trapped in init().
cleanup() {
- echo "Restoring default gamma"
- xrandr --output "$OUTPUT" --gamma "1.0:1.0:1.0"
+ echo
+ printmsg "Restoring old gamma"
+ xrandr --output "$OUTPUT" --gamma "$OLDGAMMA"
exit 0
}
+# Takes 2 agruments: min and max. Returns a random number between
+# min and max (actually >= min and < max).
getrand() {
- range=$(( MAX - MIN ))
- echo $(( ( RANDOM % range ) + MIN ))
+ min="$1"
+ max="$2"
+ range=$(( max - min ))
+ echo $(( ( RANDOM % range ) + min ))
}
+# Pick random RBG values between MIN and MAX, use them to set the gamma.
cycle() {
- r=0; g=0; b=0
- r="$( getrand )"
- g="$( getrand )"
- b="$( getrand )"
+ r="$( getrand $MIN $MAX )"
+ g="$( getrand $MIN $MAX )"
+ b="$( getrand $MIN $MAX )"
+
cmd="xrandr --output $OUTPUT --gamma "
+
for i in $r $g $b; do
cmd="$cmd$( printf "%03d" $i | sed 's,^.,&.,' ):"
done
- # remove trailing colon. actually, xrandr doesn't care about it,
+ # Remove trailing colon. Actually, xrandr doesn't care about it,
# but someday it might.
cmd="$( echo $cmd | sed 's,:$,,' )"
- echo $cmd
+ printmsg $cmd
$cmd
}
-init
+### main()
+init "$@"
+
while true; do
cycle
sleep "$DELAY"