1
0
mirror of https://github.com/samueldr/wip-pinebook-pro.git synced 2024-06-13 16:23:41 +02:00
wip-pinebook-pro/flake.nix
2020-08-24 00:35:14 -04:00

63 lines
2.1 KiB
Nix

{
description = "WIP stuff to get started on the pinebook pro.";
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs-channels/nixos-unstable";
flake-utils.url = "github:numtide/flake-utils";
};
outputs = { self, nixpkgs, flake-utils }:
{
overlay = final: prev: import "${self}/overlay.nix" final prev;
} // flake-utils.lib.eachDefaultSystem (
system:
let
inherit (nixpkgs) lib;
darwin_network_cmds_openssl_overlay = final: prev: {
darwin = prev.darwin // {
network_cmds = prev.darwin.network_cmds.override { openssl_1_0_2 = prev.openssl; };
};
};
pkgsNative = import nixpkgs {
inherit system;
config.allowUnfree = true;
overlays = [ darwin_network_cmds_openssl_overlay self.overlay ];
};
pkgs = if system == "aarch64-linux" then pkgsNative else pkgsNative.pkgsCross.aarch64-multiplatform;
in
rec {
packages = rec {
inherit (pkgs)
uBootPinebookPro uBootPinebookProExternalFirst
linux_pinebookpro_latest
linux_pinebookpro_lts
pinebookpro-firmware
pinebookpro-keyboard-updater
;
inherit (nixosConfigurations.config.system.build) sdImage;
};
defaultPackage = packages.sdImage;
nixosConfigurations = lib.nixosSystem {
system = "aarch64-linux";
# Pass nixpkgs as an argument to each module so that modules from nixpkgs can be imported purely
specialArgs = { inherit nixpkgs; };
modules = [
{ nixpkgs.config.allowUnfree = true; }
"${self}/configuration.nix"
(
lib.optionalAttrs (system != "aarch64-linux") {
imports = [ "${self}/cross-hacks.nix" ];
nixpkgs.crossSystem.system = "aarch64-linux";
}
)
];
};
nixosModule = import "${self}/pinebook_pro.nix";
}
);
}