mirror of
https://github.com/NixOS/nix
synced 2025-06-26 07:31:15 +02:00
Get rid of some unnecessary ExprConcatStrings nodes in dynamic attrs
This gives a ~18% speedup in NixOS evaluation (after converting most calls to hasAttr/getAttr to dynamic attrs).
This commit is contained in:
parent
1418806969
commit
b6809608cc
3 changed files with 18 additions and 25 deletions
|
@ -701,13 +701,10 @@ void ExprAttrs::eval(EvalState & state, Env & env, Value & v)
|
|||
/* Dynamic attrs apply *after* rec and __overrides. */
|
||||
foreach (DynamicAttrDefs::iterator, i, dynamicAttrs) {
|
||||
Value nameVal;
|
||||
if (i->nameExpr->es->size() == 1) {
|
||||
i->nameExpr->es->front()->eval(state, *dynamicEnv, nameVal);
|
||||
state.forceValue(nameVal);
|
||||
if (nameVal.type == tNull)
|
||||
continue;
|
||||
}
|
||||
i->nameExpr->eval(state, *dynamicEnv, nameVal);
|
||||
state.forceValue(nameVal);
|
||||
if (nameVal.type == tNull)
|
||||
continue;
|
||||
state.forceStringNoCtx(nameVal);
|
||||
Symbol nameSym = state.symbols.create(nameVal.string.s);
|
||||
Bindings::iterator j = v.attrs->find(nameSym);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue