X-Git-Url: https://gitweb.fperrin.net/?p=GpsPrune.git;a=blobdiff_plain;f=tim%2Fprune%2Fload%2Fxml%2FXmlFileLoader.java;h=d528420029a325f8cfc33238de6c80b5c55ef8cc;hp=4170dc9b747b9e4380d1832b156393b68a238743;hb=6814c830d470f73c7ec57c71235de333f5ea4279;hpb=140e9d165f85c3d4f0435a311e091209313faa2a diff --git a/tim/prune/load/xml/XmlFileLoader.java b/tim/prune/load/xml/XmlFileLoader.java index 4170dc9..d528420 100644 --- a/tim/prune/load/xml/XmlFileLoader.java +++ b/tim/prune/load/xml/XmlFileLoader.java @@ -1,6 +1,8 @@ package tim.prune.load.xml; import java.io.File; +import java.io.FileInputStream; + import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParserFactory; @@ -61,11 +63,13 @@ public class XmlFileLoader extends DefaultHandler implements Runnable */ public void run() { + FileInputStream inStream = null; try { // Construct a SAXParser and use this as a default handler SAXParser saxParser = SAXParserFactory.newInstance().newSAXParser(); - saxParser.parse(_file, this); + inStream = new FileInputStream(_file); + saxParser.parse(inStream, this); // Check whether handler was properly instantiated if (_handler == null) @@ -85,6 +89,11 @@ public class XmlFileLoader extends DefaultHandler implements Runnable } catch (Exception e) { + // clean up file stream + try { + inStream.close(); + } + catch (Exception e2) {} // Show error dialog _app.showErrorMessageNoLookup("error.load.dialogtitle", I18nManager.getText("error.load.othererror") + " " + e.getMessage());