Merge pull request #258384 from doronbehar/buildNpmPackage-makeWrapperArgs
buildNpmPackage: support makeWrapperArgs
This commit is contained in:
commit
d090cd9af4
@ -161,6 +161,8 @@ git config --global url."https://github.com/".insteadOf git://github.com/
|
|||||||
|
|
||||||
`buildNpmPackage` allows you to package npm-based projects in Nixpkgs without the use of an auto-generated dependencies file (as used in [node2nix](#javascript-node2nix)). It works by utilizing npm's cache functionality -- creating a reproducible cache that contains the dependencies of a project, and pointing npm to it.
|
`buildNpmPackage` allows you to package npm-based projects in Nixpkgs without the use of an auto-generated dependencies file (as used in [node2nix](#javascript-node2nix)). It works by utilizing npm's cache functionality -- creating a reproducible cache that contains the dependencies of a project, and pointing npm to it.
|
||||||
|
|
||||||
|
Here's an example:
|
||||||
|
|
||||||
```nix
|
```nix
|
||||||
{ lib, buildNpmPackage, fetchFromGitHub }:
|
{ lib, buildNpmPackage, fetchFromGitHub }:
|
||||||
|
|
||||||
@ -191,6 +193,8 @@ buildNpmPackage rec {
|
|||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
In the default `installPhase` set by `buildNpmPackage`, it uses `npm pack --json --dry-run` to decide what files to install in `$out/lib/node_modules/$name/`, where `$name` is the `name` string defined in the package's `package.json`. Additionally, the `bin` and `man` keys in the source's `package.json` are used to decide what binaries and manpages are supposed to be installed. If these are not defined, `npm pack` may miss some files, and no binaries will be produced.
|
||||||
|
|
||||||
#### Arguments {#javascript-buildNpmPackage-arguments}
|
#### Arguments {#javascript-buildNpmPackage-arguments}
|
||||||
|
|
||||||
* `npmDepsHash`: The output hash of the dependencies for this project. Can be calculated in advance with [`prefetch-npm-deps`](#javascript-buildNpmPackage-prefetch-npm-deps).
|
* `npmDepsHash`: The output hash of the dependencies for this project. Can be calculated in advance with [`prefetch-npm-deps`](#javascript-buildNpmPackage-prefetch-npm-deps).
|
||||||
@ -204,10 +208,11 @@ buildNpmPackage rec {
|
|||||||
* `npmBuildFlags`: Flags to pass to `npm run ${npmBuildScript}`.
|
* `npmBuildFlags`: Flags to pass to `npm run ${npmBuildScript}`.
|
||||||
* `npmPackFlags`: Flags to pass to `npm pack`.
|
* `npmPackFlags`: Flags to pass to `npm pack`.
|
||||||
* `npmPruneFlags`: Flags to pass to `npm prune`. Defaults to the value of `npmInstallFlags`.
|
* `npmPruneFlags`: Flags to pass to `npm prune`. Defaults to the value of `npmInstallFlags`.
|
||||||
|
* `makeWrapperArgs`: Flags to pass to `makeWrapper`, added to executable calling the generated `.js` with `node` as an interpreter. These scripts are defined in `package.json`.
|
||||||
|
|
||||||
#### prefetch-npm-deps {#javascript-buildNpmPackage-prefetch-npm-deps}
|
#### prefetch-npm-deps {#javascript-buildNpmPackage-prefetch-npm-deps}
|
||||||
|
|
||||||
`prefetch-npm-deps` can calculate the hash of the dependencies of an npm project ahead of time.
|
`prefetch-npm-deps` is a Nixpkgs package that calculates the hash of the dependencies of an npm project ahead of time.
|
||||||
|
|
||||||
```console
|
```console
|
||||||
$ ls
|
$ ls
|
||||||
@ -217,6 +222,15 @@ $ prefetch-npm-deps package-lock.json
|
|||||||
sha256-AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=
|
sha256-AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=
|
||||||
```
|
```
|
||||||
|
|
||||||
|
#### fetchNpmDeps {#javascript-buildNpmPackage-fetchNpmDeps}
|
||||||
|
|
||||||
|
`fetchNpmDeps` is a Nix function that requires the following mandatory arguments:
|
||||||
|
|
||||||
|
- `src`: A directory / tarball with `package-lock.json` file
|
||||||
|
- `hash`: The output hash of the node dependencies defined in `package-lock.json`.
|
||||||
|
|
||||||
|
It returns a derivation with all `package-lock.json` dependencies downloaded into `$out/`, usable as an npm cache.
|
||||||
|
|
||||||
### corepack {#javascript-corepack}
|
### corepack {#javascript-corepack}
|
||||||
|
|
||||||
This package puts the corepack wrappers for pnpm and yarn in your PATH, and they will honor the `packageManager` setting in the `package.json`.
|
This package puts the corepack wrappers for pnpm and yarn in your PATH, and they will honor the `packageManager` setting in the `package.json`.
|
||||||
|
@ -16,9 +16,19 @@ npmInstallHook() {
|
|||||||
cp "${npmWorkspace-.}/$file" "$dest"
|
cp "${npmWorkspace-.}/$file" "$dest"
|
||||||
done < <(@jq@ --raw-output '.[0].files | map(.path) | join("\n")' <<< "$(npm pack --json --dry-run ${npmWorkspace+--workspace=$npmWorkspace} $npmPackFlags "${npmPackFlagsArray[@]}" $npmFlags "${npmFlagsArray[@]}")")
|
done < <(@jq@ --raw-output '.[0].files | map(.path) | join("\n")' <<< "$(npm pack --json --dry-run ${npmWorkspace+--workspace=$npmWorkspace} $npmPackFlags "${npmPackFlagsArray[@]}" $npmFlags "${npmFlagsArray[@]}")")
|
||||||
|
|
||||||
|
# Based on code from Python's buildPythonPackage wrap.sh script, for
|
||||||
|
# supporting both the case when makeWrapperArgs is an array and a
|
||||||
|
# IFS-separated string.
|
||||||
|
#
|
||||||
|
# TODO: remove the string branch when __structuredAttrs are used.
|
||||||
|
if [[ "${makeWrapperArgs+defined}" == "defined" && "$(declare -p makeWrapperArgs)" =~ ^'declare -a makeWrapperArgs=' ]]; then
|
||||||
|
local -a user_args=("${makeWrapperArgs[@]}")
|
||||||
|
else
|
||||||
|
local -a user_args="(${makeWrapperArgs:-})"
|
||||||
|
fi
|
||||||
while IFS=" " read -ra bin; do
|
while IFS=" " read -ra bin; do
|
||||||
mkdir -p "$out/bin"
|
mkdir -p "$out/bin"
|
||||||
makeWrapper @hostNode@ "$out/bin/${bin[0]}" --add-flags "$packageOut/${bin[1]}"
|
makeWrapper @hostNode@ "$out/bin/${bin[0]}" --add-flags "$packageOut/${bin[1]}" "${user_args[@]}"
|
||||||
done < <(@jq@ --raw-output '(.bin | type) as $typ | if $typ == "string" then
|
done < <(@jq@ --raw-output '(.bin | type) as $typ | if $typ == "string" then
|
||||||
.name + " " + .bin
|
.name + " " + .bin
|
||||||
elif $typ == "object" then .bin | to_entries | map(.key + " " + .value) | join("\n")
|
elif $typ == "object" then .bin | to_entries | map(.key + " " + .value) | join("\n")
|
||||||
|
Loading…
Reference in New Issue
Block a user