X-Git-Url: http://jaekl.net/gitweb/?a=blobdiff_plain;f=prod%2Fnet%2Fjaekl%2Fcfb%2Fxml%2FBugClass.java;h=99a561f9bb0a24e66ddff1ba48826f2deca938bf;hb=7ac6be132ecd6872971a1de56f033b4434d3173a;hp=eb2c5929347c5c108331286f6362e76d3097a3c1;hpb=a938b67bf3d3bd86f8dd7b1f958e81007bf6f2fe;p=cfb.git diff --git a/prod/net/jaekl/cfb/xml/BugClass.java b/prod/net/jaekl/cfb/xml/BugClass.java index eb2c592..99a561f 100644 --- a/prod/net/jaekl/cfb/xml/BugClass.java +++ b/prod/net/jaekl/cfb/xml/BugClass.java @@ -1,9 +1,11 @@ package net.jaekl.cfb.xml; +import java.io.PrintWriter; import java.util.ArrayList; import org.xml.sax.Attributes; +import net.jaekl.qd.xml.MissingAttributeException; import net.jaekl.qd.xml.ParseResult; import net.jaekl.qd.xml.XmlParseException; @@ -16,18 +18,27 @@ public class BugClass extends ParseResult { static final String CLASS_NAME = "classname"; String m_className; - ArrayList m_sourceLines; + ArrayList m_lines; public BugClass() { super(TAG, INTERNAL, EXTERNAL); m_className = ""; + m_lines = new ArrayList(); + } + + public String getClassName() { return m_className; } + public SourceLine[] getSourceLines() { return m_lines.toArray(new SourceLine[m_lines.size()]); } + + @Override + public void handleMainAttributes(Attributes attr) throws MissingAttributeException + { + m_className = getRequiredAttr(TAG, attr, CLASS_NAME); } @Override - public void endContents(String uri, String localName, String qName, String chars, Attributes attr) + public void endContents(String uri, String localName, String qName, String chars) throws XmlParseException { - m_className = getRequiredAttr(TAG, attr, CLASS_NAME); } @Override @@ -38,8 +49,22 @@ public class BugClass extends ParseResult { ParseResult[] collected = collectParsedChildren(SourceLine.class); for (ParseResult pr : collected) { assert(pr instanceof SourceLine); - m_sourceLines.add((SourceLine)pr); + m_lines.add((SourceLine)pr); } } } + + @Override + public void dump(PrintWriter pw, int indent) + { + super.dump(pw, indent); + String tab = String.format("%" + (indent + 2) + "s", ""); + + pw.println(tab + CLASS_NAME + "=" + m_className); + if (null != m_lines) { + for (SourceLine sl : m_lines) { + sl.dump(pw, indent + 2); + } + } + } }