2022-09-10 05:08:51 +00:00
|
|
|
# Contributing a Device Profile
|
|
|
|
|
|
|
|
## 1. Writing profiles
|
|
|
|
|
|
|
|
Create an appropriate directory and start writing your expression.
|
2017-12-24 19:34:39 +00:00
|
|
|
|
2018-07-17 12:39:49 +00:00
|
|
|
When setting an option, use `lib.mkDefault` unless:
|
2022-09-10 05:08:51 +00:00
|
|
|
- The option *must* be set and the user should get an error if they try to
|
|
|
|
override it.
|
|
|
|
- The setting should merge with the user's settings (typical for list or set
|
|
|
|
options).
|
2018-07-17 12:39:49 +00:00
|
|
|
|
|
|
|
For example:
|
|
|
|
|
|
|
|
```nix
|
|
|
|
{ lib }: {
|
|
|
|
# Using mkDefault, because the user might want to disable tlp
|
|
|
|
services.tlp.enable = lib.mkDefault true;
|
|
|
|
# No need to use mkDefault, because the setting will merge with the user's setting
|
|
|
|
boot.kernelModules = [ "tmp_smapi" ];
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2022-09-10 05:08:51 +00:00
|
|
|
Where possible, use module imports to share code between similar hardware
|
|
|
|
variants. In most cases, import:
|
|
|
|
- a cpu module;
|
|
|
|
- a gpu module;
|
|
|
|
- either the pc or the laptop module;
|
|
|
|
- either the HDD or the SSD module.
|
|
|
|
|
|
|
|
Try to avoid "opinionated" settings relating to optional features like sound,
|
|
|
|
bluetooth, choice of bootloader etc. You can mention these in the readme.
|
2018-07-17 12:39:49 +00:00
|
|
|
|
2022-09-10 05:08:51 +00:00
|
|
|
Profiles should favor usability and stability, so performance improvements
|
|
|
|
should either be conservative or be guarded behind additional NixOS module
|
|
|
|
options. If it makes sense to have a performance-focussed config, it can be
|
|
|
|
declared in a separate profile.
|
2018-07-17 12:39:49 +00:00
|
|
|
|
2022-09-10 05:08:51 +00:00
|
|
|
## 2. Adding Entry
|
2018-07-17 12:39:49 +00:00
|
|
|
|
2022-09-10 05:08:51 +00:00
|
|
|
Link the profile in the table in README.md and in flake.nix.
|
2018-07-17 12:39:49 +00:00
|
|
|
|
2022-09-10 05:08:51 +00:00
|
|
|
## 3. Testing
|
2018-07-17 12:39:49 +00:00
|
|
|
|
2022-09-10 05:08:51 +00:00
|
|
|
Run ./tests/run.py to test building. The test script script will parse all the
|
|
|
|
profiles from the README.md.
|
2018-07-17 12:39:49 +00:00
|
|
|
|
2022-09-14 05:24:15 +00:00
|
|
|
You can also just specify a single profile like this:
|
|
|
|
|
|
|
|
```
|
|
|
|
./tests/run.py '<nixos-hardware/purism/librem/15v3>'
|
|
|
|
```
|
|
|
|
|
2022-09-10 05:08:51 +00:00
|
|
|
Because profiles can only be tested with the appropriate hardware, quality
|
|
|
|
assurance is up to *you*.
|
2022-10-01 12:51:04 +00:00
|
|
|
|
|
|
|
# For reviewers:
|
|
|
|
|
|
|
|
This repository has bors enabled for easier merging after a successfull build:
|
|
|
|
|
|
|
|
* `bors try` - check if the PR builds.
|
|
|
|
* `bors merge` - same as `bors try` but will also merge the PR if it builds successfully.
|
|
|
|
* https://bors.tech/documentation/
|