From 412c6636482774dfa4494be8551e4cee7b1a8232 Mon Sep 17 00:00:00 2001 From: Gabriel Arazas Date: Fri, 12 Jul 2024 13:02:40 +0800 Subject: [PATCH] wrapper-manager/programs/zellij: init --- modules/wrapper-manager/default.nix | 1 + modules/wrapper-manager/programs/zellij.nix | 32 +++++++++++++++++++++ 2 files changed, 33 insertions(+) create mode 100644 modules/wrapper-manager/programs/zellij.nix diff --git a/modules/wrapper-manager/default.nix b/modules/wrapper-manager/default.nix index 6a7c6f8c..f82f3c02 100644 --- a/modules/wrapper-manager/default.nix +++ b/modules/wrapper-manager/default.nix @@ -1,5 +1,6 @@ { imports = [ ./programs/blender.nix + ./programs/zellij.nix ]; } diff --git a/modules/wrapper-manager/programs/zellij.nix b/modules/wrapper-manager/programs/zellij.nix new file mode 100644 index 00000000..d24ce9c6 --- /dev/null +++ b/modules/wrapper-manager/programs/zellij.nix @@ -0,0 +1,32 @@ +{ lib, pkgs, config, ... }: + +let + cfg = config.programs.zellij; +in +{ + options.programs.zellij = { + enable = lib.mkEnableOption "Zellij, a terminal multiplexer"; + + package = lib.mkPackageOption pkgs "zellij" { }; + + configFile = lib.mkOption { + type = lib.types.path; + description = '' + The configuration file of the Zellij wrapper to be used. This module + will use the environment variable `ZELLIJ_CONFIG_FILE` which would + still allow overriding of the user's own if they choose to. + ''; + example = lib.literalExpression '' + ./config/zellij/config.kdl + ''; + }; + }; + + config = lib.mkIf cfg.enable { + basePackages = [ cfg.package ]; + wrappers.zellij = { + arg0 = lib.getExe' cfg.package "zellij"; + env.ZELLIJ_CONFIG_FILE = cfg.configFile; + }; + }; +}