From 049a379ec6ca755bcc077fd0e8da186ff76b8679 Mon Sep 17 00:00:00 2001 From: Shea Levy Date: Sun, 9 Mar 2014 14:41:02 -0400 Subject: [PATCH] The expr of AttrNames/DynamicAttrDefs is always an ExprConcatStrings --- src/libexpr/eval.cc | 8 +++----- src/libexpr/nixexpr.hh | 10 +++++----- src/libexpr/parser.y | 4 ++-- 3 files changed, 10 insertions(+), 12 deletions(-) diff --git a/src/libexpr/eval.cc b/src/libexpr/eval.cc index 730b431cf..04c3418a0 100644 --- a/src/libexpr/eval.cc +++ b/src/libexpr/eval.cc @@ -642,15 +642,13 @@ void ExprAttrs::eval(EvalState & state, Env & env, Value & v) /* dynamic attrs apply *after* rec and __overrides */ foreach (DynamicAttrDefs::iterator, i, dynamicAttrs) { Value nameVal; - assert(dynamic_cast(i->nameExpr)); - ExprConcatStrings * nameExpr = static_cast(i->nameExpr); - if (nameExpr->es->size() == 1) { - nameExpr->es->front()->eval(state, *dynamicEnv, nameVal); + if (i->nameExpr->es->size() == 1) { + i->nameExpr->es->front()->eval(state, *dynamicEnv, nameVal); state.forceValue(nameVal); if (nameVal.type == tNull) continue; } - nameExpr->eval(state, *dynamicEnv, nameVal); + i->nameExpr->eval(state, *dynamicEnv, nameVal); state.forceStringNoCtx(nameVal); Symbol nameSym = state.symbols.create(nameVal.string.s); Bindings::iterator j = v.attrs->find(nameSym); diff --git a/src/libexpr/nixexpr.hh b/src/libexpr/nixexpr.hh index 7586fffb8..a5c5d0533 100644 --- a/src/libexpr/nixexpr.hh +++ b/src/libexpr/nixexpr.hh @@ -50,16 +50,16 @@ struct Env; struct Value; class EvalState; struct StaticEnv; -struct Expr; +struct ExprConcatStrings; /* An attribute path is a sequence of attribute names. */ struct AttrName { Symbol symbol; - Expr *expr; + ExprConcatStrings * expr; AttrName(const Symbol & s) : symbol(s) {}; - AttrName(Expr *e) : expr(e) {}; + AttrName(ExprConcatStrings * e) : expr(e) {}; }; typedef std::vector AttrPath; @@ -174,10 +174,10 @@ struct ExprAttrs : Expr typedef std::map AttrDefs; AttrDefs attrs; struct DynamicAttrDef { - Expr * nameExpr; + ExprConcatStrings * nameExpr; Expr * valueExpr; Pos pos; - DynamicAttrDef(Expr * nameExpr, Expr * valueExpr, const Pos & pos) : nameExpr(nameExpr), valueExpr(valueExpr), pos(pos) { }; + DynamicAttrDef(ExprConcatStrings * nameExpr, Expr * valueExpr, const Pos & pos) : nameExpr(nameExpr), valueExpr(valueExpr), pos(pos) { }; }; typedef std::vector DynamicAttrDefs; DynamicAttrDefs dynamicAttrs; diff --git a/src/libexpr/parser.y b/src/libexpr/parser.y index dc995db00..ab0b86224 100644 --- a/src/libexpr/parser.y +++ b/src/libexpr/parser.y @@ -488,7 +488,7 @@ attrpath $$->push_back(AttrName(str->s)); delete str; } else - $$->push_back(AttrName($3)); + $$->push_back(AttrName(static_cast($3))); } | attr { $$ = new vector; $$->push_back(AttrName(data->symbols.create($1))); } | string_attr @@ -498,7 +498,7 @@ attrpath $$->push_back(AttrName(str->s)); delete str; } else - $$->push_back(AttrName($1)); + $$->push_back(AttrName(static_cast($1))); } ;