diff --git a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/Parser.java b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/Parser.java index b2832cb399b..2c8d669d08a 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/Parser.java +++ b/src/utils/IdealGraphVisualizer/Data/src/main/java/com/sun/hotspot/igv/data/serialization/Parser.java @@ -34,6 +34,7 @@ import java.nio.channels.Channels; import java.nio.channels.ReadableByteChannel; import java.util.ArrayList; import java.util.HashMap; +import java.util.Locale; import java.util.Map; import javax.swing.SwingUtilities; import javax.xml.parsers.ParserConfigurationException; @@ -529,6 +530,8 @@ public class Parser implements GraphParser { } try { XMLReader reader = createReader(); + // To enforce using English for non-English users, we must use Locale.ROOT rather than Locale.ENGLISH + reader.setProperty("http://apache.org/xml/properties/locale", Locale.ROOT); reader.setContentHandler(new XMLParser(xmlDocument, monitor)); reader.parse(new InputSource(Channels.newInputStream(channel))); } catch (SAXException ex) { diff --git a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/serialization/ParserTest.java b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/serialization/ParserTest.java index c6b36d07c6d..10ff3966fab 100644 --- a/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/serialization/ParserTest.java +++ b/src/utils/IdealGraphVisualizer/Data/src/test/java/com/sun/hotspot/igv/data/serialization/ParserTest.java @@ -222,4 +222,10 @@ public class ParserTest { testBoth(new GraphDocument(), ""); } + @Test + public void testParseIncompleteXML() { + // Exception should be swallowed, see catch clause in GraphParser.parse. + testBoth(new GraphDocument(), ""); + } + }