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

htsjdk.samtools.seekablestream.ISeekableStreamFactory Maven / Gradle / Ivy

There is a newer version: 4.1.3
Show newest version
package htsjdk.samtools.seekablestream;

import java.io.IOException;
import java.net.URL;
import java.nio.channels.SeekableByteChannel;
import java.util.function.Function;

/**
 * Factory for creating {@link SeekableStream}s based on URLs/paths.
 * Implementations can be set as the default with {@link SeekableStreamFactory#setInstance(ISeekableStreamFactory)}
 * @author jacob
 * @date 2013-Oct-24
 */
public interface ISeekableStreamFactory {

    public SeekableStream getStreamFor(URL url) throws IOException;

    public SeekableStream getStreamFor(String path) throws IOException;

    /**
     * Return a buffered {@code SeekableStream} which wraps the input {@code stream}
     * using the default buffer size
     * @param stream
     * @return
     */
    public SeekableStream getBufferedStream(SeekableStream stream);

    /**
     * Return a buffered {@code SeekableStream} which wraps the input {@code stream}
     * @param stream
     * @param bufferSize
     * @return
     */
    public SeekableStream getBufferedStream(SeekableStream stream, int bufferSize);

    /**
     * Open a stream from the input path, applying the wrapper to the stream.
     *
     * The wrapper allows applying operations directly to the byte stream so that things like caching, prefetching, or decryption
     * can be done at the raw byte level.
     *
     * The default implementation throws if wrapper != null, but implementations may support this wrapping operation
     *
     * @param path    a uri like String representing a resource to open
     * @param wrapper a wrapper to apply to the stream
     * @return a stream opened path
     */
    default SeekableStream getStreamFor(String path, Function wrapper) throws IOException {
        if(wrapper != null) {
            throw new UnsupportedOperationException("This factory doesn't support adding wrappers");
        } else {
            return this.getStreamFor(path);
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy