buildGoPackage
: remove (#349478)
This commit is contained in:
commit
0ecc88f77d
@ -7,32 +7,6 @@ The function `buildGoModule` builds Go programs managed with Go modules. It buil
|
|||||||
- An intermediate fetcher derivation called `goModules`. This derivation will be used to fetch all the dependencies of the Go module.
|
- An intermediate fetcher derivation called `goModules`. This derivation will be used to fetch all the dependencies of the Go module.
|
||||||
- A final derivation will use the output of the intermediate derivation to build the binaries and produce the final output.
|
- A final derivation will use the output of the intermediate derivation to build the binaries and produce the final output.
|
||||||
|
|
||||||
### Attributes of `buildGoModule` {#buildgomodule-parameters}
|
|
||||||
|
|
||||||
The `buildGoModule` function accepts the following parameters in addition to the [attributes accepted by both Go builders](#ssec-go-common-attributes):
|
|
||||||
|
|
||||||
- `vendorHash`: is the hash of the output of the intermediate fetcher derivation (the dependencies of the Go modules).
|
|
||||||
|
|
||||||
`vendorHash` can be set to `null`.
|
|
||||||
In that case, rather than fetching the dependencies, the dependencies already vendored in the `vendor` directory of the source repo will be used.
|
|
||||||
|
|
||||||
To avoid updating this field when dependencies change, run `go mod vendor` in your source repo and set `vendorHash = null;`.
|
|
||||||
You can read more about [vendoring in the Go documentation](https://go.dev/ref/mod#vendoring).
|
|
||||||
|
|
||||||
To obtain the actual hash, set `vendorHash = lib.fakeHash;` and run the build ([more details here](#sec-source-hashes)).
|
|
||||||
- `proxyVendor`: If `true`, the intermediate fetcher downloads dependencies from the
|
|
||||||
[Go module proxy](https://go.dev/ref/mod#module-proxy) (using `go mod download`) instead of vendoring them. The resulting
|
|
||||||
[module cache](https://go.dev/ref/mod#module-cache) is then passed to the final derivation.
|
|
||||||
|
|
||||||
This is useful if your code depends on C code and `go mod tidy` does not include the needed sources to build or
|
|
||||||
if any dependency has case-insensitive conflicts which will produce platform-dependent `vendorHash` checksums.
|
|
||||||
|
|
||||||
Defaults to `false`.
|
|
||||||
- `modPostBuild`: Shell commands to run after the build of the goModules executes `go mod vendor`, and before calculating fixed output derivation's `vendorHash`.
|
|
||||||
Note that if you change this attribute, you need to update `vendorHash` attribute.
|
|
||||||
- `modRoot`: The root directory of the Go module that contains the `go.mod` file.
|
|
||||||
Defaults to `./`, which is the root of `src`.
|
|
||||||
|
|
||||||
### Example for `buildGoModule` {#ex-buildGoModule}
|
### Example for `buildGoModule` {#ex-buildGoModule}
|
||||||
|
|
||||||
The following is an example expression using `buildGoModule`:
|
The following is an example expression using `buildGoModule`:
|
||||||
@ -62,17 +36,45 @@ The following is an example expression using `buildGoModule`:
|
|||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
### Obtaining and overriding `vendorHash` for `buildGoModule` {#buildGoModule-vendorHash}
|
## Attributes of `buildGoModule` {#buildgomodule-parameters}
|
||||||
|
|
||||||
|
Many attributes [controlling the build phase](#variables-controlling-the-build-phase) are respected by `buildGoModule`. Note that `buildGoModule` reads the following attributes also when building the `vendor/` goModules fixed output derivation as well:
|
||||||
|
|
||||||
|
- [`sourceRoot`](#var-stdenv-sourceRoot)
|
||||||
|
- [`prePatch`](#var-stdenv-prePatch)
|
||||||
|
- [`patches`](#var-stdenv-patches)
|
||||||
|
- [`patchFlags`](#var-stdenv-patchFlags)
|
||||||
|
- [`postPatch`](#var-stdenv-postPatch)
|
||||||
|
- [`preBuild`](#var-stdenv-preBuild)
|
||||||
|
- `env`: useful for passing down variables such as `GOWORK`.
|
||||||
|
|
||||||
|
To control test execution of the build derivation, the following attributes are of interest:
|
||||||
|
|
||||||
|
- [`checkInputs`](#var-stdenv-checkInputs)
|
||||||
|
- [`preCheck`](#var-stdenv-preCheck)
|
||||||
|
- [`checkFlags`](#var-stdenv-checkFlags)
|
||||||
|
|
||||||
|
In addition to the above attributes, and the many more variables respected also by `stdenv.mkDerivation`, `buildGoModule` respects Go-specific attributes that tweak them to behave slightly differently:
|
||||||
|
|
||||||
|
### `vendorHash` {#var-go-vendorHash}
|
||||||
|
|
||||||
|
Hash of the output of the intermediate fetcher derivation (the dependencies of the Go modules).
|
||||||
|
|
||||||
|
`vendorHash` can be set to `null`.
|
||||||
|
In that case, rather than fetching the dependencies, the dependencies already vendored in the `vendor` directory of the source repo will be used.
|
||||||
|
|
||||||
|
To avoid updating this field when dependencies change, run `go mod vendor` in your source repo and set `vendorHash = null;`.
|
||||||
|
You can read more about [vendoring in the Go documentation](https://go.dev/ref/mod#vendoring).
|
||||||
|
|
||||||
|
To obtain the hash, set `vendorHash = lib.fakeHash;` and run the build. ([more details here](#sec-source-hashes)).
|
||||||
|
Another way is to use use `nix-prefetch` to obtain the hash. The following command gets the value of `vendorHash` for package `pet`:
|
||||||
|
|
||||||
We can use `nix-prefetch` to obtain the actual hash. The following command gets the value of `vendorHash` for package `pet`:
|
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
cd path/to/nixpkgs
|
cd path/to/nixpkgs
|
||||||
nix-prefetch -E "{ sha256 }: ((import ./. { }).my-package.overrideAttrs { vendorHash = sha256; }).goModules"
|
nix-prefetch -E "{ sha256 }: ((import ./. { }).my-package.overrideAttrs { vendorHash = sha256; }).goModules"
|
||||||
```
|
```
|
||||||
|
|
||||||
To obtain the hash without external tools, set `vendorHash = lib.fakeHash;` and run the build. ([more details here](#sec-source-hashes)).
|
|
||||||
|
|
||||||
`vendorHash` can be overridden with `overrideAttrs`. Override the above example like this:
|
`vendorHash` can be overridden with `overrideAttrs`. Override the above example like this:
|
||||||
|
|
||||||
```nix
|
```nix
|
||||||
@ -91,144 +93,29 @@ To obtain the hash without external tools, set `vendorHash = lib.fakeHash;` and
|
|||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
### Overriding `goModules` {#buildGoModule-goModules-override}
|
### `proxyVendor` {#var-go-proxyVendor}
|
||||||
|
|
||||||
Overriding `<pkg>.goModules` by calling `goModules.overrideAttrs` is unsupported. Still, it is possible to override the `vendorHash` (`goModules`'s `outputHash`) and the `pre`/`post` hooks for both the build and patch phases of the primary and `goModules` derivation. Alternatively, the primary derivation provides an overridable `passthru.overrideModAttrs` function to store the attribute overlay implicitly taken by `goModules.overrideAttrs`. Here's an example usage of `overrideModAttrs`:
|
If `true`, the intermediate fetcher downloads dependencies from the
|
||||||
|
[Go module proxy](https://go.dev/ref/mod#module-proxy) (using `go mod download`) instead of vendoring them. The resulting
|
||||||
|
[module cache](https://go.dev/ref/mod#module-cache) is then passed to the final derivation.
|
||||||
|
|
||||||
```nix
|
This is useful if your code depends on C code and `go mod tidy` does not include the needed sources to build or
|
||||||
{
|
if any dependency has case-insensitive conflicts which will produce platform-dependent `vendorHash` checksums.
|
||||||
pet-overridden = pet.overrideAttrs (
|
|
||||||
finalAttrs: previousAttrs: {
|
|
||||||
passthru = previousAttrs.passthru // {
|
|
||||||
# If the original package has an `overrideModAttrs` attribute set, you'd
|
|
||||||
# want to extend it, and not replace it. Hence we use
|
|
||||||
# `lib.composeExtensions`. If you are sure the `overrideModAttrs` of the
|
|
||||||
# original package trivially does nothing, you can safely replace it
|
|
||||||
# with your own by not using `lib.composeExtensions`.
|
|
||||||
overrideModAttrs = lib.composeExtensions previousAttrs.passthru.overrideModAttrs (
|
|
||||||
finalModAttrs: previousModAttrs: {
|
|
||||||
# goModules-specific overriding goes here
|
|
||||||
postBuild = ''
|
|
||||||
# Here you have access to the `vendor` directory.
|
|
||||||
substituteInPlace vendor/github.com/example/repo/file.go \
|
|
||||||
--replace-fail "panic(err)" ""
|
|
||||||
'';
|
|
||||||
}
|
|
||||||
);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
## `buildGoPackage` (legacy) {#ssec-go-legacy}
|
Defaults to `false`.
|
||||||
|
|
||||||
The function `buildGoPackage` builds legacy Go programs, not supporting Go modules.
|
|
||||||
|
|
||||||
::: {.warning}
|
### `modPostBuild` {#var-go-modPostBuild}
|
||||||
`buildGoPackage` is deprecated and will be removed for the 25.05 release.
|
|
||||||
:::
|
|
||||||
|
|
||||||
### Migrating from `buildGoPackage` to `buildGoModule` {#buildGoPackage-migration}
|
Shell commands to run after the build of the goModules executes `go mod vendor`, and before calculating fixed output derivation's `vendorHash`.
|
||||||
|
Note that if you change this attribute, you need to update `vendorHash` attribute.
|
||||||
|
|
||||||
Go modules, released 6y ago, are now widely adopted in the ecosystem.
|
|
||||||
Most upstream projects are using Go modules, and the tooling previously used for dependency management in Go is mostly deprecated, archived or at least unmaintained at this point.
|
|
||||||
|
|
||||||
In case a project doesn't have external dependencies or dependencies are vendored in a way understood by `go mod init`, migration can be done with a few changes in the package.
|
### `modRoot` {#var-go-modRoot}
|
||||||
|
|
||||||
- Switch the builder from `buildGoPackage` to `buildGoModule`
|
The root directory of the Go module that contains the `go.mod` file.
|
||||||
- Remove `goPackagePath` and other attributes specific to `buildGoPackage`
|
|
||||||
- Set `vendorHash = null;`
|
|
||||||
- Run `go mod init <module name>` in `postPatch`
|
|
||||||
|
|
||||||
In case the package has external dependencies that aren't vendored or the build setup is more complex the upstream source might need to be patched.
|
Defaults to `./`, which is the root of `src`.
|
||||||
Examples for the migration can be found in the [issue tracking migration withing nixpkgs](https://github.com/NixOS/nixpkgs/issues/318069).
|
|
||||||
|
|
||||||
### Example for `buildGoPackage` {#example-for-buildgopackage}
|
|
||||||
|
|
||||||
In the following is an example expression using `buildGoPackage`, the following arguments are of special significance to the function:
|
|
||||||
|
|
||||||
- `goPackagePath` specifies the package's canonical Go import path.
|
|
||||||
- `goDeps` is where the Go dependencies of a Go program are listed as a list of package source identified by Go import path. It could be imported as a separate `deps.nix` file for readability. The dependency data structure is described below.
|
|
||||||
|
|
||||||
```nix
|
|
||||||
{
|
|
||||||
deis = buildGoPackage rec {
|
|
||||||
pname = "deis";
|
|
||||||
version = "1.13.0";
|
|
||||||
|
|
||||||
goPackagePath = "github.com/deis/deis";
|
|
||||||
|
|
||||||
src = fetchFromGitHub {
|
|
||||||
owner = "deis";
|
|
||||||
repo = "deis";
|
|
||||||
rev = "v${version}";
|
|
||||||
hash = "sha256-XCPD4LNWtAd8uz7zyCLRfT8rzxycIUmTACjU03GnaeM=";
|
|
||||||
};
|
|
||||||
|
|
||||||
goDeps = ./deps.nix;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
The `goDeps` attribute can be imported from a separate `nix` file that defines which Go libraries are needed and should be included in `GOPATH` for `buildPhase`:
|
|
||||||
|
|
||||||
```nix
|
|
||||||
# deps.nix
|
|
||||||
[ # goDeps is a list of Go dependencies.
|
|
||||||
{
|
|
||||||
# goPackagePath specifies Go package import path.
|
|
||||||
goPackagePath = "gopkg.in/yaml.v2";
|
|
||||||
fetch = {
|
|
||||||
# `fetch type` that needs to be used to get package source.
|
|
||||||
# If `git` is used there should be `url`, `rev` and `hash` defined next to it.
|
|
||||||
type = "git";
|
|
||||||
url = "https://gopkg.in/yaml.v2";
|
|
||||||
rev = "a83829b6f1293c91addabc89d0571c246397bbf4";
|
|
||||||
hash = "sha256-EMrdy0M0tNuOcITaTAmT5/dPSKPXwHDKCXFpkGbVjdQ=";
|
|
||||||
};
|
|
||||||
}
|
|
||||||
{
|
|
||||||
goPackagePath = "github.com/docopt/docopt-go";
|
|
||||||
fetch = {
|
|
||||||
type = "git";
|
|
||||||
url = "https://github.com/docopt/docopt-go";
|
|
||||||
rev = "784ddc588536785e7299f7272f39101f7faccc3f";
|
|
||||||
hash = "sha256-Uo89zjE+v3R7zzOq/gbQOHj3SMYt2W1nDHS7RCUin3M=";
|
|
||||||
};
|
|
||||||
}
|
|
||||||
]
|
|
||||||
```
|
|
||||||
|
|
||||||
To extract dependency information from a Go package in automated way use [go2nix (deprecated)](https://github.com/kamilchm/go2nix). It can produce complete derivation and `goDeps` file for Go programs.
|
|
||||||
|
|
||||||
You may use Go packages installed into the active Nix profiles by adding the following to your ~/.bashrc:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
for p in $NIX_PROFILES; do
|
|
||||||
GOPATH="$p/share/go:$GOPATH"
|
|
||||||
done
|
|
||||||
```
|
|
||||||
|
|
||||||
## Attributes used by both builders {#ssec-go-common-attributes}
|
|
||||||
|
|
||||||
Many attributes [controlling the build phase](#variables-controlling-the-build-phase) are respected by both `buildGoModule` and `buildGoPackage`. Note that `buildGoModule` reads the following attributes also when building the `vendor/` goModules fixed output derivation as well:
|
|
||||||
|
|
||||||
- [`sourceRoot`](#var-stdenv-sourceRoot)
|
|
||||||
- [`prePatch`](#var-stdenv-prePatch)
|
|
||||||
- [`patches`](#var-stdenv-patches)
|
|
||||||
- [`patchFlags`](#var-stdenv-patchFlags)
|
|
||||||
- [`postPatch`](#var-stdenv-postPatch)
|
|
||||||
- [`preBuild`](#var-stdenv-preBuild)
|
|
||||||
- `env`: useful for passing down variables such as `GOWORK`.
|
|
||||||
|
|
||||||
To control test execution of the build derivation, the following attributes are of interest:
|
|
||||||
|
|
||||||
- [`checkInputs`](#var-stdenv-checkInputs)
|
|
||||||
- [`preCheck`](#var-stdenv-preCheck)
|
|
||||||
- [`checkFlags`](#var-stdenv-checkFlags)
|
|
||||||
|
|
||||||
In addition to the above attributes, and the many more variables respected also by `stdenv.mkDerivation`, both `buildGoModule` and `buildGoPackage` respect Go-specific attributes that tweak them to behave slightly differently:
|
|
||||||
|
|
||||||
### `ldflags` {#var-go-ldflags}
|
### `ldflags` {#var-go-ldflags}
|
||||||
|
|
||||||
@ -326,6 +213,38 @@ Whether the build result should be allowed to contain references to the Go tool
|
|||||||
|
|
||||||
Defaults to `false`
|
Defaults to `false`
|
||||||
|
|
||||||
|
## Overriding `goModules` {#buildGoModule-goModules-override}
|
||||||
|
|
||||||
|
Overriding `<pkg>.goModules` by calling `goModules.overrideAttrs` is unsupported. Still, it is possible to override the `vendorHash` (`goModules`'s `outputHash`) and the `pre`/`post` hooks for both the build and patch phases of the primary and `goModules` derivation.
|
||||||
|
|
||||||
|
Alternatively, the primary derivation provides an overridable `passthru.overrideModAttrs` function to store the attribute overlay implicitly taken by `goModules.overrideAttrs`. Here's an example usage of `overrideModAttrs`:
|
||||||
|
|
||||||
|
```nix
|
||||||
|
{
|
||||||
|
pet-overridden = pet.overrideAttrs (
|
||||||
|
finalAttrs: previousAttrs: {
|
||||||
|
passthru = previousAttrs.passthru // {
|
||||||
|
# If the original package has an `overrideModAttrs` attribute set, you'd
|
||||||
|
# want to extend it, and not replace it. Hence we use
|
||||||
|
# `lib.composeExtensions`. If you are sure the `overrideModAttrs` of the
|
||||||
|
# original package trivially does nothing, you can safely replace it
|
||||||
|
# with your own by not using `lib.composeExtensions`.
|
||||||
|
overrideModAttrs = lib.composeExtensions previousAttrs.passthru.overrideModAttrs (
|
||||||
|
finalModAttrs: previousModAttrs: {
|
||||||
|
# goModules-specific overriding goes here
|
||||||
|
postBuild = ''
|
||||||
|
# Here you have access to the `vendor` directory.
|
||||||
|
substituteInPlace vendor/github.com/example/repo/file.go \
|
||||||
|
--replace-fail "panic(err)" ""
|
||||||
|
'';
|
||||||
|
}
|
||||||
|
);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
## Controlling the Go environment {#ssec-go-environment}
|
## Controlling the Go environment {#ssec-go-environment}
|
||||||
|
|
||||||
The Go build can be further tweaked by setting environment variables. In most cases, this isn't needed. Possible values can be found in the [Go documentation of accepted environment variables](https://pkg.go.dev/cmd/go#hdr-Environment_variables). Notice that some of these flags are set by the builder itself and should not be set explicitly. If in doubt, grep the implementation of the builder.
|
The Go build can be further tweaked by setting environment variables. In most cases, this isn't needed. Possible values can be found in the [Go documentation of accepted environment variables](https://pkg.go.dev/cmd/go#hdr-Environment_variables). Notice that some of these flags are set by the builder itself and should not be set explicitly. If in doubt, grep the implementation of the builder.
|
||||||
@ -364,4 +283,23 @@ If a larger amount of tests should be skipped, the following pattern can be used
|
|||||||
```
|
```
|
||||||
|
|
||||||
To disable tests altogether, set `doCheck = false;`.
|
To disable tests altogether, set `doCheck = false;`.
|
||||||
`buildGoPackage` does not execute tests by default.
|
|
||||||
|
## Migrating from `buildGoPackage` to `buildGoModule` {#buildGoPackage-migration}
|
||||||
|
|
||||||
|
::: {.warning}
|
||||||
|
`buildGoPackage` was removed for the 25.05 release. It was used to build legacy Go programs
|
||||||
|
that do not support Go modules.
|
||||||
|
:::
|
||||||
|
|
||||||
|
Go modules, released 6y ago, are now widely adopted in the ecosystem.
|
||||||
|
Most upstream projects are using Go modules, and the tooling previously used for dependency management in Go is mostly deprecated, archived or at least unmaintained at this point.
|
||||||
|
|
||||||
|
In case a project doesn't have external dependencies or dependencies are vendored in a way understood by `go mod init`, migration can be done with a few changes in the package.
|
||||||
|
|
||||||
|
- Switch the builder from `buildGoPackage` to `buildGoModule`
|
||||||
|
- Remove `goPackagePath` and other attributes specific to `buildGoPackage`
|
||||||
|
- Set `vendorHash = null;`
|
||||||
|
- Run `go mod init <module name>` in `postPatch`
|
||||||
|
|
||||||
|
In case the package has external dependencies that aren't vendored or the build setup is more complex the upstream source might need to be patched.
|
||||||
|
Examples for the migration can be found in the [issue tracking migration withing nixpkgs](https://github.com/NixOS/nixpkgs/issues/318069).
|
||||||
|
@ -2721,29 +2721,20 @@
|
|||||||
"index.html#ssec-language-go"
|
"index.html#ssec-language-go"
|
||||||
],
|
],
|
||||||
"buildgomodule-parameters": [
|
"buildgomodule-parameters": [
|
||||||
"index.html#buildgomodule-parameters"
|
"index.html#buildgomodule-parameters",
|
||||||
|
"index.html#ssec-go-common-attributes"
|
||||||
],
|
],
|
||||||
"ex-buildGoModule": [
|
"ex-buildGoModule": [
|
||||||
"index.html#ex-buildGoModule"
|
"index.html#ex-buildGoModule"
|
||||||
],
|
],
|
||||||
"buildGoModule-vendorHash": [
|
|
||||||
"index.html#buildGoModule-vendorHash"
|
|
||||||
],
|
|
||||||
"buildGoModule-goModules-override": [
|
"buildGoModule-goModules-override": [
|
||||||
"index.html#buildGoModule-goModules-override"
|
"index.html#buildGoModule-goModules-override"
|
||||||
],
|
],
|
||||||
"ssec-go-legacy": [
|
|
||||||
"index.html#ssec-go-legacy"
|
|
||||||
],
|
|
||||||
"buildGoPackage-migration": [
|
"buildGoPackage-migration": [
|
||||||
"index.html#buildGoPackage-migration"
|
"index.html#buildGoPackage-migration",
|
||||||
],
|
"index.html#ssec-go-legacy",
|
||||||
"example-for-buildgopackage": [
|
|
||||||
"index.html#example-for-buildgopackage"
|
"index.html#example-for-buildgopackage"
|
||||||
],
|
],
|
||||||
"ssec-go-common-attributes": [
|
|
||||||
"index.html#ssec-go-common-attributes"
|
|
||||||
],
|
|
||||||
"var-go-ldflags": [
|
"var-go-ldflags": [
|
||||||
"index.html#var-go-ldflags"
|
"index.html#var-go-ldflags"
|
||||||
],
|
],
|
||||||
@ -2759,6 +2750,9 @@
|
|||||||
"var-go-excludedPackages": [
|
"var-go-excludedPackages": [
|
||||||
"index.html#var-go-excludedPackages"
|
"index.html#var-go-excludedPackages"
|
||||||
],
|
],
|
||||||
|
"var-go-proxyVendor": [
|
||||||
|
"index.html#var-go-proxyVendor"
|
||||||
|
],
|
||||||
"var-go-CGO_ENABLED": [
|
"var-go-CGO_ENABLED": [
|
||||||
"index.html#var-go-CGO_ENABLED"
|
"index.html#var-go-CGO_ENABLED"
|
||||||
],
|
],
|
||||||
@ -2768,6 +2762,16 @@
|
|||||||
"var-go-allowGoReference": [
|
"var-go-allowGoReference": [
|
||||||
"index.html#var-go-allowGoReference"
|
"index.html#var-go-allowGoReference"
|
||||||
],
|
],
|
||||||
|
"var-go-vendorHash": [
|
||||||
|
"index.html#var-go-vendorHash",
|
||||||
|
"index.html#buildGoModule-vendorHash"
|
||||||
|
],
|
||||||
|
"var-go-modPostBuild": [
|
||||||
|
"index.html#var-go-modPostBuild"
|
||||||
|
],
|
||||||
|
"var-go-modRoot": [
|
||||||
|
"index.html#var-go-modRoot"
|
||||||
|
],
|
||||||
"ssec-go-environment": [
|
"ssec-go-environment": [
|
||||||
"index.html#ssec-go-environment"
|
"index.html#ssec-go-environment"
|
||||||
],
|
],
|
||||||
|
@ -20,6 +20,8 @@
|
|||||||
|
|
||||||
<!-- To avoid merge conflicts, consider adding your item at an arbitrary place in the list instead. -->
|
<!-- To avoid merge conflicts, consider adding your item at an arbitrary place in the list instead. -->
|
||||||
|
|
||||||
|
- `buildGoPackage` has been removed. Use `buildGoModule` instead. See the [Go section in the nixpkgs manual](https://nixos.org/manual/nixpkgs/unstable/#sec-language-go) for details.
|
||||||
|
|
||||||
- `kanata` was updated to v1.7.0, which introduces several breaking changes.
|
- `kanata` was updated to v1.7.0, which introduces several breaking changes.
|
||||||
See the release notes of
|
See the release notes of
|
||||||
[v1.7.0](https://github.com/jtroo/kanata/releases/tag/v1.7.0)
|
[v1.7.0](https://github.com/jtroo/kanata/releases/tag/v1.7.0)
|
||||||
|
@ -46,9 +46,6 @@
|
|||||||
# Meta data for the final derivation.
|
# Meta data for the final derivation.
|
||||||
, meta ? { }
|
, meta ? { }
|
||||||
|
|
||||||
# Not needed with `buildGoModule`.
|
|
||||||
, goPackagePath ? ""
|
|
||||||
|
|
||||||
# Go linker flags.
|
# Go linker flags.
|
||||||
, ldflags ? [ ]
|
, ldflags ? [ ]
|
||||||
# Go build flags.
|
# Go build flags.
|
||||||
@ -61,8 +58,6 @@
|
|||||||
, ...
|
, ...
|
||||||
}@args':
|
}@args':
|
||||||
|
|
||||||
assert goPackagePath != "" -> throw "`goPackagePath` is not needed with `buildGoModule`";
|
|
||||||
|
|
||||||
let
|
let
|
||||||
args = removeAttrs args' [ "overrideModAttrs" "vendorSha256" ];
|
args = removeAttrs args' [ "overrideModAttrs" "vendorSha256" ];
|
||||||
|
|
||||||
|
@ -1,295 +0,0 @@
|
|||||||
{ go, govers, lib, fetchgit, fetchhg, fetchbzr, rsync
|
|
||||||
, fetchFromGitHub, stdenv }:
|
|
||||||
|
|
||||||
{ buildInputs ? []
|
|
||||||
, nativeBuildInputs ? []
|
|
||||||
, passthru ? {}
|
|
||||||
, preFixup ? ""
|
|
||||||
, shellHook ? ""
|
|
||||||
|
|
||||||
# We want parallel builds by default
|
|
||||||
, enableParallelBuilding ? true
|
|
||||||
|
|
||||||
# Go import path of the package
|
|
||||||
, goPackagePath
|
|
||||||
|
|
||||||
# Go package aliases
|
|
||||||
, goPackageAliases ? [ ]
|
|
||||||
|
|
||||||
# Extra sources to include in the gopath
|
|
||||||
, extraSrcs ? [ ]
|
|
||||||
|
|
||||||
# Extra gopaths containing src subfolder
|
|
||||||
# with sources to include in the gopath
|
|
||||||
, extraSrcPaths ? [ ]
|
|
||||||
|
|
||||||
# go2nix dependency file
|
|
||||||
, goDeps ? null
|
|
||||||
|
|
||||||
# Whether to delete the vendor folder supplied with the source.
|
|
||||||
, deleteVendor ? false
|
|
||||||
|
|
||||||
, dontRenameImports ? false
|
|
||||||
|
|
||||||
# Do not enable this without good reason
|
|
||||||
# IE: programs coupled with the compiler
|
|
||||||
, allowGoReference ? false
|
|
||||||
|
|
||||||
, CGO_ENABLED ? go.CGO_ENABLED
|
|
||||||
|
|
||||||
, ldflags ? [ ]
|
|
||||||
|
|
||||||
, GOFLAGS ? [ ]
|
|
||||||
|
|
||||||
# needed for buildFlags{,Array} warning
|
|
||||||
, buildFlags ? ""
|
|
||||||
, buildFlagsArray ? ""
|
|
||||||
|
|
||||||
, meta ? {}, ... } @ args:
|
|
||||||
|
|
||||||
let
|
|
||||||
dep2src = goDep:
|
|
||||||
{
|
|
||||||
inherit (goDep) goPackagePath;
|
|
||||||
src = if goDep.fetch.type == "git" then
|
|
||||||
fetchgit {
|
|
||||||
inherit (goDep.fetch) url rev sha256;
|
|
||||||
}
|
|
||||||
else if goDep.fetch.type == "hg" then
|
|
||||||
fetchhg {
|
|
||||||
inherit (goDep.fetch) url rev sha256;
|
|
||||||
}
|
|
||||||
else if goDep.fetch.type == "bzr" then
|
|
||||||
fetchbzr {
|
|
||||||
inherit (goDep.fetch) url rev sha256;
|
|
||||||
}
|
|
||||||
else if goDep.fetch.type == "FromGitHub" then
|
|
||||||
fetchFromGitHub {
|
|
||||||
inherit (goDep.fetch) owner repo rev sha256;
|
|
||||||
}
|
|
||||||
else abort "Unrecognized package fetch type: ${goDep.fetch.type}";
|
|
||||||
};
|
|
||||||
|
|
||||||
importGodeps = { depsFile }:
|
|
||||||
map dep2src (import depsFile);
|
|
||||||
|
|
||||||
goPath = if goDeps != null then importGodeps { depsFile = goDeps; } ++ extraSrcs
|
|
||||||
else extraSrcs;
|
|
||||||
package = stdenv.mkDerivation (
|
|
||||||
(builtins.removeAttrs args [ "goPackageAliases" "disabled" "extraSrcs"]) // {
|
|
||||||
|
|
||||||
nativeBuildInputs = [ go ]
|
|
||||||
++ (lib.optional (!dontRenameImports) govers) ++ nativeBuildInputs;
|
|
||||||
buildInputs = buildInputs;
|
|
||||||
|
|
||||||
inherit (go) GOOS GOARCH GO386;
|
|
||||||
|
|
||||||
GOHOSTARCH = go.GOHOSTARCH or null;
|
|
||||||
GOHOSTOS = go.GOHOSTOS or null;
|
|
||||||
|
|
||||||
inherit CGO_ENABLED enableParallelBuilding;
|
|
||||||
|
|
||||||
GO111MODULE = "off";
|
|
||||||
GOTOOLCHAIN = "local";
|
|
||||||
GOFLAGS = GOFLAGS ++ lib.optional (!allowGoReference) "-trimpath" ;
|
|
||||||
|
|
||||||
GOARM = toString (lib.intersectLists [(stdenv.hostPlatform.parsed.cpu.version or "")] ["5" "6" "7"]);
|
|
||||||
|
|
||||||
# If not set to an explicit value, set the buildid empty for reproducibility.
|
|
||||||
ldflags = ldflags ++ lib.optional (!lib.any (lib.hasPrefix "-buildid=") ldflags) "-buildid=";
|
|
||||||
|
|
||||||
configurePhase = args.configurePhase or (''
|
|
||||||
runHook preConfigure
|
|
||||||
|
|
||||||
# Extract the source
|
|
||||||
cd "$NIX_BUILD_TOP"
|
|
||||||
mkdir -p "go/src/$(dirname "$goPackagePath")"
|
|
||||||
mv "$sourceRoot" "go/src/$goPackagePath"
|
|
||||||
|
|
||||||
'' + lib.optionalString deleteVendor ''
|
|
||||||
if [ ! -d "go/src/$goPackagePath/vendor" ]; then
|
|
||||||
echo "vendor folder does not exist, 'deleteVendor' is not needed"
|
|
||||||
exit 10
|
|
||||||
else
|
|
||||||
rm -rf "go/src/$goPackagePath/vendor"
|
|
||||||
fi
|
|
||||||
'' + lib.optionalString (goDeps != null) ''
|
|
||||||
if [ -d "go/src/$goPackagePath/vendor" ]; then
|
|
||||||
echo "vendor folder exists, 'goDeps' is not needed"
|
|
||||||
exit 10
|
|
||||||
fi
|
|
||||||
'' + lib.flip lib.concatMapStrings goPath ({ src, goPackagePath }: ''
|
|
||||||
mkdir goPath
|
|
||||||
(cd goPath; unpackFile "${src}")
|
|
||||||
mkdir -p "go/src/$(dirname "${goPackagePath}")"
|
|
||||||
chmod -R u+w goPath/*
|
|
||||||
mv goPath/* "go/src/${goPackagePath}"
|
|
||||||
rmdir goPath
|
|
||||||
|
|
||||||
'') + (lib.optionalString (extraSrcPaths != []) ''
|
|
||||||
${rsync}/bin/rsync -a ${lib.concatMapStringsSep " " (p: "${p}/src") extraSrcPaths} go
|
|
||||||
|
|
||||||
'') + ''
|
|
||||||
export GOPATH=$NIX_BUILD_TOP/go:$GOPATH
|
|
||||||
export GOCACHE=$TMPDIR/go-cache
|
|
||||||
|
|
||||||
# currently pie is only enabled by default in pkgsMusl
|
|
||||||
# this will respect the `hardening{Disable,Enable}` flags if set
|
|
||||||
if [[ $NIX_HARDENING_ENABLE =~ "pie" ]]; then
|
|
||||||
export GOFLAGS="-buildmode=pie $GOFLAGS"
|
|
||||||
fi
|
|
||||||
|
|
||||||
runHook postConfigure
|
|
||||||
'');
|
|
||||||
|
|
||||||
renameImports = args.renameImports or (
|
|
||||||
let
|
|
||||||
inputsWithAliases = lib.filter (x: x ? goPackageAliases)
|
|
||||||
(buildInputs ++ (args.propagatedBuildInputs or [ ]));
|
|
||||||
rename = to: from: "echo Renaming '${from}' to '${to}'; govers -d -m ${from} ${to}";
|
|
||||||
renames = p: lib.concatMapStringsSep "\n" (rename p.goPackagePath) p.goPackageAliases;
|
|
||||||
in lib.concatMapStringsSep "\n" renames inputsWithAliases);
|
|
||||||
|
|
||||||
buildPhase = args.buildPhase or (''
|
|
||||||
runHook preBuild
|
|
||||||
|
|
||||||
runHook renameImports
|
|
||||||
|
|
||||||
exclude='\(/_\|examples\|Godeps\|testdata'
|
|
||||||
if [[ -n "$excludedPackages" ]]; then
|
|
||||||
IFS=' ' read -r -a excludedArr <<<$excludedPackages
|
|
||||||
printf -v excludedAlternates '%s\\|' "''${excludedArr[@]}"
|
|
||||||
excludedAlternates=''${excludedAlternates%\\|} # drop final \| added by printf
|
|
||||||
exclude+='\|'"$excludedAlternates"
|
|
||||||
fi
|
|
||||||
exclude+='\)'
|
|
||||||
|
|
||||||
buildGoDir() {
|
|
||||||
local cmd="$1" dir="$2"
|
|
||||||
|
|
||||||
. $TMPDIR/buildFlagsArray
|
|
||||||
|
|
||||||
declare -a flags
|
|
||||||
flags+=($buildFlags "''${buildFlagsArray[@]}")
|
|
||||||
flags+=(''${tags:+-tags=''${tags// /,}})
|
|
||||||
flags+=(''${ldflags:+-ldflags="$ldflags"})
|
|
||||||
flags+=("-p" "$NIX_BUILD_CORES")
|
|
||||||
|
|
||||||
if [ "$cmd" = "test" ]; then
|
|
||||||
flags+=(-vet=off)
|
|
||||||
flags+=($checkFlags)
|
|
||||||
fi
|
|
||||||
|
|
||||||
local OUT
|
|
||||||
if ! OUT="$(go $cmd "''${flags[@]}" $dir 2>&1)"; then
|
|
||||||
if ! echo "$OUT" | grep -qE '(no( buildable| non-test)?|build constraints exclude all) Go (source )?files'; then
|
|
||||||
echo "$OUT" >&2
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
if [ -n "$OUT" ]; then
|
|
||||||
echo "$OUT" >&2
|
|
||||||
fi
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
|
|
||||||
getGoDirs() {
|
|
||||||
local type;
|
|
||||||
type="$1"
|
|
||||||
if [ -n "$subPackages" ]; then
|
|
||||||
echo "$subPackages" | sed "s,\(^\| \),\1$goPackagePath/,g"
|
|
||||||
else
|
|
||||||
pushd "$NIX_BUILD_TOP/go/src" >/dev/null
|
|
||||||
find "$goPackagePath" -type f -name \*$type.go -exec dirname {} \; | grep -v "/vendor/" | sort | uniq | grep -v "$exclude"
|
|
||||||
popd >/dev/null
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
if (( "''${NIX_DEBUG:-0}" >= 1 )); then
|
|
||||||
buildFlagsArray+=(-x)
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ ''${#buildFlagsArray[@]} -ne 0 ]; then
|
|
||||||
declare -p buildFlagsArray > $TMPDIR/buildFlagsArray
|
|
||||||
else
|
|
||||||
touch $TMPDIR/buildFlagsArray
|
|
||||||
fi
|
|
||||||
if [ -z "$enableParallelBuilding" ]; then
|
|
||||||
export NIX_BUILD_CORES=1
|
|
||||||
fi
|
|
||||||
for pkg in $(getGoDirs ""); do
|
|
||||||
echo "Building subPackage $pkg"
|
|
||||||
buildGoDir install "$pkg"
|
|
||||||
done
|
|
||||||
'' + lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) ''
|
|
||||||
# normalize cross-compiled builds w.r.t. native builds
|
|
||||||
(
|
|
||||||
dir=$NIX_BUILD_TOP/go/bin/${go.GOOS}_${go.GOARCH}
|
|
||||||
if [[ -n "$(shopt -s nullglob; echo $dir/*)" ]]; then
|
|
||||||
mv $dir/* $dir/..
|
|
||||||
fi
|
|
||||||
if [[ -d $dir ]]; then
|
|
||||||
rmdir $dir
|
|
||||||
fi
|
|
||||||
)
|
|
||||||
'' + ''
|
|
||||||
runHook postBuild
|
|
||||||
'');
|
|
||||||
|
|
||||||
doCheck = args.doCheck or false;
|
|
||||||
checkPhase = args.checkPhase or ''
|
|
||||||
runHook preCheck
|
|
||||||
# We do not set trimpath for tests, in case they reference test assets
|
|
||||||
export GOFLAGS=''${GOFLAGS//-trimpath/}
|
|
||||||
|
|
||||||
for pkg in $(getGoDirs test); do
|
|
||||||
buildGoDir test "$pkg"
|
|
||||||
done
|
|
||||||
|
|
||||||
runHook postCheck
|
|
||||||
'';
|
|
||||||
|
|
||||||
installPhase = args.installPhase or ''
|
|
||||||
runHook preInstall
|
|
||||||
|
|
||||||
mkdir -p $out
|
|
||||||
dir="$NIX_BUILD_TOP/go/bin"
|
|
||||||
[ -e "$dir" ] && cp -r $dir $out
|
|
||||||
|
|
||||||
runHook postInstall
|
|
||||||
'';
|
|
||||||
|
|
||||||
strictDeps = true;
|
|
||||||
|
|
||||||
shellHook = ''
|
|
||||||
d=$(mktemp -d "--suffix=-$name")
|
|
||||||
'' + toString (map (dep: ''
|
|
||||||
mkdir -p "$d/src/$(dirname "${dep.goPackagePath}")"
|
|
||||||
ln -s "${dep.src}" "$d/src/${dep.goPackagePath}"
|
|
||||||
''
|
|
||||||
) goPath) + ''
|
|
||||||
export GOPATH=${lib.concatStringsSep ":" ( ["$d"] ++ ["$GOPATH"] ++ ["$PWD"] ++ extraSrcPaths)}
|
|
||||||
'' + shellHook;
|
|
||||||
|
|
||||||
disallowedReferences = lib.optional (!allowGoReference) go
|
|
||||||
++ lib.optional (!dontRenameImports) govers;
|
|
||||||
|
|
||||||
passthru = passthru //
|
|
||||||
{ inherit go; } //
|
|
||||||
lib.optionalAttrs (goPackageAliases != []) { inherit goPackageAliases; };
|
|
||||||
|
|
||||||
meta = {
|
|
||||||
# Add default meta information
|
|
||||||
homepage = "https://${goPackagePath}";
|
|
||||||
platforms = go.meta.platforms or lib.platforms.all;
|
|
||||||
} // meta;
|
|
||||||
});
|
|
||||||
in
|
|
||||||
lib.warnIf (buildFlags != "" || buildFlagsArray != "")
|
|
||||||
"`buildFlags`/`buildFlagsArray` are deprecated and will be removed in the 24.11 release. Use the `ldflags` and/or `tags` attributes instead"
|
|
||||||
lib.warnIf (builtins.elem "-buildid=" ldflags) "`-buildid=` is set by default as ldflag by buildGoModule"
|
|
||||||
lib.warnIf (builtins.elem "-trimpath" GOFLAGS) "`-trimpath` is added by default to GOFLAGS by buildGoModule when allowGoReference isn't set to true"
|
|
||||||
lib.warn ''
|
|
||||||
'buildGoPackage' is deprecated and will be removed for the 25.05 release.
|
|
||||||
Please use 'buildGoModule' instead. Tips for migration can be found in the Go section of the nixpkgs manual.''
|
|
||||||
package
|
|
@ -161,6 +161,7 @@ mapAliases {
|
|||||||
|
|
||||||
budgie = throw "The `budgie` scope has been removed and all packages moved to the top-level"; # Added 2024-07-14
|
budgie = throw "The `budgie` scope has been removed and all packages moved to the top-level"; # Added 2024-07-14
|
||||||
budgiePlugins = throw "The `budgiePlugins` scope has been removed and all packages moved to the top-level"; # Added 2024-07-14
|
budgiePlugins = throw "The `budgiePlugins` scope has been removed and all packages moved to the top-level"; # Added 2024-07-14
|
||||||
|
buildGoPackage = throw "`buildGoPackage` has been deprecated and removed, see the Go section in the nixpkgs manual for details"; # Added 2024-11-18
|
||||||
|
|
||||||
inherit (libsForQt5.mauiPackages) buho; # added 2022-05-17
|
inherit (libsForQt5.mauiPackages) buho; # added 2022-05-17
|
||||||
butler = throw "butler was removed because it was broken and abandoned upstream"; # added 2024-06-18
|
butler = throw "butler was removed because it was broken and abandoned upstream"; # added 2024-06-18
|
||||||
|
@ -11416,23 +11416,16 @@ with pkgs;
|
|||||||
# the unversioned attributes should always point to the same go version
|
# the unversioned attributes should always point to the same go version
|
||||||
go = go_1_23;
|
go = go_1_23;
|
||||||
buildGoModule = buildGo123Module;
|
buildGoModule = buildGo123Module;
|
||||||
buildGoPackage = buildGo123Package;
|
|
||||||
|
|
||||||
go_1_22 = callPackage ../development/compilers/go/1.22.nix { };
|
go_1_22 = callPackage ../development/compilers/go/1.22.nix { };
|
||||||
buildGo122Module = callPackage ../build-support/go/module.nix {
|
buildGo122Module = callPackage ../build-support/go/module.nix {
|
||||||
go = buildPackages.go_1_22;
|
go = buildPackages.go_1_22;
|
||||||
};
|
};
|
||||||
buildGo122Package = callPackage ../build-support/go/package.nix {
|
|
||||||
go = buildPackages.go_1_22;
|
|
||||||
};
|
|
||||||
|
|
||||||
go_1_23 = callPackage ../development/compilers/go/1.23.nix { };
|
go_1_23 = callPackage ../development/compilers/go/1.23.nix { };
|
||||||
buildGo123Module = callPackage ../build-support/go/module.nix {
|
buildGo123Module = callPackage ../build-support/go/module.nix {
|
||||||
go = buildPackages.go_1_23;
|
go = buildPackages.go_1_23;
|
||||||
};
|
};
|
||||||
buildGo123Package = callPackage ../build-support/go/package.nix {
|
|
||||||
go = buildPackages.go_1_23;
|
|
||||||
};
|
|
||||||
|
|
||||||
### DEVELOPMENT / HARE
|
### DEVELOPMENT / HARE
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user