From 2084e19a0c267409ba41f4ba8b856dc653b5edcc Mon Sep 17 00:00:00 2001 From: rok Date: Wed, 22 May 2024 16:41:31 +0900 Subject: [PATCH 1/4] CI configs: add nix flake --- flake.lock | 82 ++++++++++++++++++++++++++++++++++++++++++++++++++ flake.nix | 66 ++++++++++++++++++++++++++++++++++++++++ gomod2nix.toml | 27 +++++++++++++++++ 3 files changed, 175 insertions(+) create mode 100644 flake.lock create mode 100644 flake.nix create mode 100644 gomod2nix.toml diff --git a/flake.lock b/flake.lock new file mode 100644 index 000000000..75fb935e9 --- /dev/null +++ b/flake.lock @@ -0,0 +1,82 @@ +{ + "nodes": { + "flake-utils": { + "inputs": { + "systems": "systems" + }, + "locked": { + "lastModified": 1694529238, + "narHash": "sha256-zsNZZGTGnMOf9YpHKJqMSsa0dXbfmxeoJ7xHlrt+xmY=", + "owner": "numtide", + "repo": "flake-utils", + "rev": "ff7b65b44d01cf9ba6a71320833626af21126384", + "type": "github" + }, + "original": { + "owner": "numtide", + "repo": "flake-utils", + "type": "github" + } + }, + "gomod2nix": { + "inputs": { + "flake-utils": "flake-utils", + "nixpkgs": [ + "nixpkgs" + ] + }, + "locked": { + "lastModified": 1716202913, + "narHash": "sha256-zjPNXI4DWBOrPsrK8u/XTsm5Q36quONQvz0jhAKHEeg=", + "owner": "nix-community", + "repo": "gomod2nix", + "rev": "4702caff8e201f4c98fe3583637a930d253447c8", + "type": "github" + }, + "original": { + "owner": "nix-community", + "repo": "gomod2nix", + "type": "github" + } + }, + "nixpkgs": { + "locked": { + "lastModified": 1716218643, + "narHash": "sha256-i/E7gzQybvcGAYDRGDl39WL6yVk30Je/NXypBz6/nmM=", + "owner": "NixOS", + "repo": "nixpkgs", + "rev": "a8695cbd09a7ecf3376bd62c798b9864d20f86ee", + "type": "github" + }, + "original": { + "owner": "NixOS", + "ref": "nixos-23.11", + "repo": "nixpkgs", + "type": "github" + } + }, + "root": { + "inputs": { + "gomod2nix": "gomod2nix", + "nixpkgs": "nixpkgs" + } + }, + "systems": { + "locked": { + "lastModified": 1681028828, + "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", + "owner": "nix-systems", + "repo": "default", + "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", + "type": "github" + }, + "original": { + "owner": "nix-systems", + "repo": "default", + "type": "github" + } + } + }, + "root": "root", + "version": 7 +} diff --git a/flake.nix b/flake.nix new file mode 100644 index 000000000..09ab30259 --- /dev/null +++ b/flake.nix @@ -0,0 +1,66 @@ +{ + description = "elvish"; + + inputs = { + nixpkgs.url = "github:NixOS/nixpkgs/nixos-23.11"; + gomod2nix = { + url = "github:nix-community/gomod2nix"; + inputs.nixpkgs.follows = "nixpkgs"; + }; + }; + + outputs = { self, nixpkgs, gomod2nix }: + let + allSystems = [ + "x86_64-linux" # 64-bit Intel/AMD Linux + "aarch64-linux" # 64-bit ARM Linux + "x86_64-darwin" # 64-bit Intel macOS + "aarch64-darwin" # 64-bit ARM macOS + ]; + forAllSystems = f: nixpkgs.lib.genAttrs allSystems (system: f { + inherit system; + pkgs = import nixpkgs { inherit system; }; + }); + in + { + packages = forAllSystems ({ system, pkgs, ... }: + let + buildGoApplication = gomod2nix.legacyPackages.${system}.buildGoApplication; + in + rec { + default = elvish; + + elvish = buildGoApplication { + name = "elvish"; + src = ./.; + go = pkgs.go_1_21; + pwd = ./.; + subPackages = [ "cmd/elvish" ]; + CGO_ENABLED = 0; + flags = [ + "-trimpath" + ]; + ldflags = [ + "-s" + "-w" + "-extldflags -static" + ]; + }; + }); + + # `nix develop` provides a shell containing development tools. + devShell = forAllSystems ({ system, pkgs }: + pkgs.mkShell { + buildInputs = with pkgs; [ + go_1_21 + gomod2nix.legacyPackages.${system}.gomod2nix + gopls + ]; + }); + + overlays.default = final: prev: { + elvish = self.packages.${final.stdenv.system}.elvish; + }; + }; +} + diff --git a/gomod2nix.toml b/gomod2nix.toml new file mode 100644 index 000000000..3209e340c --- /dev/null +++ b/gomod2nix.toml @@ -0,0 +1,27 @@ +schema = 3 + +[mod] + [mod."github.com/creack/pty"] + version = "v1.1.21" + hash = "sha256-pjGw6wQlrVhN65XaIxZueNJqnXThGu00u24rKOLzxS0=" + [mod."github.com/google/go-cmp"] + version = "v0.6.0" + hash = "sha256-qgra5jze4iPGP0JSTVeY5qV5AvEnEu39LYAuUCIkMtg=" + [mod."github.com/mattn/go-isatty"] + version = "v0.0.20" + hash = "sha256-qhw9hWtU5wnyFyuMbKx+7RB8ckQaFQ8D+8GKPkN3HHQ=" + [mod."github.com/sourcegraph/jsonrpc2"] + version = "v0.2.0" + hash = "sha256-UPJQN/TSg9CjRj0239EV9dbZTwe7grOCf8lFWMkqo8U=" + [mod."go.etcd.io/bbolt"] + version = "v1.3.9" + hash = "sha256-98cKiMZcxl11laO3IiRHnhSgh7mEjl0iKlPxsSPdbww=" + [mod."golang.org/x/sync"] + version = "v0.6.0" + hash = "sha256-LLims/wjDZtIqlYCVHREewcUOX4hwRwplEuZKPOJ/HI=" + [mod."golang.org/x/sys"] + version = "v0.17.0" + hash = "sha256-e0qnE+SitE02IzvnJKI4Uzpq9EOZY+zvE8Wf5b2e6Kg=" + [mod."pkg.nimblebun.works/go-lsp"] + version = "v1.1.0" + hash = "sha256-mJS7tsR4bPOIcHpvIsdKHQvZxpgFRm3hBSMVBMFcDZI=" From 9743271794dfb9198ae07f57b0ce09d433c0292e Mon Sep 17 00:00:00 2001 From: Qi Xiao Date: Fri, 3 Jan 2025 19:08:41 +0000 Subject: [PATCH 2/4] Bump nixpkgs edition, Go compiler version, and update gomod2nix.toml. --- flake.lock | 8 ++++---- flake.nix | 6 +++--- gomod2nix.toml | 37 +++++++++++++++++++++++++++++-------- 3 files changed, 36 insertions(+), 15 deletions(-) diff --git a/flake.lock b/flake.lock index 75fb935e9..583cf75e2 100644 --- a/flake.lock +++ b/flake.lock @@ -41,16 +41,16 @@ }, "nixpkgs": { "locked": { - "lastModified": 1716218643, - "narHash": "sha256-i/E7gzQybvcGAYDRGDl39WL6yVk30Je/NXypBz6/nmM=", + "lastModified": 1735669367, + "narHash": "sha256-tfYRbFhMOnYaM4ippqqid3BaLOXoFNdImrfBfCp4zn0=", "owner": "NixOS", "repo": "nixpkgs", - "rev": "a8695cbd09a7ecf3376bd62c798b9864d20f86ee", + "rev": "edf04b75c13c2ac0e54df5ec5c543e300f76f1c9", "type": "github" }, "original": { "owner": "NixOS", - "ref": "nixos-23.11", + "ref": "nixos-24.11", "repo": "nixpkgs", "type": "github" } diff --git a/flake.nix b/flake.nix index 09ab30259..d24c6ceae 100644 --- a/flake.nix +++ b/flake.nix @@ -2,7 +2,7 @@ description = "elvish"; inputs = { - nixpkgs.url = "github:NixOS/nixpkgs/nixos-23.11"; + nixpkgs.url = "github:NixOS/nixpkgs/nixos-24.11"; gomod2nix = { url = "github:nix-community/gomod2nix"; inputs.nixpkgs.follows = "nixpkgs"; @@ -33,7 +33,7 @@ elvish = buildGoApplication { name = "elvish"; src = ./.; - go = pkgs.go_1_21; + go = pkgs.go_1_22; pwd = ./.; subPackages = [ "cmd/elvish" ]; CGO_ENABLED = 0; @@ -52,7 +52,7 @@ devShell = forAllSystems ({ system, pkgs }: pkgs.mkShell { buildInputs = with pkgs; [ - go_1_21 + go_1_22 gomod2nix.legacyPackages.${system}.gomod2nix gopls ]; diff --git a/gomod2nix.toml b/gomod2nix.toml index 3209e340c..faea46c25 100644 --- a/gomod2nix.toml +++ b/gomod2nix.toml @@ -1,27 +1,48 @@ schema = 3 [mod] + [mod."github.com/BurntSushi/toml"] + version = "v1.4.0" + hash = "sha256-3cr8hfVA4th/AfveHDxigmj8Eiiae0ZBnxAgy+7RYO4=" [mod."github.com/creack/pty"] - version = "v1.1.21" - hash = "sha256-pjGw6wQlrVhN65XaIxZueNJqnXThGu00u24rKOLzxS0=" + version = "v1.1.23" + hash = "sha256-42k7lObS5h99pPoicb6tkRlBvVvSPqsy+aC87PWq2o4=" + [mod."github.com/davecgh/go-spew"] + version = "v1.1.1" + hash = "sha256-nhzSUrE1fCkN0+RL04N4h8jWmRFPPPWbCuDc7Ss0akI=" [mod."github.com/google/go-cmp"] version = "v0.6.0" hash = "sha256-qgra5jze4iPGP0JSTVeY5qV5AvEnEu39LYAuUCIkMtg=" + [mod."github.com/gorilla/websocket"] + version = "v1.4.1" + hash = "sha256-+yo/0+zSqf2/dPZyp/9so21r7cfMx1yhxmmOzy2wwQ4=" [mod."github.com/mattn/go-isatty"] version = "v0.0.20" hash = "sha256-qhw9hWtU5wnyFyuMbKx+7RB8ckQaFQ8D+8GKPkN3HHQ=" + [mod."github.com/pmezard/go-difflib"] + version = "v1.0.0" + hash = "sha256-/FtmHnaGjdvEIKAJtrUfEhV7EVo5A/eYrtdnUkuxLDA=" [mod."github.com/sourcegraph/jsonrpc2"] version = "v0.2.0" hash = "sha256-UPJQN/TSg9CjRj0239EV9dbZTwe7grOCf8lFWMkqo8U=" + [mod."github.com/stretchr/testify"] + version = "v1.8.1" + hash = "sha256-3e0vOJLgCMAan+GfaGN8RGZdarh5iCavM6flf6YMNPk=" [mod."go.etcd.io/bbolt"] - version = "v1.3.9" - hash = "sha256-98cKiMZcxl11laO3IiRHnhSgh7mEjl0iKlPxsSPdbww=" + version = "v1.3.10" + hash = "sha256-uEnz6jmmgT+hlwdZ8ns5NCJSbZcB4i123FF2cn2CbQA=" + [mod."go.etcd.io/gofail"] + version = "v0.1.0" + hash = "sha256-y7524CIGBFYMnqwSv6uzCN726sXqMx3Pupw9z7NBBsU=" [mod."golang.org/x/sync"] - version = "v0.6.0" - hash = "sha256-LLims/wjDZtIqlYCVHREewcUOX4hwRwplEuZKPOJ/HI=" + version = "v0.8.0" + hash = "sha256-usvF0z7gq1vsX58p4orX+8WHlv52pdXgaueXlwj2Wss=" [mod."golang.org/x/sys"] - version = "v0.17.0" - hash = "sha256-e0qnE+SitE02IzvnJKI4Uzpq9EOZY+zvE8Wf5b2e6Kg=" + version = "v0.24.0" + hash = "sha256-P0fsA+qy9taYHWPTtCs5XmrJ1i8tWfvkno+PNuc2elw=" + [mod."gopkg.in/yaml.v3"] + version = "v3.0.1" + hash = "sha256-FqL9TKYJ0XkNwJFnq9j0VvJ5ZUU1RvH/52h/f5bkYAU=" [mod."pkg.nimblebun.works/go-lsp"] version = "v1.1.0" hash = "sha256-mJS7tsR4bPOIcHpvIsdKHQvZxpgFRm3hBSMVBMFcDZI=" From 852874ace18454297640138e7d10ee1934a5bb4d Mon Sep 17 00:00:00 2001 From: Qi Xiao Date: Fri, 3 Jan 2025 19:09:17 +0000 Subject: [PATCH 3/4] .gitignore: Add /result, used by nix --- .gitignore | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.gitignore b/.gitignore index 60d9f7828..d597bfa2b 100644 --- a/.gitignore +++ b/.gitignore @@ -21,6 +21,8 @@ _testmain.go *.exe +# Nix +/result # Project specific cover /_* From c996ee12ef313c42c8ef20a1a65db701d94e420e Mon Sep 17 00:00:00 2001 From: Qi Xiao Date: Fri, 3 Jan 2025 19:11:48 +0000 Subject: [PATCH 4/4] flake.nix: Document how to update gomod2nix.toml. --- flake.nix | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/flake.nix b/flake.nix index d24c6ceae..99dcbda46 100644 --- a/flake.nix +++ b/flake.nix @@ -48,7 +48,10 @@ }; }); - # `nix develop` provides a shell containing development tools. + # "nix develop" provides a shell containing development tools. + # + # "nix develop --command gomod2nix" should be run to update gomod2nix.toml + # after updating Go module dependencies. devShell = forAllSystems ({ system, pkgs }: pkgs.mkShell { buildInputs = with pkgs; [