forked from lix-project/lix
Add source location information to the XML output.
* src/libexpr/expr-to-xml.cc (nix::showAttrs): Dereference the attribute RHS. Add "path", "line", and "column" XML attributes to the node when source location information is available. (nix::printTermAsXML): Likewise for functions.
This commit is contained in:
parent
eb07a4f1ee
commit
471419d1fa
1 changed files with 33 additions and 5 deletions
|
@ -34,8 +34,25 @@ static void showAttrs(const ATermMap & attrs, XMLWriter & doc,
|
||||||
for (ATermMap::const_iterator i = attrs.begin(); i != attrs.end(); ++i)
|
for (ATermMap::const_iterator i = attrs.begin(); i != attrs.end(); ++i)
|
||||||
names.insert(aterm2String(i->key));
|
names.insert(aterm2String(i->key));
|
||||||
for (StringSet::iterator i = names.begin(); i != names.end(); ++i) {
|
for (StringSet::iterator i = names.begin(); i != names.end(); ++i) {
|
||||||
XMLOpenElement _(doc, "attr", singletonAttrs("name", *i));
|
ATerm attrRHS = attrs.get(toATerm(*i));
|
||||||
printTermAsXML(attrs.get(toATerm(*i)), doc, context, drvsSeen);
|
ATerm attr;
|
||||||
|
Pos pos;
|
||||||
|
XMLAttrs xmlAttrs;
|
||||||
|
|
||||||
|
xmlAttrs["name"] = *i;
|
||||||
|
if(matchAttrRHS(attrRHS, attr, pos)) {
|
||||||
|
ATerm path;
|
||||||
|
int line, column;
|
||||||
|
if (matchPos(pos, path, line, column)) {
|
||||||
|
xmlAttrs["path"] = aterm2String(path);
|
||||||
|
xmlAttrs["line"] = (format("%1%") % line).str();
|
||||||
|
xmlAttrs["column"] = (format("%1%") % column).str();
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
abort(); // Should not happen.
|
||||||
|
|
||||||
|
XMLOpenElement _(doc, "attr", xmlAttrs);
|
||||||
|
printTermAsXML(attr, doc, context, drvsSeen);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -97,9 +114,12 @@ static void printTermAsXML(Expr e, XMLWriter & doc, PathSet & context,
|
||||||
|
|
||||||
else if (matchAttrs(e, as)) {
|
else if (matchAttrs(e, as)) {
|
||||||
ATermMap attrs;
|
ATermMap attrs;
|
||||||
queryAllAttrs(e, attrs);
|
queryAllAttrs(e, attrs, true);
|
||||||
|
|
||||||
Expr a = attrs.get(toATerm("type"));
|
Expr aRHS = attrs.get(toATerm("type"));
|
||||||
|
Expr a = NULL;
|
||||||
|
if (aRHS)
|
||||||
|
matchAttrRHS(aRHS, a, pos);
|
||||||
if (a && matchStr(a, s, context) && s == "derivation") {
|
if (a && matchStr(a, s, context) && s == "derivation") {
|
||||||
|
|
||||||
XMLAttrs xmlAttrs;
|
XMLAttrs xmlAttrs;
|
||||||
|
@ -135,7 +155,15 @@ static void printTermAsXML(Expr e, XMLWriter & doc, PathSet & context,
|
||||||
}
|
}
|
||||||
|
|
||||||
else if (matchFunction(e, pat, body, pos)) {
|
else if (matchFunction(e, pat, body, pos)) {
|
||||||
XMLOpenElement _(doc, "function");
|
ATerm path;
|
||||||
|
int line, column;
|
||||||
|
XMLAttrs xmlAttrs;
|
||||||
|
if (matchPos(pos, path, line, column)) {
|
||||||
|
xmlAttrs["path"] = aterm2String(path);
|
||||||
|
xmlAttrs["line"] = (format("%1%") % line).str();
|
||||||
|
xmlAttrs["column"] = (format("%1%") % column).str();
|
||||||
|
}
|
||||||
|
XMLOpenElement _(doc, "function", xmlAttrs);
|
||||||
printPatternAsXML(pat, doc);
|
printPatternAsXML(pat, doc);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue