haskellPackages.callPackage: preserve functionArgs (#443442)
This commit is contained in:
@@ -107,14 +107,17 @@ let
|
|||||||
# is that nix has no way to "passthrough" args while preserving the reflection
|
# is that nix has no way to "passthrough" args while preserving the reflection
|
||||||
# info that callPackage uses to determine the arguments).
|
# info that callPackage uses to determine the arguments).
|
||||||
drv = if lib.isFunction fn then fn else import fn;
|
drv = if lib.isFunction fn then fn else import fn;
|
||||||
auto = builtins.intersectAttrs (lib.functionArgs drv) scope;
|
drvFunctionArgs = lib.functionArgs drv;
|
||||||
|
auto = builtins.intersectAttrs drvFunctionArgs scope;
|
||||||
|
|
||||||
# Converts a returned function to a functor attribute set if necessary
|
# Converts a returned function to a functor attribute set if necessary
|
||||||
ensureAttrs = v: if builtins.isFunction v then { __functor = _: v; } else v;
|
ensureAttrs = v: if builtins.isFunction v then { __functor = _: v; } else v;
|
||||||
|
|
||||||
# this wraps the `drv` function to add `scope` and `overrideScope` to the result.
|
# this wraps the `drv` function to add `scope` and `overrideScope` to the result.
|
||||||
drvScope =
|
# it's a functor, so that we can pass through `functionArgs`
|
||||||
allArgs:
|
drvScope = {
|
||||||
|
__functor =
|
||||||
|
_: allArgs:
|
||||||
ensureAttrs (drv allArgs)
|
ensureAttrs (drv allArgs)
|
||||||
// {
|
// {
|
||||||
inherit scope;
|
inherit scope;
|
||||||
@@ -130,6 +133,9 @@ let
|
|||||||
# nothing.
|
# nothing.
|
||||||
callPackageWithScope newScope drv manualArgs;
|
callPackageWithScope newScope drv manualArgs;
|
||||||
};
|
};
|
||||||
|
# `drvScope` accepts the same arguments as `drv`
|
||||||
|
__functionArgs = drvFunctionArgs;
|
||||||
|
};
|
||||||
in
|
in
|
||||||
lib.makeOverridable drvScope (auto // manualArgs);
|
lib.makeOverridable drvScope (auto // manualArgs);
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user