/* TODO 1. Find and replace "day1" with your package name for **ALL FILES IN REPOSITORY** 2. Add a flake description that describes the workspace on line 27 3. Add a package description on line 70 4. (optional) uncomment `nativeBuildInputs` and `buildInputs` on lines 43 and 44 if you need openssl 5. (optional) set your project homepage, license, and maintainers list on lines 48-51 6. (optional) uncomment the NixOS module and update it for your needs 7. Delete this comment block */ /* Some utility commands: - `nix flake update --commit-lock-file` - `nix flake lock update-input ` - `nix build .#day1` or `nix build .` - `nix run .#day1` or `nix run .` */ { description = ""; inputs = { nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable"; rust-overlay.url = "github:oxalica/rust-overlay"; }; outputs = { self, nixpkgs, rust-overlay }: let overlays = [ (import rust-overlay) ]; system = "x86_64-linux"; pkgs = import nixpkgs { inherit system overlays; }; rustSettings = with pkgs; { src = ./.; #nativeBuildInputs = [ pkg-config ]; #buildInputs = [ openssl ]; cargoHash = nixpkgs.lib.fakeHash; }; meta = with nixpkgs.lib; { #homepage = "https://example.com"; #license = [ licenses.gpl3 ]; platforms = [ system ]; #maintainers = with maintainers; [ ]; }; in { devShells.${system}.default = with pkgs; mkShell { packages = [ (pkgs.rust-bin.stable.latest.default.override { extensions = [ "rust-src" ]; }) cargo-edit bacon ]; inputsFrom = with self.packages.${system}; [ day1 ]; }; packages.${system} = { default = self.packages.${system}.day1; day1 = pkgs.rustPlatform.buildRustPackage (rustSettings // { pname = "day1"; version = "0.1.0"; buildAndTestSubdir = "day1"; cargoHash = "sha256-+TaGIiKf+Pz2bTABeG8aCZz0/ZTCKl5398+qbas4Nvo="; meta = meta // { description = "Advent of code solution: day 1"; }; }); }; /* nixosModules.default = { config, ... }: let lib = nixpkgs.lib; in { options.services.day1 = { enable = lib.mkEnableOption (lib.mdDoc "day1 service"); package = lib.mkOption { type = lib.types.package; default = self.packages.${system}.day1; defaultText = "pkgs.day1"; description = lib.mdDoc '' The day1 package that should be used. ''; }; port = lib.mkOption { type = lib.types.port; default = 8000; description = lib.mdDoc '' The port at which to run. ''; }; }; config.systemd.services.day1 = let cfg = config.services.day1; pkg = self.packages.${system}.day1; in lib.mkIf cfg.enable { description = pkg.meta.description; after = [ "network.target" ]; wantedBy = [ "network.target" ]; serviceConfig = { ExecStart = '' ${cfg.package}/bin/day1 --port ${builtins.toString cfg.port} ''; Restart = "always"; DynamicUser = true; }; }; }; */ }; }