2018-06-17 02:21:41 +03:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
2018-06-27 04:54:41 +03:00
|
|
|
failed = map (x: x.message) (filter (x: !x.assertion) config.assertions);
|
|
|
|
|
2018-06-17 02:21:41 +03:00
|
|
|
system_type = config.mobile.system.type;
|
|
|
|
|
2019-09-22 05:40:24 +03:00
|
|
|
known_system_types = config.mobile.system.types;
|
2018-06-17 02:21:41 +03:00
|
|
|
in
|
|
|
|
{
|
2019-09-22 00:30:12 +03:00
|
|
|
imports = [
|
|
|
|
../systems/rootfs.nix
|
|
|
|
];
|
|
|
|
|
2018-06-17 02:21:41 +03:00
|
|
|
options.mobile = {
|
2019-09-22 05:40:24 +03:00
|
|
|
system.types = mkOption {
|
|
|
|
type = types.listOf types.str;
|
|
|
|
internal = true;
|
|
|
|
description = ''
|
|
|
|
Registry of system types.
|
|
|
|
'';
|
|
|
|
};
|
2018-06-17 02:21:41 +03:00
|
|
|
system.type = mkOption {
|
2019-09-22 05:40:24 +03:00
|
|
|
type = types.enum known_system_types;
|
2018-06-17 02:21:41 +03:00
|
|
|
description = ''
|
|
|
|
Defines the kind of system the device is.
|
|
|
|
|
|
|
|
The different kind of system types will define the outputs
|
|
|
|
produced for the system.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = {
|
|
|
|
assertions = [
|
|
|
|
# While the enum type is enough to implement value safety, this will help
|
2019-09-22 05:40:24 +03:00
|
|
|
# when implementing new platforms and not implementing them in known_system_types.
|
|
|
|
{
|
|
|
|
assertion = lib.lists.any (x: x == system_type) known_system_types;
|
|
|
|
message = "Cannot build unexpected system type: ${system_type}.\n Known types: ${lib.concatStringsSep ", " known_system_types}";
|
|
|
|
}
|
2018-06-17 02:21:41 +03:00
|
|
|
];
|
|
|
|
};
|
|
|
|
}
|