use reader instead of xmlsource to read configuration entry stores

This commit is contained in:
Sebastian Sdorra
2013-06-20 18:33:24 +02:00
parent 18c1c5ed01
commit a504ddf543

View File

@@ -30,10 +30,12 @@
*/ */
package sonia.scm.store; package sonia.scm.store;
//~--- non-JDK imports -------------------------------------------------------- //~--- non-JDK imports --------------------------------------------------------
import com.google.common.base.Charsets;
import com.google.common.base.Predicate; import com.google.common.base.Predicate;
import com.google.common.collect.Collections2; import com.google.common.collect.Collections2;
import com.google.common.collect.Maps; import com.google.common.collect.Maps;
@@ -47,7 +49,13 @@ import sonia.scm.xml.IndentXMLStreamWriter;
//~--- JDK imports ------------------------------------------------------------ //~--- JDK imports ------------------------------------------------------------
import java.io.File; import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream; import java.io.FileOutputStream;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.io.Reader;
import java.io.Writer;
import java.util.Collection; import java.util.Collection;
import java.util.Collections; import java.util.Collections;
@@ -65,7 +73,6 @@ import javax.xml.stream.XMLOutputFactory;
import javax.xml.stream.XMLStreamException; import javax.xml.stream.XMLStreamException;
import javax.xml.stream.XMLStreamReader; import javax.xml.stream.XMLStreamReader;
import javax.xml.stream.XMLStreamWriter; import javax.xml.stream.XMLStreamWriter;
import javax.xml.transform.stream.StreamSource;
/** /**
* *
@@ -294,6 +301,32 @@ public class JAXBConfigurationEntryStore<V>
} }
} }
/**
* Method description
*
*
* @return
*
* @throws FileNotFoundException
*/
private Reader createReader() throws FileNotFoundException
{
return new InputStreamReader(new FileInputStream(file), Charsets.UTF_8);
}
/**
* Method description
*
*
* @return
*
* @throws FileNotFoundException
*/
private Writer createWriter() throws FileNotFoundException
{
return new OutputStreamWriter(new FileOutputStream(file), Charsets.UTF_8);
}
/** /**
* Method description * Method description
* *
@@ -312,7 +345,7 @@ public class JAXBConfigurationEntryStore<V>
{ {
Unmarshaller u = context.createUnmarshaller(); Unmarshaller u = context.createUnmarshaller();
reader = xmlInputFactory.createXMLStreamReader(new StreamSource(file)); reader = xmlInputFactory.createXMLStreamReader(createReader());
reader.nextTag(); reader.nextTag();
reader.nextTag(); reader.nextTag();
@@ -357,7 +390,7 @@ public class JAXBConfigurationEntryStore<V>
//J- //J-
writer = new IndentXMLStreamWriter( writer = new IndentXMLStreamWriter(
XMLOutputFactory.newFactory().createXMLStreamWriter( XMLOutputFactory.newFactory().createXMLStreamWriter(
new FileOutputStream(file) createWriter()
) )
); );
//J+ //J+