diff --git a/pmd-core/src/main/java/net/sourceforge/pmd/cpd/XMLRenderer.java b/pmd-core/src/main/java/net/sourceforge/pmd/cpd/XMLRenderer.java index 5390e9410f..3cb2ead41b 100644 --- a/pmd-core/src/main/java/net/sourceforge/pmd/cpd/XMLRenderer.java +++ b/pmd-core/src/main/java/net/sourceforge/pmd/cpd/XMLRenderer.java @@ -77,6 +77,7 @@ public final class XMLRenderer implements Renderer, CPDRenderer { try { TransformerFactory tf = TransformerFactory.newInstance(); Transformer transformer = tf.newTransformer(); + transformer.setOutputProperty(OutputKeys.VERSION, "1.0"); transformer.setOutputProperty(OutputKeys.METHOD, "xml"); transformer.setOutputProperty(OutputKeys.ENCODING, encoding); transformer.setOutputProperty(OutputKeys.INDENT, "yes"); @@ -120,7 +121,8 @@ public final class XMLRenderer implements Renderer, CPDRenderer { mark = iterator.next(); final Element file = doc.createElement("file"); file.setAttribute("line", String.valueOf(mark.getBeginLine())); - file.setAttribute("path", mark.getFilename()); + String filenameXml10 = StringEscapeUtils.unescapeXml(StringEscapeUtils.escapeXml10(mark.getFilename())); + file.setAttribute("path", filenameXml10); file.setAttribute("endline", String.valueOf(mark.getEndLine())); final int beginCol = mark.getBeginColumn(); final int endCol = mark.getEndColumn(); diff --git a/pmd-core/src/test/java/net/sourceforge/pmd/cpd/XMLRendererTest.java b/pmd-core/src/test/java/net/sourceforge/pmd/cpd/XMLRendererTest.java index a7ddbb5474..d5340d2c67 100644 --- a/pmd-core/src/test/java/net/sourceforge/pmd/cpd/XMLRendererTest.java +++ b/pmd-core/src/test/java/net/sourceforge/pmd/cpd/XMLRendererTest.java @@ -31,6 +31,9 @@ import net.sourceforge.pmd.cpd.renderer.CPDRenderer; public class XMLRendererTest { private static final String ENCODING = (String) System.getProperties().get("file.encoding"); + private static final String FORM_FEED = "\u000C"; // this character is invalid in XML 1.0 documents + private static final String FORM_FEED_ENTITY = " "; // this is also not allowed in XML 1.0 documents + @Test public void testWithNoDuplication() throws IOException { @@ -186,8 +189,8 @@ public class XMLRendererTest { CPDRenderer renderer = new XMLRenderer(); List list = new ArrayList<>(); final String espaceChar = "<"; - Mark mark1 = createMark("public", "/var/F" + '<' + "oo.java", 48, 6, "code fragment"); - Mark mark2 = createMark("void", "/var/F list = new ArrayList<>(); Mark mark1 = createMark("public", "file1", 1, 2, codefragment); @@ -211,7 +215,8 @@ public class XMLRendererTest { StringWriter sw = new StringWriter(); renderer.render(list.iterator(), sw); String report = sw.toString(); - assertFalse(report.contains(formfeed)); + assertFalse(report.contains(FORM_FEED)); + assertFalse(report.contains(FORM_FEED_ENTITY)); } private Mark createMark(String image, String tokenSrcID, int beginLine, int lineCount, String code) {