/** * Copyright 2006 by Know-Center, Graz, Austria * PDF-AS has been contracted by the E-Government Innovation Center EGIZ, a * joint initiative of the Federal Chancellery Austria and Graz University of * Technology. * * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by * the European Commission - subsequent versions of the EUPL (the "Licence"); * You may not use this work except in compliance with the Licence. * You may obtain a copy of the Licence at: * http://www.osor.eu/eupl/ * * Unless required by applicable law or agreed to in writing, software * distributed under the Licence is distributed on an "AS IS" basis, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the Licence for the specific language governing permissions and * limitations under the Licence. * * This product combines work with different licenses. See the "NOTICE" text * file for details on the various modules and licenses. * The "NOTICE" text file is part of the distribution. Any derivative works * that you distribute must include a readable copy of the "NOTICE" text file. */ package at.gv.egiz.pdfas.framework.input; import java.io.InputStream; /** * The input document data source. * *

* Usually this is a PdfDataSource, but it may be a TextDataSource as well. *

* * @author wprinz * */ public interface DataSource { /** * Creates a new InputStream that allows to read out the document's binary * data from the beginning. * * @return Returns the InputStream with the binary data. */ public InputStream createInputStream(); /** * Returns the length (number of bytes) of the stream. * * @return Returns the length (number of bytes) of the stream. */ public int getLength(); /** * Returns the data of this DataSource as a byte array. * *

* Calling this method indicates that you need a byte array for random read access. * The DataSource implementation should of course cache this byte array to avoid too much memory usage. *

*

* Performance analysis has shown that the libraries internally convert the streams to byte arrays and * that file system access is very slow. *

* * @return */ public byte [] getAsByteArray(); }