2024-05-21 14:53:46 -07:00
|
|
|
{
|
|
|
|
config,
|
|
|
|
lib,
|
|
|
|
pkgs,
|
|
|
|
...
|
2024-04-16 09:44:26 -07:00
|
|
|
}:
|
2023-07-13 09:17:51 -07:00
|
|
|
let
|
2024-05-13 13:33:16 -07:00
|
|
|
# this is a recursive attribute with all the functions below
|
|
|
|
inherit (lib) ctp;
|
|
|
|
in
|
|
|
|
{
|
2023-07-13 09:17:51 -07:00
|
|
|
# string -> type -> string -> a -> a
|
|
|
|
# this is an internal function and shouldn't be
|
|
|
|
# used unless you know what you're doing. it takes
|
2024-05-21 17:23:55 -07:00
|
|
|
# a string (the name of the property, i.e., flavor
|
2023-07-13 09:17:51 -07:00
|
|
|
# or accent), the type of the property, the name of
|
|
|
|
# the module, followed by local config attrset
|
2024-05-21 14:53:46 -07:00
|
|
|
mkBasicOpt =
|
|
|
|
attr: type: name:
|
2023-07-13 09:17:51 -07:00
|
|
|
lib.mkOption {
|
|
|
|
inherit type;
|
|
|
|
default = config.catppuccin.${attr};
|
|
|
|
description = "Catppuccin ${attr} for ${name}";
|
|
|
|
};
|
2023-04-17 09:44:07 -07:00
|
|
|
|
2023-07-13 09:17:51 -07:00
|
|
|
# string -> a -> a
|
2024-05-21 17:23:55 -07:00
|
|
|
# this creates a flavor option for modules
|
2023-07-13 09:17:51 -07:00
|
|
|
# the first string should be the name of the module,
|
|
|
|
# followed by the local config attrset
|
2024-05-27 23:49:04 -07:00
|
|
|
mkFlavorOpt = ctp.mkBasicOpt "flavor" ctp.types.flavorOption;
|
2023-04-17 09:44:07 -07:00
|
|
|
|
|
|
|
types = {
|
2024-05-21 17:23:55 -07:00
|
|
|
flavorOption = lib.types.enum [
|
2024-05-21 14:53:46 -07:00
|
|
|
"latte"
|
|
|
|
"frappe"
|
|
|
|
"macchiato"
|
|
|
|
"mocha"
|
|
|
|
];
|
2023-04-17 09:44:07 -07:00
|
|
|
accentOption = lib.types.enum [
|
|
|
|
"blue"
|
|
|
|
"flamingo"
|
|
|
|
"green"
|
|
|
|
"lavender"
|
|
|
|
"maroon"
|
|
|
|
"mauve"
|
|
|
|
"peach"
|
|
|
|
"pink"
|
|
|
|
"red"
|
|
|
|
"rosewater"
|
|
|
|
"sapphire"
|
|
|
|
"sky"
|
|
|
|
"teal"
|
|
|
|
"yellow"
|
|
|
|
];
|
|
|
|
};
|
|
|
|
|
2023-07-13 09:17:51 -07:00
|
|
|
# string -> string
|
|
|
|
# this capitalizes the first letter in a string,
|
|
|
|
# which is sometimes needed in order to format
|
|
|
|
# the names of themes correctly
|
2024-05-21 14:53:46 -07:00
|
|
|
mkUpper =
|
|
|
|
str:
|
2024-05-13 13:33:16 -07:00
|
|
|
(lib.toUpper (builtins.substring 0 1 str)) + (builtins.substring 1 (builtins.stringLength str) str);
|
2023-04-17 09:44:07 -07:00
|
|
|
|
2023-07-13 09:17:51 -07:00
|
|
|
# a -> path -> a
|
|
|
|
# fromJSON but for yaml (and without readFile)
|
|
|
|
# a should be the local pkgs attrset
|
2024-05-21 14:53:46 -07:00
|
|
|
fromYaml =
|
|
|
|
file:
|
2023-07-13 09:17:51 -07:00
|
|
|
let
|
|
|
|
# convert to json
|
2024-05-13 13:33:16 -07:00
|
|
|
json = pkgs.runCommand "converted.json" { } ''
|
|
|
|
${lib.getExe pkgs.yj} < ${file} > $out
|
|
|
|
'';
|
2023-07-13 09:17:51 -07:00
|
|
|
in
|
2024-05-13 13:33:16 -07:00
|
|
|
builtins.fromJSON (builtins.readFile json);
|
2023-07-13 09:17:51 -07:00
|
|
|
|
2023-11-02 08:55:47 -07:00
|
|
|
# a -> path -> a
|
|
|
|
# fromJSON but for ini (and without readFile)
|
|
|
|
# a should be the local pkgs attrset
|
2024-05-21 14:53:46 -07:00
|
|
|
fromINI =
|
|
|
|
file:
|
2023-11-02 08:55:47 -07:00
|
|
|
let
|
|
|
|
# convert to json
|
2024-05-13 13:33:16 -07:00
|
|
|
json = pkgs.runCommand "converted.json" { } ''
|
|
|
|
${lib.getExe pkgs.jc} --ini < ${file} > $out
|
|
|
|
'';
|
2023-11-02 08:55:47 -07:00
|
|
|
in
|
2024-05-13 13:33:16 -07:00
|
|
|
builtins.fromJSON (builtins.readFile json);
|
2023-11-02 08:55:47 -07:00
|
|
|
|
2024-04-16 09:44:26 -07:00
|
|
|
# a -> path -> a
|
|
|
|
# fromJSON but for raw ini (and without readFile)
|
|
|
|
# a should be the local pkgs attrset
|
2024-05-21 14:53:46 -07:00
|
|
|
fromINIRaw =
|
|
|
|
file:
|
2024-04-16 09:44:26 -07:00
|
|
|
let
|
|
|
|
inherit (builtins) fromJSON readFile;
|
|
|
|
|
|
|
|
# convert to json
|
2024-05-21 14:53:46 -07:00
|
|
|
json =
|
|
|
|
with pkgs;
|
2024-04-16 09:44:26 -07:00
|
|
|
runCommand "converted.json" { } ''
|
|
|
|
${jc}/bin/jc --ini -r < ${file} > $out
|
|
|
|
'';
|
|
|
|
in
|
|
|
|
fromJSON (readFile json);
|
|
|
|
|
2023-04-17 09:44:07 -07:00
|
|
|
# string -> a -> a
|
|
|
|
# this creates a basic attrset only containing an
|
2024-05-21 17:23:55 -07:00
|
|
|
# enable and flavor option. the fist string should
|
2023-04-17 09:44:07 -07:00
|
|
|
# be the name of the module, followed by the local config
|
|
|
|
# attrset
|
2023-11-02 10:55:47 -07:00
|
|
|
mkCatppuccinOpt = name: {
|
2024-04-22 10:39:12 -07:00
|
|
|
enable = lib.mkEnableOption "Catppuccin theme" // {
|
|
|
|
default = config.catppuccin.enable;
|
|
|
|
};
|
2024-05-27 23:49:04 -07:00
|
|
|
flavor = ctp.mkFlavorOpt name;
|
2023-04-17 09:44:07 -07:00
|
|
|
};
|
2023-07-13 09:17:51 -07:00
|
|
|
|
|
|
|
# string -> a -> a
|
|
|
|
# this creates an accent option for modules
|
|
|
|
# the first string should be the name of the module,
|
|
|
|
# followed by the local config attrset
|
2024-05-13 13:33:16 -07:00
|
|
|
mkAccentOpt = ctp.mkBasicOpt "accent" ctp.types.accentOption;
|
2023-11-03 10:25:24 -07:00
|
|
|
|
2024-05-13 13:33:16 -07:00
|
|
|
# a -> a -> a
|
2024-04-18 13:10:23 -07:00
|
|
|
# see https://nlewo.github.io/nixos-manual-sphinx/development/option-types.xml.html
|
|
|
|
# by default enums cannot be merged, but they keep their passed value in `functor.payload`.
|
|
|
|
# `functor.binOp` can merge those values
|
|
|
|
mergeEnums = a: b: lib.types.enum (a.functor.binOp a.functor.payload b.functor.payload);
|
2024-05-20 21:34:42 -07:00
|
|
|
|
|
|
|
# string
|
|
|
|
# returns the current release version of nixos or home-manager. throws an evaluation error if neither are
|
|
|
|
# found
|
2024-05-21 14:53:46 -07:00
|
|
|
getModuleRelease =
|
|
|
|
config.home.version.release or config.system.nixos.release
|
|
|
|
or (throw "Couldn't determine release version!");
|
2024-05-20 21:34:42 -07:00
|
|
|
|
|
|
|
# string -> a -> a
|
|
|
|
# if the current module release is less than `minVersion`, all options are made no-ops with
|
|
|
|
# `lib.mkSinkUndeclaredOptions`
|
2024-05-21 14:53:46 -07:00
|
|
|
mkVersionedOpts =
|
|
|
|
minVersion: option:
|
|
|
|
if lib.versionAtLeast ctp.getModuleRelease minVersion then
|
|
|
|
option
|
|
|
|
else
|
|
|
|
lib.mkSinkUndeclaredOptions { };
|
2024-06-04 04:29:28 -07:00
|
|
|
|
|
|
|
# string -> a
|
|
|
|
# this is to ensure users are running a supported version of nixos/home-manager
|
|
|
|
assertMinimumVersion = version: {
|
|
|
|
assertion = lib.versionAtLeast ctp.getModuleRelease version;
|
|
|
|
message = "`catppuccin/nix` requires at least version ${version} of NixOS/home-manager";
|
|
|
|
};
|
2023-04-17 09:44:07 -07:00
|
|
|
}
|