-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathflake.nix
84 lines (77 loc) · 2.79 KB
/
flake.nix
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
{
description = "typesafe (generics) helpers for better golang tests";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs";
flake-utils.url = "github:numtide/flake-utils";
flake-compat.url = "github:edolstra/flake-compat";
flake-compat.flake = false;
};
outputs = { self, ... }@inputs:
inputs.flake-utils.lib.eachDefaultSystem (system:
let
# standard nix definitions
overlays = [ ];
pkgs = import inputs.nixpkgs {
inherit system overlays;
};
lib = pkgs.lib;
# localias specific
version = (builtins.readFile ./VERSION);
in
rec {
packages = rec { };
apps = rec { };
devShells = rec {
default = pkgs.mkShell {
packages = with pkgs;
[
# golang
delve
go-outline
go
golangci-lint
gopkgs
gopls
gotools
gotests
gomodifytags
impl
# nix
nixpkgs-fmt
nil
# xcode: this wrapper symlinks to the host system.
# other tools
just
];
shellHook = ''
# The path to this repository
shell_nix="''${IN_LORRI_SHELL:-$(pwd)/shell.nix}"
workspace_root=$(dirname "$shell_nix")
export WORKSPACE_ROOT="$workspace_root"
# We put the $GOPATH/$GOCACHE/$GOENV in $TOOLCHAIN_ROOT,
# and ensure that the GOPATH's bin dir is on our PATH so tools
# can be installed with `go install`.
#
# Any tools installed explicitly with `go install` will take precedence
# over versions installed by Nix due to the ordering here.
export TOOLCHAIN_ROOT="$workspace_root/.toolchain"
export GOROOT=
export GOCACHE="$TOOLCHAIN_ROOT/go/cache"
export GOENV="$TOOLCHAIN_ROOT/go/env"
export GOPATH="$TOOLCHAIN_ROOT/go/path"
export GOMODCACHE="$GOPATH/pkg/mod"
export PATH=$(go env GOPATH)/bin:$PATH
export CGO_ENABLED=1
# Make it easy to test while developing; add the golang and nix
# build outputs to the path.
export PATH="$workspace_root/bin:$workspace_root/result/bin:$PATH"
'';
# Need to disable fortify hardening because GCC is not built with -oO,
# which means that if CGO_ENABLED=1 (which it is by default) then the golang
# debugger fails.
# see https://github.com/NixOS/nixpkgs/pull/12895/files
hardeningDisable = [ "fortify" ];
};
};
});
}