001/**
002 * Logback: the reliable, generic, fast and flexible logging framework.
003 * Copyright (C) 1999-2015, QOS.ch. All rights reserved.
004 *
005 * This program and the accompanying materials are dual-licensed under
006 * either the terms of the Eclipse Public License v1.0 as published by
007 * the Eclipse Foundation
008 *
009 *   or (per the licensee's choosing)
010 *
011 * under the terms of the GNU Lesser General Public License version 2.1
012 * as published by the Free Software Foundation.
013 */
014package ch.qos.logback.core.net;
015
016import java.io.IOException;
017import java.io.ObjectOutputStream;
018import java.io.OutputStream;
019
020import ch.qos.logback.core.CoreConstants;
021
022/**
023 * Factory for {@link ch.qos.logback.core.net.ObjectWriter} instances.
024 *
025 * @author Sebastian Gröbler
026 */
027public class ObjectWriterFactory {
028
029    /**
030     * Creates a new {@link ch.qos.logback.core.net.AutoFlushingObjectWriter}
031     * instance.
032     *
033     * @param outputStream the underlying {@link java.io.OutputStream} to write to
034     * @return a new {@link ch.qos.logback.core.net.AutoFlushingObjectWriter}
035     *         instance
036     * @throws IOException if an I/O error occurs while writing stream header
037     */
038    public AutoFlushingObjectWriter newAutoFlushingObjectWriter(OutputStream outputStream) throws IOException {
039        return new AutoFlushingObjectWriter(new ObjectOutputStream(outputStream), CoreConstants.OOS_RESET_FREQUENCY);
040    }
041}