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

de.schlichtherle.truezip.file.TFileInputStream Maven / Gradle / Ivy

Go to download

This module provides the TFile* classes for simple, uniform, transparent, thread-safe, read/write access to archive files as if they were virtual directories in a file system path. This module also provides Swing GUI classes for viewing file trees and choosing entries in archive files.

There is a newer version: 7.7.10
Show newest version
/*
 * Copyright (C) 2005-2015 Schlichtherle IT Services.
 * All rights reserved. Use is subject to license terms.
 */
package de.schlichtherle.truezip.file;

import de.schlichtherle.truezip.io.DecoratingInputStream;
import de.schlichtherle.truezip.socket.InputSocket;
import edu.umd.cs.findbugs.annotations.CreatesObligation;
import java.io.*;
import javax.annotation.concurrent.Immutable;

/**
 * A replacement for the class {@link FileInputStream} for reading plain old
 * files or entries in an archive file.
 * Mind that applications cannot read archive files directly - just their
 * entries!
 * 

* To prevent exceptions to be thrown subsequently, applications should * always close their streams using the following idiom: *

{@code
 * TFileInputStream in = new TFileInputStream(file);
 * try {
 *     // Do I/O here...
 * } finally {
 *     in.close(); // ALWAYS close the stream!
 * }
 * }
*

* Note that the {@link #close()} method may throw an {@link IOException}, too. * Applications need to deal with this appropriately, for example by enclosing * the entire block with another {@code try-catch}-block: *

{@code
 * try {
 *     TFileInputStream in = new TFileInputStream(file);
 *     try {
 *         // Do I/O here...
 *     } finally {
 *         in.close(); // ALWAYS close the stream!
 *     }
 * } catch (IOException ex) {
 *     ex.printStackTrace();
 * }
 * }
*

* Applications cannot read from an entry in an archive file if an implicit * {@link TFile#umount() unmount} is required but cannot get performed because * another {@link TFileInputStream} or {@link TFileOutputStream} object hasn't * been closed or garbage collected yet. * A {@link FileNotFoundException} is thrown by the constructors of this class * in this case. *

* If you would like to use this class in order to cp files, * please consider using one of the * cp methods of the class {@link TFile} * instead. * These methods provide ease of use, enhanced features, superior performance * and require less space in the temp file folder. * * @see TFile#cat(InputStream, OutputStream) * @see TFileOutputStream * @author Christian Schlichtherle */ @Immutable public final class TFileInputStream extends DecoratingInputStream { /** * Constructs a new input stream for reading plain old files or entries * in an archive file. * This constructor calls {@link TFile#TFile(String) new TFile(path)} for * the given path. * * @param path the path of the plain old file or entry in an archive file * to read. * @throws FileNotFoundException on any I/O failure. */ @CreatesObligation @edu.umd.cs.findbugs.annotations.SuppressWarnings("OBL_UNSATISFIED_OBLIGATION") public TFileInputStream(String path) throws FileNotFoundException { super(newInputStream(new TFile(path))); } /** * Constructs a new input stream for reading plain old files or entries * in an archive file. * * @param file the plain old file or entry in an archive file to read. * @throws FileNotFoundException on any I/O failure. */ @CreatesObligation @edu.umd.cs.findbugs.annotations.SuppressWarnings("OBL_UNSATISFIED_OBLIGATION") public TFileInputStream(File file) throws FileNotFoundException { super(newInputStream(file)); } @CreatesObligation private static InputStream newInputStream(final File src) throws FileNotFoundException { final InputSocket input = TBIO.getInputSocket(src, TConfig.get().getInputPreferences()); try { return input.newInputStream(); } catch (FileNotFoundException ex) { throw ex; } catch (IOException ex) { throw (FileNotFoundException) new FileNotFoundException( src.toString()).initCause(ex); } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy