{ inputs = { nixpkgs.url = "github:nixos/nixpkgs/nixpkgs-unstable"; fenix = { url = "github:nix-community/fenix"; inputs.nixpkgs.follows = "nixpkgs"; }; }; outputs = { self , nixpkgs , fenix }: let supportedSystems = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; forAllSystems = nixpkgs.lib.genAttrs supportedSystems; nixpkgsFor = forAllSystems (system: import nixpkgs { inherit system; overlays = [ self.overlay ]; }); chanspec = { date = "2021-12-01"; channel = "nightly"; sha256 = "DhIP1w63/hMbWlgElJGBumEK/ExFWCdLaeBV5F8uWHc="; # set zeros after modifying channel or date }; rustChannel = p: (fenix.overlay p p).fenix.toolchainOf chanspec; in { overlay = final: prev: { prompt = with final; let pname = "prompt"; packageMeta = (lib.importTOML ./Cargo.toml).package; rustPlatform = makeRustPlatform { inherit (rustChannel final) cargo rustc; }; in rustPlatform.buildRustPackage { inherit pname; inherit (packageMeta) version; nativeBuildInputs = [ pkgconfig ]; buildInputs = [ openssl ] ++ pkgs.lib.optionals pkgs.stdenv.isDarwin [ darwin.apple_sdk.frameworks.Security darwin.apple_sdk.frameworks.CoreServices darwin.libiconv ]; doCheck = false; src = self; cargoLock.lockFile = ./Cargo.lock; }; }; packages = forAllSystems (system: { inherit (nixpkgsFor."${system}") prompt; }); defaultPackage = forAllSystems (system: self.packages."${system}".prompt); devShell = forAllSystems (system: let pkgs = nixpkgsFor."${system}"; toolchain = (rustChannel pkgs).withComponents [ "rustc" "cargo" "rust-std" "rustfmt" "clippy" "rust-src" ]; inherit (fenix.packages."${system}") rust-analyzer; in pkgs.mkShell { nativeBuildInputs = [ pkgs.pkgconfig pkgs.openssl pkgs.bacon rust-analyzer toolchain ]; RUST_LOG = "info"; RUST_BACKTRACE = 1; }); }; }