All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.amazon.ion.IonLoader Maven / Gradle / Ivy

/*
 * 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;

import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.io.Reader;


/**
 * Loads Ion data in the form of datagrams.  These methods parse the input in
 * its entirety to identify problems immediately.  In contrast, an
 * {@link IonReader} will parse one top-level value at a time, and is better
 * suited for streaming protocols or large inputs.
 * 

* WARNING: This interface should not be implemented or extended by * code outside of this library. *

* Implementations of this interface are safe for use by multiple * threads. * * @see IonReader */ public interface IonLoader { /** * Gets the {@link IonSystem} from which this loader was created. * * @return the system instance; not null. */ public IonSystem getSystem(); /** * Gets the {@link IonCatalog} being used by this loader. * * @return a catalog; not null. */ public IonCatalog getCatalog(); /** * Loads an entire file of Ion data into a single datagram, * detecting whether it's text or binary data. * * @param ionFile a file containing Ion data. * * @return a datagram containing all the values in the file; not null. * * @throws IonException if there's a syntax error in the Ion content. * @throws IOException if reading from the specified file results * in an IOException. */ public IonDatagram load(File ionFile) throws IonException, IOException; /** * Loads Ion text in its entirety. * * @param ionText must not be null. * * @return a datagram containing the input values; not null. * * @throws NullPointerException if ionText is null. * @throws IonException if there's a syntax error in the Ion content. */ public IonDatagram load(String ionText) throws IonException; /** * Loads a stream of Ion text into a single datagram. *

* The specified reader remains open after this method returns. *

* Because this library performs its own buffering, it's recommended that * you avoid adding additional buffering to the given stream. * * @param ionText the reader from which to read Ion text. * * @return a datagram containing all the elements on the input stream; * not null. * * @throws NullPointerException if ionText is null. * @throws IonException if there's a syntax error in the Ion content. * @throws IOException if reading from the specified input stream results * in an IOException. */ public IonDatagram load(Reader ionText) throws IonException, IOException; /** * Loads a block of Ion data into a single datagram, * detecting whether it's text or binary data. *

* This method will auto-detect and uncompress GZIPped Ion data. * * @param ionData may be either Ion binary data, or UTF-8 Ion text. * This method assumes ownership of the array and may modify it at * will. * * @return a datagram containing all the values on the input stream; * not null. * * @throws NullPointerException if ionData is null. * @throws IonException if there's a syntax error in the Ion content. */ public IonDatagram load(byte[] ionData) throws IonException; /** *

* WARNING: Will cause a memory leak when reading a gzipped stream, use * {@link IonLoader#load(IonReader)} instead. *

* * Loads an entire stream of Ion data into a single datagram, * detecting whether it's text or binary data. *

* The specified stream remains open after this method returns. *

* This method will auto-detect and uncompress GZIPped Ion data. *

* Because this library performs its own buffering, it's recommended that * you avoid adding additional buffering to the given stream. * * @param ionData the stream from which to read Ion data. * * @return a datagram containing all the values on the input stream; * not null. * * @throws NullPointerException if ionData is null. * @throws IonException if there's a syntax error in the Ion content. * @throws IOException if reading from the specified input stream results * in an IOException. * * @deprecated Will cause a memory leak when reading a gzipped stream. * Use {@link IonLoader#load(IonReader)} instead. */ @Deprecated public IonDatagram load(InputStream ionData) throws IonException, IOException; /** * Loads an entire stream of Ion data into a single datagram, * detecting whether it's text or binary data. *

* The specified reader remains open after this method returns. *

* * @param reader @param reader source of the Ion data to load. * * @return a datagram containing all the values on the reader; not null. * * @throws NullPointerException if reader is null. * @throws IonException if there's a syntax error in the Ion content. */ public IonDatagram load(IonReader reader) throws IonException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy