mirror of
https://github.com/NixOS/nix
synced 2025-06-26 11:41:15 +02:00
* Simplify @-patterns: only {attrs}@name' or
name@{attrs}' are now
allowed. So `name1@name2', `{attrs1}@{attrs2}' and so on are now no longer legal. This is no big loss because they were not useful anyway. This also changes the output of builtins.toXML for @-patterns slightly.
This commit is contained in:
parent
7482349fe8
commit
8a10360c91
13 changed files with 83 additions and 173 deletions
|
@ -85,16 +85,17 @@ static void patternMatch(EvalState & state,
|
|||
{
|
||||
ATerm name;
|
||||
ATermList formals;
|
||||
Pattern pat1, pat2;
|
||||
ATermBool ellipsis;
|
||||
|
||||
if (matchVarPat(pat, name))
|
||||
subs.set(name, arg);
|
||||
|
||||
else if (matchAttrsPat(pat, formals, ellipsis)) {
|
||||
else if (matchAttrsPat(pat, formals, ellipsis, name)) {
|
||||
|
||||
arg = evalExpr(state, arg);
|
||||
|
||||
if (name != sNoAlias) subs.set(name, arg);
|
||||
|
||||
/* Get the actual arguments. */
|
||||
ATermMap attrs;
|
||||
queryAllAttrs(arg, attrs);
|
||||
|
@ -131,11 +132,6 @@ static void patternMatch(EvalState & state,
|
|||
% aterm2String(attrs.begin()->key));
|
||||
}
|
||||
|
||||
else if (matchAtPat(pat, pat1, pat2)) {
|
||||
patternMatch(state, pat1, arg, subs, subsRecursive);
|
||||
patternMatch(state, pat2, arg, subs, subsRecursive);
|
||||
}
|
||||
|
||||
else abort();
|
||||
}
|
||||
|
||||
|
@ -425,12 +421,11 @@ Path coerceToPath(EvalState & state, Expr e, PathSet & context)
|
|||
Expr autoCallFunction(Expr e, const ATermMap & args)
|
||||
{
|
||||
Pattern pat;
|
||||
ATerm body, pos;
|
||||
ATerm body, pos, name;
|
||||
ATermList formals;
|
||||
ATermBool ellipsis;
|
||||
|
||||
/* !!! this should be more general */
|
||||
if (matchFunction(e, pat, body, pos) && matchAttrsPat(pat, formals, ellipsis)) {
|
||||
if (matchFunction(e, pat, body, pos) && matchAttrsPat(pat, formals, ellipsis, name)) {
|
||||
ATermMap actualArgs(ATgetLength(formals));
|
||||
|
||||
for (ATermIterator i(formals); i; ++i) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue