com.amazon.ion.impl.lite.IonLoaderLite Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ion-java Show documentation
Show all versions of ion-java Show documentation
A Java implementation of the Amazon Ion data notation.
/*
* Copyright 2007-2019 Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* or in the "license" file accompanying this file. This file is distributed
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
package com.amazon.ion.impl.lite;
import com.amazon.ion.IonCatalog;
import com.amazon.ion.IonCursor;
import com.amazon.ion.IonDatagram;
import com.amazon.ion.IonException;
import com.amazon.ion.IonLoader;
import com.amazon.ion.IonReader;
import com.amazon.ion.IonSystem;
import com.amazon.ion.IonWriter;
import com.amazon.ion.impl._Private_IonWriterFactory;
import com.amazon.ion.system.IonReaderBuilder;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.Reader;
final class IonLoaderLite
implements IonLoader
{
private final IonSystemLite _system;
/** Not null. */
private final IonCatalog _catalog;
private final IonReaderBuilder _readerBuilder;
/**
* @param system must not be null.
* @param catalog must not be null.
*/
public IonLoaderLite(IonSystemLite system, IonCatalog catalog)
{
assert system != null;
assert catalog != null;
_system = system;
_catalog = catalog;
if (catalog == system.getCatalog()) {
_readerBuilder = system.getReaderBuilder();
} else {
// The IonCatalog provided in the constructor always takes precedence over the one already configured on the
// system's IonReaderBuilder.
_readerBuilder = system.getReaderBuilder().withCatalog(catalog).immutable();
}
}
public IonSystem getSystem()
{
return _system;
}
public IonCatalog getCatalog()
{
return _catalog;
}
/**
* This doesn't wrap IOException because some callers need to propagate it.
*
* @return a new datagram; not null.
*/
private IonDatagramLite load_helper(IonReader reader)
throws IOException
{
IonDatagramLite datagram = new IonDatagramLite(_system, _catalog);
IonWriter writer = _Private_IonWriterFactory.makeWriter(datagram);
writer.writeValues(reader);
if (_readerBuilder.isIncrementalReadingEnabled() && reader instanceof IonCursor) {
// Force incremental readers to either disambiguate an incomplete value or raise an error.
if (((IonCursor) reader).endStream() != IonCursor.Event.NEEDS_DATA) {
// Only text readers can reach this case, because it indicates that completion of an ambiguous token
// was forced. Add the resulting value to the datagram.
writer.writeValue(reader);
}
}
return datagram;
}
public IonDatagram load(File ionFile) throws IonException, IOException
{
InputStream ionData = new FileInputStream(ionFile);
try
{
IonDatagram datagram = load(ionData);
return datagram;
}
finally
{
ionData.close();
}
}
public IonDatagram load(String ionText) throws IonException
{
try {
IonReader reader = _readerBuilder.build(ionText);
IonDatagramLite datagram = load_helper(reader);
return datagram;
}
catch (IOException e) {
throw new IonException(e);
}
}
public IonDatagram load(Reader ionText) throws IonException, IOException
{
try {
IonReader reader = _readerBuilder.build(ionText);
IonDatagramLite datagram = load_helper(reader);
return datagram;
}
catch (IonException e) {
IOException io = e.causeOfType(IOException.class);
if (io != null) throw io;
throw e;
}
}
public IonDatagram load(byte[] ionData) throws IonException
{
IonReader reader = _readerBuilder.build(ionData, 0, ionData.length);
try {
return load(reader);
}
finally {
try {
reader.close();
}
catch (IOException e) {
throw new IonException(e);
}
}
}
public IonDatagram load(InputStream ionData)
throws IonException, IOException
{
try {
return load(_readerBuilder.build(ionData));
}
catch (IonException e) {
IOException io = e.causeOfType(IOException.class);
if (io != null) throw io;
throw e;
}
// Note: the reader cannot be closed, as this would close the InputStream, which was provided by the user.
}
public IonDatagram load(IonReader reader) throws IonException
{
try {
IonDatagramLite datagram = load_helper(reader);
return datagram;
}
catch (IOException e) {
throw new IonException(e);
}
}
}