yarn2nix: add easy yarn & nodejs pkg overrides

Projects often require a specific major version of NodeJS, and sometimes
a specific yarn version. Since yarn2nix utilities are accessed from
nixpkgs now, there is no simple way to override versions of nodejs and
yarn without complex solutions like an overlay.

This adds `yarn` and `nodejs` as optional attribute arguments to
`mkYarnModules`, `mkYarnPackage`, and `mkYarnWorkspace`. They default to
the same versions that are currently being used, and the nodejs input to
yarn is overridden so that it will match if only `nodejs` is overridden
by the user.

These arguments will also cascade from `mkYarnWorkspace` ->
`mkYarnPackage` -> `mkYarnModules`, making per-package overrides very
simple.
This commit is contained in:
Mel Bourgeois 2022-11-12 19:36:51 -06:00
parent bdaf0a39fe
commit 31f7acfbb5
No known key found for this signature in database
GPG key ID: 290FCF081AEDB3EC

View file

@ -2,7 +2,7 @@
, nodejs ? pkgs.nodejs , nodejs ? pkgs.nodejs
, yarn ? pkgs.yarn , yarn ? pkgs.yarn
, allowAliases ? pkgs.config.allowAliases , allowAliases ? pkgs.config.allowAliases
}: }@inputs:
let let
inherit (pkgs) stdenv lib fetchurl linkFarm callPackage git rsync makeWrapper runCommandLocal; inherit (pkgs) stdenv lib fetchurl linkFarm callPackage git rsync makeWrapper runCommandLocal;
@ -70,6 +70,8 @@ in rec {
offlineCache ? importOfflineCache yarnNix, offlineCache ? importOfflineCache yarnNix,
yarnFlags ? [ ], yarnFlags ? [ ],
ignoreScripts ? true, ignoreScripts ? true,
nodejs ? inputs.nodejs,
yarn ? inputs.yarn.override { nodejs = nodejs; },
pkgConfig ? {}, pkgConfig ? {},
preBuild ? "", preBuild ? "",
postBuild ? "", postBuild ? "",
@ -169,6 +171,8 @@ in rec {
src, src,
packageJSON ? src + "/package.json", packageJSON ? src + "/package.json",
yarnLock ? src + "/yarn.lock", yarnLock ? src + "/yarn.lock",
nodejs ? inputs.nodejs,
yarn ? inputs.yarn.override { nodejs = nodejs; },
packageOverrides ? {}, packageOverrides ? {},
... ...
}@attrs: }@attrs:
@ -226,7 +230,7 @@ in rec {
inherit name; inherit name;
value = mkYarnPackage ( value = mkYarnPackage (
builtins.removeAttrs attrs ["packageOverrides"] builtins.removeAttrs attrs ["packageOverrides"]
// { inherit src packageJSON yarnLock packageResolutions workspaceDependencies; } // { inherit src packageJSON yarnLock nodejs yarn packageResolutions workspaceDependencies; }
// lib.attrByPath [name] {} packageOverrides // lib.attrByPath [name] {} packageOverrides
); );
}) })
@ -241,6 +245,8 @@ in rec {
yarnLock ? src + "/yarn.lock", yarnLock ? src + "/yarn.lock",
yarnNix ? mkYarnNix { inherit yarnLock; }, yarnNix ? mkYarnNix { inherit yarnLock; },
offlineCache ? importOfflineCache yarnNix, offlineCache ? importOfflineCache yarnNix,
nodejs ? inputs.nodejs,
yarn ? inputs.yarn.override { nodejs = nodejs; },
yarnFlags ? [ ], yarnFlags ? [ ],
yarnPreBuild ? "", yarnPreBuild ? "",
yarnPostBuild ? "", yarnPostBuild ? "",
@ -268,7 +274,7 @@ in rec {
preBuild = yarnPreBuild; preBuild = yarnPreBuild;
postBuild = yarnPostBuild; postBuild = yarnPostBuild;
workspaceDependencies = workspaceDependenciesTransitive; workspaceDependencies = workspaceDependenciesTransitive;
inherit packageJSON pname version yarnLock offlineCache yarnFlags pkgConfig packageResolutions; inherit packageJSON pname version yarnLock offlineCache nodejs yarn yarnFlags pkgConfig packageResolutions;
}; };
publishBinsFor_ = unlessNull publishBinsFor [pname]; publishBinsFor_ = unlessNull publishBinsFor [pname];