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

org.jwat.arc.ArcWriterFactory Maven / Gradle / Ivy

Go to download

Used for reading, writing and validating ARC files. Trying to follow the adhoc standard as much as possible.

There is a newer version: 1.2.1
Show newest version
/**
 * Java Web Archive Toolkit - Software to read and validate ARC, WARC
 * and GZip files. (http://jwat.org/)
 * Copyright 2011-2012 Netarkivet.dk (http://netarkivet.dk/)
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.jwat.arc;

import java.io.OutputStream;

/**
 * Factory used for creating ArcWriter instances.
 * Factory methods are available for creating ArcWriter
 * instances for writing either compressed or uncompressed records.
 * Use of buffered methods and/or buffering speeds up the writer considerably.
 *
 * @author nicl
 */
public class ArcWriterFactory {

    /**
     * Private constructor to enforce factory method.
     */
    protected ArcWriterFactory() {
    }

    /**
     * Creates a new unbuffered ArcWriter from an
     * OutputStream.
     * Returns a compressing or non compressing writer according to the arguments.
     * @param out output stream to write to
     * @param compressed compression switch
     * @return unbuffered ArcWriter
     */
    public static ArcWriter getWriter(OutputStream out, boolean compressed) {
        if (out == null) {
            throw new IllegalArgumentException(
                    "The 'out' parameter is null!");
        }
        if (compressed) {
            return new ArcWriterCompressed(out);
        } else {
            return new ArcWriterUncompressed(out);
        }
    }

    /**
     * Creates a new buffered ArcWriter from an
     * OutputStream.
     * Returns a compressing or non compressing writer according to the arguments.
     * @param out output stream to write to
     * @param buffer_size buffer size to use
     * @param compressed compression switch
     * @return buffered ArcWriter
     */
    public static ArcWriter getWriter(OutputStream out, int buffer_size, boolean compressed) {
        if (out == null) {
            throw new IllegalArgumentException(
                    "The 'out' parameter is null!");
        }
        if (buffer_size <= 0) {
            throw new IllegalArgumentException(
                    "The 'buffer_size' parameter is less than or equal to zero!");
        }
        if (compressed) {
            return new ArcWriterCompressed(out, buffer_size);
        } else {
            return new ArcWriterUncompressed(out, buffer_size);
        }
    }

    /**
     * Creates a new unbuffered non compressing ArcWriter from an
     * OutputStream.
     * @param out output stream to write to
     * @return unbuffered non compressing ArcWriter
     */
    public static ArcWriter getWriterUncompressed(OutputStream out) {
        if (out == null) {
            throw new IllegalArgumentException(
                    "The 'out' parameter is null!");
        }
        return new ArcWriterUncompressed(out);
    }

    /**
     * Creates a new buffered non compressing ArcWriter from an
     * OutputStream.
     * @param out output stream to write to
     * @param buffer_size buffer size to use
     * @return buffered non compressing ArcWriter
     */
    public static ArcWriter getWriterUncompressed(OutputStream out, int buffer_size) {
        if (out == null) {
            throw new IllegalArgumentException(
                    "The 'out' parameter is null!");
        }
        if (buffer_size <= 0) {
            throw new IllegalArgumentException(
                    "The 'buffer_size' parameter is less than or equal to zero!");
        }
        return new ArcWriterUncompressed(out, buffer_size);
    }

    /**
     * Creates a new unbuffered compressing ArcWriter from an
     * OutputStream.
     * @param out output stream to write to
     * @return unbuffered compressing ArcWriter
     */
    public static ArcWriter getWriterCompressed(OutputStream out) {
        if (out == null) {
            throw new IllegalArgumentException(
                    "The 'out' parameter is null!");
        }
        return new ArcWriterCompressed(out);
    }

    /**
     * Creates a new buffered compressing ArcWriter from an
     * OutputStream.
     * @param out output stream to write to
     * @param buffer_size buffer size to use
     * @return buffered compressing ArcWriter
     */
    public static ArcWriter getWriterCompressed(OutputStream out, int buffer_size) {
        if (out == null) {
            throw new IllegalArgumentException(
                    "The 'out' parameter is null!");
        }
        if (buffer_size <= 0) {
            throw new IllegalArgumentException(
                    "The 'buffer_size' parameter is less than or equal to zero!");
        }
        return new ArcWriterCompressed(out, buffer_size);
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy