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

org.opentripplanner.datastore.base.ByteArrayDataSource Maven / Gradle / Ivy

There is a newer version: 2.6.0
Show newest version
package org.opentripplanner.datastore.base;

import org.opentripplanner.datastore.DataSource;
import org.opentripplanner.datastore.FileType;

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.InputStream;
import java.io.OutputStream;


/**
 * This data source keep its data in memory as a byte array. You may insert data using
 * {@link #withBytes(byte[])} or {@link #asOutputStream()}. To access data you can use the
 * {@link #asBytes()} or reading the input stream {@link #asInputStream()}.
 * 

* Any existing data in the datasource will be erased if you insert data using the output stream * {@link #asOutputStream()} or set the byte array {@link #withBytes(byte[])}. */ public class ByteArrayDataSource implements DataSource { private final String path; private final String name; private final FileType type; private final long size; private final long lastModified; private final boolean writable; private ByteArrayOutputStream out = null; private byte[] buffer; ByteArrayDataSource( String path, String name, FileType type, long size, long lastModified, boolean writable ) { this.path = path; this.name = name; this.type = type; this.size = size; this.lastModified = lastModified; this.writable = writable; } @Override public String name() { return name; } @Override public String path() { return path; } @Override public FileType type() { return type; } @Override public long size() { return size; } @Override public long lastModified() { return lastModified; } @Override public boolean isWritable() { return writable; } /** * Return the internal byte array as an {@link InputStream}. A new input stream is generated for * each call to this method, and it is safe to do so. */ @Override public InputStream asInputStream() { return new ByteArrayInputStream(asBytes()); } @Override public byte[] asBytes() { return buffer == null ? out.toByteArray() : buffer; } /** * Clean any existing data, and return a new {@link OutputStream} witch can be used to insert * data into the byte array. *

* If the source is created with {@code writable = false} then the {@link #asOutputStream()} * will throw an exception, instead use the {@link #withBytes(byte[])} to inject data. */ @Override public OutputStream asOutputStream() { if(!writable) { throw new UnsupportedOperationException( "This datasource type " + type() + " do not support WRITING. Can not write to: " + path() ); } if (out == null) { out = new ByteArrayOutputStream(1024); buffer = null; } return out; } @Override public String toString() { return type + " " + path(); } /** * Clean any existing data, and set the byte array. */ ByteArrayDataSource withBytes(byte[] buffer) { this.buffer = buffer; this.out = null; return this; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy