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;
|
2018-06-17 03:43:19 +03:00
|
|
|
device_config = config.mobile.device;
|
2018-06-18 03:50:17 +03:00
|
|
|
hardware_config = config.mobile.hardware;
|
2018-06-17 03:43:19 +03:00
|
|
|
stage-1 = config.mobile.boot.stage-1;
|
2018-06-17 02:21:41 +03:00
|
|
|
|
|
|
|
build_types = {
|
2018-06-18 02:57:03 +03:00
|
|
|
android-bootimg = pkgs.callPackage ../systems/bootimg.nix {
|
2018-06-17 03:43:19 +03:00
|
|
|
inherit device_config;
|
|
|
|
# XXX : this feels like a hack
|
2018-06-18 02:57:03 +03:00
|
|
|
initrd = pkgs.callPackage ../systems/initrd.nix { inherit device_config stage-1; };
|
2018-06-17 03:43:19 +03:00
|
|
|
};
|
2018-06-24 00:11:07 +03:00
|
|
|
kernel-initrd = pkgs.linkFarm "${device_config.name}-build" [
|
|
|
|
{
|
|
|
|
name = "kernel-initrd";
|
|
|
|
path = pkgs.callPackage ../systems/kernel-initrd.nix {
|
|
|
|
# FIXME this all feels a bit not enough generic.
|
|
|
|
inherit device_config hardware_config;
|
|
|
|
initrd = pkgs.callPackage ../systems/initrd.nix { inherit device_config stage-1; };
|
|
|
|
};
|
|
|
|
}
|
|
|
|
{
|
|
|
|
name = "system";
|
|
|
|
# Equivalent to:
|
|
|
|
# → nix-build nixos -I nixos-config=system-image.nix -A config.system.build.sdImage
|
|
|
|
path = ((import (pkgs.path + "/nixos")) { configuration = ../system-image.nix; }).config.system.build.sdImage;
|
|
|
|
}
|
|
|
|
];
|
2018-06-17 02:21:41 +03:00
|
|
|
};
|
|
|
|
in
|
|
|
|
{
|
|
|
|
options.mobile = {
|
|
|
|
system.type = mkOption {
|
2018-06-24 00:11:07 +03:00
|
|
|
type = types.enum (lib.attrNames build_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
|
|
|
|
# when implementing new platforms and not implementing them in build_types.
|
|
|
|
{ assertion = build_types ? system_type; message = "cannot build unexpected system type: ${system_type}.";}
|
|
|
|
];
|
|
|
|
system = {
|
2018-06-27 04:54:41 +03:00
|
|
|
build =
|
|
|
|
if failed == [] then
|
|
|
|
build_types."${system_type}"
|
|
|
|
else throw "\nFailed assertions:\n${concatStringsSep "\n" (map (x: " → ${x}") failed)}\n"
|
|
|
|
;
|
2018-06-17 02:21:41 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|