mirror of
https://github.com/NixOS/nix.git
synced 2025-11-24 11:19:35 +01:00
Similar to the deepSeq fix, toJSON on deeply nested structures caused an uncontrolled OS-level stack overflow. Fix by adding call depth tracking to printValueAsJSON.
54 lines
2.4 KiB
Text
54 lines
2.4 KiB
Text
error:
|
|
… while evaluating the attribute 'outPath'
|
|
at «nix-internal»/derivation-internal.nix:50:7:
|
|
49| value = commonAttrs // {
|
|
50| outPath = builtins.getAttr outputName strict;
|
|
| ^
|
|
51| drvPath = strict.drvPath;
|
|
|
|
… while calling the 'getAttr' builtin
|
|
at «nix-internal»/derivation-internal.nix:50:17:
|
|
49| value = commonAttrs // {
|
|
50| outPath = builtins.getAttr outputName strict;
|
|
| ^
|
|
51| drvPath = strict.drvPath;
|
|
|
|
… while calling the 'derivationStrict' builtin
|
|
at «nix-internal»/derivation-internal.nix:37:12:
|
|
36|
|
|
37| strict = derivationStrict drvAttrs;
|
|
| ^
|
|
38|
|
|
|
|
… while evaluating derivation 'test'
|
|
whose name attribute is located at /pwd/lang/eval-fail-derivation-structuredAttrs-stack-overflow.nix:5:3
|
|
|
|
… while evaluating attribute 'nested' of derivation 'test'
|
|
at /pwd/lang/eval-fail-derivation-structuredAttrs-stack-overflow.nix:9:3:
|
|
8| __structuredAttrs = true;
|
|
9| nested =
|
|
| ^
|
|
10| let
|
|
|
|
… while evaluating attribute 'tail'
|
|
at /pwd/lang/eval-fail-derivation-structuredAttrs-stack-overflow.nix:12:71:
|
|
11| long = builtins.genList (x: x) 100000;
|
|
12| reverseLinkedList = builtins.foldl' (tail: head: { inherit head tail; }) null long;
|
|
| ^
|
|
13| in
|
|
|
|
(9994 duplicate frames omitted)
|
|
|
|
… while evaluating attribute 'head'
|
|
at /pwd/lang/eval-fail-derivation-structuredAttrs-stack-overflow.nix:12:66:
|
|
11| long = builtins.genList (x: x) 100000;
|
|
12| reverseLinkedList = builtins.foldl' (tail: head: { inherit head tail; }) null long;
|
|
| ^
|
|
13| in
|
|
|
|
error: stack overflow; max-call-depth exceeded
|
|
at /pwd/lang/eval-fail-derivation-structuredAttrs-stack-overflow.nix:12:66:
|
|
11| long = builtins.genList (x: x) 100000;
|
|
12| reverseLinkedList = builtins.foldl' (tail: head: { inherit head tail; }) null long;
|
|
| ^
|
|
13| in
|