blob: 94b8099d29c9e2575a4ac519fe494ece76eec121 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
|
{
inputs = {
nixpkgs.url = "nixpkgs/nixpkgs-unstable";
parts = {
url = "github:hercules-ci/flake-parts";
inputs.nixpkgs-lib.follows = "nixpkgs";
};
treefmt-nix = {
url = "github:numtide/treefmt-nix";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs =
{ parts, treefmt-nix, ... }@inputs:
parts.lib.mkFlake { inherit inputs; } {
systems = [
"x86_64-linux"
"aarch64-linux"
"x86_64-darwin"
"aarch64-darwin"
];
imports = [ treefmt-nix.flakeModule ];
perSystem =
{ self', pkgs, ... }:
{
devShells = {
default = pkgs.mkShellNoCC {
packages = with pkgs; [
# node
nodejs_20
corepack_20
wrangler
nrr
typescript-language-server
vscode-langservers-extracted # for eslint server
# github actions
actionlint
# nix
self'.formatter
nil
statix
];
env = {
# https://github.com/NixOS/nixpkgs/pull/330808
SSL_CERT_FILE = "${pkgs.cacert}/etc/ssl/certs/ca-bundle.crt";
};
};
ci = pkgs.mkShellNoCC {
shellHook = ''
corepack install
'';
packages = with pkgs; [
nodejs_20
corepack_20
nrr
self'.formatter
];
};
};
treefmt = {
projectRootFile = ".git/config";
programs = {
actionlint.enable = true;
deadnix.enable = true;
nixfmt.enable = true;
prettier.enable = true;
statix.enable = true;
};
};
};
};
}
|