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

de.schlichtherle.truezip.file.TFileWriter 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.

The newest version!
/*
 * Copyright (C) 2005-2015 Schlichtherle IT Services.
 * All rights reserved. Use is subject to license terms.
 */
package de.schlichtherle.truezip.file;

import edu.umd.cs.findbugs.annotations.CleanupObligation;
import edu.umd.cs.findbugs.annotations.CreatesObligation;
import edu.umd.cs.findbugs.annotations.DischargesObligation;
import java.io.*;
import java.nio.charset.Charset;
import java.nio.charset.CharsetEncoder;
import javax.annotation.concurrent.Immutable;

/**
 * A replacement for the class {@link FileWriter} for writing plain old files
 * or entries in an archive file.
 * Mind that applications cannot write archive files directly - just their
 * entries!
 *
 * @see    TConfig#setLenient
 * @see    TFileReader
 * @author Christian Schlichtherle
 */
@Immutable
@CleanupObligation
public final class TFileWriter extends OutputStreamWriter {

    /**
     * Constructs a new {@code TFile} writer.
     * This writer uses the default character set for encoding characters
     * to bytes.
     * 
     * @param  file a file to write.
     * @throws FileNotFoundException on any I/O failure.
     */
    @CreatesObligation
    @edu.umd.cs.findbugs.annotations.SuppressWarnings({
        "DM_DEFAULT_ENCODING", "OBL_UNSATISFIED_OBLIGATION"
    })
    public TFileWriter(File file) throws FileNotFoundException {
        super(new TFileOutputStream(file));
    }

    /**
     * Constructs a new {@code TFile} writer.
     * This writer uses the default character set for encoding characters
     * to bytes.
     * 

* TODO: Remove this redundant constructor in TrueZIP 8. * * @param file a file to write. * @throws FileNotFoundException on any I/O failure. */ @CreatesObligation @edu.umd.cs.findbugs.annotations.SuppressWarnings({ "DM_DEFAULT_ENCODING", "OBL_UNSATISFIED_OBLIGATION" }) public TFileWriter(TFile file) throws FileNotFoundException { super(new TFileOutputStream(file)); } /** * Constructs a new {@code TFile} writer. * This writer uses the default character set for encoding characters * to bytes. * * @param file a file to write. * @param append iff {@code true}, then this writer appends the data to the * given file. * @throws FileNotFoundException on any I/O failure. */ @CreatesObligation @edu.umd.cs.findbugs.annotations.SuppressWarnings({ "DM_DEFAULT_ENCODING", "OBL_UNSATISFIED_OBLIGATION" }) public TFileWriter(File file, boolean append) throws FileNotFoundException { super(new TFileOutputStream(file, append)); } /** * Constructs a new {@code TFile} writer. * This writer uses the default character set for encoding characters * to bytes. *

* TODO: Remove this redundant constructor in TrueZIP 8. * * @param file a file to write. * @param append iff {@code true}, then this writer appends the data to the * given file. * @throws FileNotFoundException on any I/O failure. */ @CreatesObligation @edu.umd.cs.findbugs.annotations.SuppressWarnings({ "DM_DEFAULT_ENCODING", "OBL_UNSATISFIED_OBLIGATION" }) public TFileWriter(TFile file, boolean append) throws FileNotFoundException { super(new TFileOutputStream(file, append)); } /** * Constructs a new {@code TFile} writer. * * @param file a file to write. * @param append iff {@code true}, then this writer appends the data to the * given file. * @param charset a character set for encoding characters to bytes. * @throws FileNotFoundException on any I/O failure. * @since TrueZIP 7.5 */ @CreatesObligation @edu.umd.cs.findbugs.annotations.SuppressWarnings("OBL_UNSATISFIED_OBLIGATION") public TFileWriter(File file, boolean append, Charset charset) throws FileNotFoundException { super(new TFileOutputStream(file, append), charset); } /** * Constructs a new {@code TFile} writer. * * @param file a file to write. * @param append iff {@code true}, then this writer appends the data to the * given file. * @param encoder an encoder for encoding characters to bytes. * @throws FileNotFoundException on any I/O failure. */ @CreatesObligation @edu.umd.cs.findbugs.annotations.SuppressWarnings("OBL_UNSATISFIED_OBLIGATION") public TFileWriter(File file, boolean append, CharsetEncoder encoder) throws FileNotFoundException { super(new TFileOutputStream(file, append), encoder); } /** * Constructs a new {@code TFile} writer. *

* TODO: Remove this redundant constructor in TrueZIP 8. * * @param file a file to write. * @param append iff {@code true}, then this writer appends the data to the * given file. * @param encoder an encoder for encoding characters to bytes. * @throws FileNotFoundException on any I/O failure. */ @CreatesObligation @edu.umd.cs.findbugs.annotations.SuppressWarnings("OBL_UNSATISFIED_OBLIGATION") public TFileWriter(TFile file, boolean append, CharsetEncoder encoder) throws FileNotFoundException { super(new TFileOutputStream(file, append), encoder); } @Override @DischargesObligation public void close() throws IOException { super.close(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy