Catch eval errors in hasContent

`legacyPackages` of nixpkgs trigger eval errors in `hasContent`, causing
the whole `legacyPackages` being skipped. We should treat it as
has-content in that case.
This commit is contained in:
oxalica 2023-03-26 22:39:24 +08:00
parent e00abd3f56
commit 2941a599fa
2 changed files with 51 additions and 24 deletions

View file

@ -1026,6 +1026,7 @@ struct CmdFlakeShow : FlakeCommand, MixJSON
auto visitor2 = visitor.getAttr(attrName); auto visitor2 = visitor.getAttr(attrName);
try {
if ((attrPathS[0] == "apps" if ((attrPathS[0] == "apps"
|| attrPathS[0] == "checks" || attrPathS[0] == "checks"
|| attrPathS[0] == "devShells" || attrPathS[0] == "devShells"
@ -1056,6 +1057,12 @@ struct CmdFlakeShow : FlakeCommand, MixJSON
// If we don't recognize it, it's probably content // If we don't recognize it, it's probably content
return true; return true;
} catch (EvalError & e) {
// Some attrs may contain errors, eg. legacyPackages of
// nixpkgs. We still want to recurse into it, instead of
// skipping it at all.
return true;
}
}; };
std::function<nlohmann::json( std::function<nlohmann::json(

View file

@ -64,3 +64,23 @@ in
assert show_output == { }; assert show_output == { };
true true
' '
# Test that legacyPackages with errors are handled correctly.
cat >flake.nix <<EOF
{
outputs = inputs: {
legacyPackages.$system = {
AAAAAASomeThingsFailToEvaluate = throw "nooo";
simple = import ./simple.nix;
};
};
}
EOF
nix flake show --json --legacy --all-systems > show-output.json
nix eval --impure --expr '
let show_output = builtins.fromJSON (builtins.readFile ./show-output.json);
in
assert show_output.legacyPackages.${builtins.currentSystem}.AAAAAASomeThingsFailToEvaluate == { };
assert show_output.legacyPackages.${builtins.currentSystem}.simple.name == "simple";
true
'