1
0
Fork 0
mirror of https://github.com/LnL7/nix-darwin.git synced 2024-12-14 11:57:34 +00:00

Merge pull request #73 from peel/master

adds skhd module
This commit is contained in:
Daiderd Jordan 2018-03-05 21:10:36 +01:00 committed by GitHub
commit 005ccb6987
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 48 additions and 0 deletions

View file

@ -56,6 +56,7 @@ let
./modules/services/ofborg
./modules/services/postgresql
./modules/services/redis
./modules/services/skhd
./modules/programs/bash
./modules/programs/fish.nix
./modules/programs/man.nix

View file

@ -0,0 +1,47 @@
{ config, lib, pkgs, ... }:
with lib;
let
cfg = config.services.skhd;
in {
options = {
services.skhd.enable = mkOption {
type = types.bool;
default = false;
description = "Whether to enable the skhd hotkey daemon.";
};
services.skhd.package = mkOption {
type = types.package;
example = literalExample "pkgs.skhd";
description = "This option specifies the skhd package to use.";
};
services.skhd.skhdConfig = mkOption {
type = types.lines;
default = "";
example = "alt + shift - r : chunkc quit";
description = "Config to use for <filename>skhdrc</filename>.";
};
};
config = mkIf cfg.enable {
environment.etc."skhdrc".text = cfg.skhdConfig;
launchd.user.agents.skhd = {
path = [ cfg.package config.environment.systemPath ];
serviceConfig.ProgramArguments = [ "${cfg.package}/bin/skhd" ]
++ optionals (cfg.skhdConfig != "") [ "-c" "/etc/skhdrc" ];
serviceConfig.KeepAlive = true;
serviceConfig.ProcessType = "Interactive";
serviceConfig.StandardOutPath = "/tmp/skhd.out";
serviceConfig.StandardErrorPath = "/tmp/skhd.err";
};
};
}