Create a file in modules/<module>/
with the name of the port. All ports should have
the catppuccin.enable
and catppuccin.flavor
options, and optionally the
catppuccin.accent
option. catppuccin.flavor
and catppuccin.accent
should
default to config.catppuccin.flavor
and config.catppuccin.accent
, respectively.
When you're done, make sure to add your new file to the list in
modules/<module>/all-modules.nix
npins is used to track our upstream sources to use in modules. This allows us to easily access and auto-update all themes. You can add a new repository using a script in our subflake
nix run ./dev#add-source -- port_name branch_if_not_main
Alternatively, you can run npins add github --directory .sources
manually
After creating your module, add the options to enable it in test.nix
under the
nodes.machine
attrset. This will allow for your configuration to be tested along
with the other modules in a VM automatically.
Commits that add ports should be of the format
feat(<nixos or home-manager>): add support for <port>
Note Unofficial ports will not be accepted; all sources must be from the Catppuccin GitHub organization
This repository uses Conventional Commits. Commit headers should be lowercase. Most commits should include a body that briefly describes the motivation and content of the commit.
fix
: A bug fix that doesn't modify the public APIfeat
: A code change that modifies the public APIrefactor
: A code change that doesn't change behaviorstyle
: A style fix or changedocs
: Any change to documentationci
: Any change to CI filesrevert
: A revert commit. The message should describe the reasoning and the commit should include theRefs:
footer with the short hashes of the commits being reverted.chore
: catch-all type
Available commit scopes are port names, nixos
, home-manager
, modules
, and
tests
. If none of these apply, omit the scope.
All breaking changes should be documented in the commit footer in the format
described by Conventional Commits. Use the <type>!
syntax in order to distinguish
breaking commits in the log, but include the footer to provide a better description
for the changelog generator.
feat(bar)!: foo the bars
BREAKING CHANGE: bars are now foo'ed
Use squash merges when reasonable. They don't pollute the log with merge commits, and unlike rebase merges, list the author as the committer as well.