|
3 | 3 |
|
4 | 4 | inputs = { |
5 | 5 | flake-utils.url = "github:numtide/flake-utils"; |
6 | | - nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable-small"; |
| 6 | + # Last working commit from nixos-small-unstable |
| 7 | + nixpkgs.url = "github:NixOS/nixpkgs?rev=75e28c029ef2605f9841e0baa335d70065fe7ae2"; |
7 | 8 |
|
8 | 9 | treefmt-nix.url = "github:numtide/treefmt-nix"; |
9 | 10 | treefmt-nix.inputs.nixpkgs.follows = "nixpkgs"; |
|
17 | 18 | }; |
18 | 19 |
|
19 | 20 | outputs = |
20 | | - { self |
21 | | - , nixpkgs |
22 | | - , flake-utils |
23 | | - , nix-github-actions |
24 | | - , treefmt-nix |
25 | | - , systems |
26 | | - , |
| 21 | + { |
| 22 | + self, |
| 23 | + nixpkgs, |
| 24 | + flake-utils, |
| 25 | + nix-github-actions, |
| 26 | + treefmt-nix, |
| 27 | + systems, |
27 | 28 | }: |
28 | 29 | let |
29 | 30 | eachSystem = f: nixpkgs.lib.genAttrs (import systems) (system: f nixpkgs.legacyPackages.${system}); |
|
35 | 36 |
|
36 | 37 | githubActions = |
37 | 38 | let |
38 | | - mkPkgs = system: |
| 39 | + mkPkgs = |
| 40 | + system: |
39 | 41 | import nixpkgs { |
40 | 42 | config = { |
41 | 43 | allowAliases = false; |
|
69 | 71 | in |
70 | 72 | { |
71 | 73 | # Aggregate all tests into one derivation so that only one GHA runner is scheduled for all darwin jobs |
72 | | - aggregate = pkgs.runCommand "darwin-aggregate" |
73 | | - { |
74 | | - env.TEST_INPUTS = lib.concatStringsSep " " (lib.attrValues (lib.filterAttrs (_: v: lib.isDerivation v) tests)); |
75 | | - } "touch $out"; |
| 74 | + aggregate = pkgs.runCommand "darwin-aggregate" { |
| 75 | + env.TEST_INPUTS = lib.concatStringsSep " " ( |
| 76 | + lib.attrValues (lib.filterAttrs (_: v: lib.isDerivation v) tests) |
| 77 | + ); |
| 78 | + } "touch $out"; |
76 | 79 | }; |
77 | 80 | aarch64-darwin = |
78 | 81 | let |
|
82 | 85 | in |
83 | 86 | { |
84 | 87 | # Aggregate all tests into one derivation so that only one GHA runner is scheduled for all darwin jobs |
85 | | - aggregate = |
86 | | - pkgs.runCommand "darwin-aggregate" |
87 | | - { |
88 | | - env.TEST_INPUTS = lib.concatStringsSep " " (lib.attrValues (lib.filterAttrs (_: v: lib.isDerivation v) tests)); |
89 | | - } "touch $out"; |
| 88 | + aggregate = pkgs.runCommand "darwin-aggregate" { |
| 89 | + env.TEST_INPUTS = lib.concatStringsSep " " ( |
| 90 | + lib.attrValues (lib.filterAttrs (_: v: lib.isDerivation v) tests) |
| 91 | + ); |
| 92 | + } "touch $out"; |
90 | 93 | }; |
91 | 94 | }; |
92 | 95 | }; |
|
99 | 102 | default = self.templates.app; |
100 | 103 | }; |
101 | 104 | } |
102 | | - // (flake-utils.lib.eachDefaultSystem (system: |
103 | | - let |
104 | | - pkgs = import nixpkgs { |
105 | | - inherit system; |
106 | | - config.allowAliases = false; |
107 | | - }; |
| 105 | + // (flake-utils.lib.eachDefaultSystem ( |
| 106 | + system: |
| 107 | + let |
| 108 | + pkgs = import nixpkgs { |
| 109 | + inherit system; |
| 110 | + config.allowAliases = false; |
| 111 | + }; |
108 | 112 |
|
109 | | - poetry2nix = import ./default.nix { inherit pkgs; }; |
110 | | - p2nix-tools = pkgs.callPackage ./tools { inherit poetry2nix; }; |
111 | | - in |
112 | | - rec { |
113 | | - formatter = treefmtEval.${system}.config.build.wrapper; |
| 113 | + poetry2nix = import ./default.nix { inherit pkgs; }; |
| 114 | + p2nix-tools = pkgs.callPackage ./tools { inherit poetry2nix; }; |
| 115 | + in |
| 116 | + rec { |
| 117 | + formatter = treefmtEval.${system}.config.build.wrapper; |
114 | 118 |
|
115 | | - packages = { |
116 | | - poetry2nix = poetry2nix.cli; |
117 | | - default = poetry2nix.cli; |
118 | | - }; |
| 119 | + packages = { |
| 120 | + poetry2nix = poetry2nix.cli; |
| 121 | + default = poetry2nix.cli; |
| 122 | + }; |
119 | 123 |
|
120 | | - devShells = { |
121 | | - default = pkgs.mkShell { |
122 | | - nativeBuildInputs = with pkgs; [ |
123 | | - p2nix-tools.env |
124 | | - p2nix-tools.flamegraph |
125 | | - nixpkgs-fmt |
126 | | - poetry |
127 | | - niv |
128 | | - jq |
129 | | - nix-prefetch-git |
130 | | - nix-eval-jobs |
131 | | - nix-build-uncached |
132 | | - ]; |
| 124 | + devShells = { |
| 125 | + default = pkgs.mkShell { |
| 126 | + nativeBuildInputs = with pkgs; [ |
| 127 | + p2nix-tools.env |
| 128 | + p2nix-tools.flamegraph |
| 129 | + nixpkgs-fmt |
| 130 | + poetry |
| 131 | + niv |
| 132 | + jq |
| 133 | + nix-prefetch-git |
| 134 | + nix-eval-jobs |
| 135 | + nix-build-uncached |
| 136 | + ]; |
| 137 | + }; |
133 | 138 | }; |
134 | | - }; |
135 | 139 |
|
136 | | - apps = { |
137 | | - poetry = { |
138 | | - # https://wiki.nixos.org/wiki/Flakes |
139 | | - type = "app"; |
140 | | - program = "${pkgs.poetry}/bin/poetry"; |
| 140 | + apps = { |
| 141 | + poetry = { |
| 142 | + # https://wiki.nixos.org/wiki/Flakes |
| 143 | + type = "app"; |
| 144 | + program = "${pkgs.poetry}/bin/poetry"; |
| 145 | + }; |
| 146 | + poetry2nix = flake-utils.lib.mkApp { drv = packages.poetry2nix; }; |
| 147 | + default = apps.poetry2nix; |
141 | 148 | }; |
142 | | - poetry2nix = flake-utils.lib.mkApp { drv = packages.poetry2nix; }; |
143 | | - default = apps.poetry2nix; |
144 | | - }; |
145 | | - })); |
| 149 | + } |
| 150 | + )); |
146 | 151 | } |
0 commit comments