Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

actkbd module: introduce services.actkbd.brightnessControl option #58609

Closed
wants to merge 2 commits into from
Closed

actkbd module: introduce services.actkbd.brightnessControl option #58609

wants to merge 2 commits into from

Conversation

ghost
Copy link

@ghost ghost commented Mar 31, 2019

Motivation for this change

As discussed in #57602

@primeos Please give it a try

Things done
  • Tested using sandboxing (nix.useSandbox on NixOS, or option sandbox in nix.conf on non-NixOS)
  • Built on platform(s)
    • NixOS
    • macOS
    • other Linux distributions
  • Tested via one or more NixOS test(s) if existing and applicable for the change (look inside nixos/tests)
  • Tested compilation of all pkgs that depend on this change using nix-shell -p nix-review --run "nix-review wip"
  • Tested execution of all binary files (usually in ./result/bin/)
  • Determined the impact on package closure size (by running nix path-info -S before and after)
  • Assured whether relevant documentation is up to date
  • Fits CONTRIBUTING.md.

@ghost ghost requested a review from infinisil as a code owner March 31, 2019 06:27
@GrahamcOfBorg GrahamcOfBorg added 6.topic: nixos Issues or PRs affecting NixOS modules, or package usability issues specific to NixOS 8.has: module (update) This PR changes an existing module in `nixos/` 10.rebuild-darwin: 0 This PR does not cause any packages to rebuild on Darwin 10.rebuild-linux: 1-10 labels Mar 31, 2019
@primeos
Copy link
Member

primeos commented Apr 8, 2019

Hey, sorry for the late response :o
Unfortunately I cannot test this on my main laptop atm, but I did test brightness.sh with debug output:

$ ./brightness.sh + 10
bl_dev: /sys/class/backlight/intel_backlight
current: 7500
max: 7500
level: 750
next_level: 7500
$ ./brightness.sh - 200
bl_dev: /sys/class/backlight/intel_backlight
current: 7500
max: 7500
level: 15000
next_level: 1
$ ./brightness.sh - 50
bl_dev: /sys/class/backlight/intel_backlight
current: 7500
max: 7500
level: 3750
next_level: 3750
$ ./brightness.sh - 50
bl_dev: /sys/class/backlight/intel_backlight
current: 3750
max: 7500
level: 3750
next_level: 1

And it does work as expected :)

To make the script more robust I would also recommend to add something like the following (especially nounset might be useful):

set -o errexit
set -o nounset

Without nounset:

$ ./brightness.sh - a
bl_dev: /sys/class/backlight/intel_backlight
current: 3750
max: 7500
level: 0
next_level: 3750
$ ./brightness.sh - $
./brightness.sh: line 9: 7500 * $ / 100: syntax error: operand expected (error token is "$ / 100")
./brightness.sh: line 10: 3750 - : syntax error: operand expected (error token is "- ")
./brightness.sh: line 11: [: -gt: unary operator expected
./brightness.sh: line 13: [: -lt: unary operator expected
bl_dev: /sys/class/backlight/intel_backlight
current: 3750
max: 7500
level: 
next_level: 

With nounset:

$ ./brightness.sh - a
./brightness.sh: line 9: a: unbound variable
$ ./brightness.sh - $
./brightness.sh: line 9: 7500 * $ / 100: syntax error: operand expected (error token is "$ / 100")
./brightness.sh: line 10: level: unbound variable

brightness.sh:

#!/usr/bin/env bash

set -o errexit
set -o nounset

bl_dev=`echo /sys/class/backlight/*`
current=$(< $bl_dev/brightness)
max=$(< $bl_dev/max_brightness)
level=$(($max * $2 / 100))
next_level=$(($current $1 $level))
if [ $next_level -gt $max ]; then
  next_level=$max
elif [ $next_level -lt 1 ]; then
  next_level=1
fi
#echo $next_level > $bl_dev/brightness

echo "bl_dev: $bl_dev"
echo "current: $current"
echo "max: $max"
echo "level: $level"
echo "next_level: $next_level"

Copy link
Member

@primeos primeos left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good otherwise :)
(I did not test the actkbd part though.)

nixos/modules/services/hardware/actkbd.nix Show resolved Hide resolved
nixos/modules/services/hardware/actkbd.nix Outdated Show resolved Hide resolved
@ghost
Copy link
Author

ghost commented Apr 9, 2019

@primeos Thank you much! I've applied your recommendations.

@primeos
Copy link
Member

primeos commented Apr 9, 2019

cc @oxij (as the author of the actkbd module) in case you have time to review this

@oxij
Copy link
Member

oxij commented Apr 15, 2019 via email

@ghost
Copy link
Author

ghost commented Apr 16, 2019

@oxij Thank you!

  • brightness.sh needs some more hacking, e.g. on my laptop ls /sys/class/backlight gives several results (it gives both acpi backlight and intel backlight controls), I think that script will do something bad in such a situation. I would consider using some lightweight tool for that instead. E.g. I use pkgs.light.
    Which brings me to programs.light option. I would just add the new options to that module instead and keep actkbd as module as it is.

Makes sense. I will make a new PR with changes to programs.light then.

@ghost ghost closed this Apr 16, 2019
@ghost ghost deleted the actkbd branch April 16, 2019 17:03
@ghost ghost mentioned this pull request Apr 16, 2019
10 tasks
This pull request was closed.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
6.topic: nixos Issues or PRs affecting NixOS modules, or package usability issues specific to NixOS 8.has: module (update) This PR changes an existing module in `nixos/` 10.rebuild-darwin: 0 This PR does not cause any packages to rebuild on Darwin 10.rebuild-linux: 1-10
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants