Logo
Distributed Genetic Programming Framework
print print

File org.sfc.io.DefaultOutputStream.java

Here you can find all the information about the file org.sfc.io.DefaultOutputStream.java. You may explore it here or download it onto your local disk.
/*
 * Copyright (c) 2005 Thomas Weise
 * 
 * E-Mail           : tweise@gmx.de
 * Creation Date    : 2005-06-22 16:25:35
 * Original Filename: org.sfc.io.DefaultOutputStream.java
 * Version          : 1.0.2
 * Last modification: 2006-03-07
 *                by: Thomas Weise
 * 
 * License          : GNU LESSER GENERAL PUBLIC LICENSE
 *                    Version 2.1, February 1999
 *                    You should have received a copy of this license along
 *                    with this library; if not, write to the Free Software
 *                    Foundation, Inc., 59 Temple Place, Suite 330, Boston,
 *                    MA 02111-1307, USA or download the license under
 *                    http://www.gnu.org/copyleft/lesser.html.
 *                    
 * Warranty         : This software is provided "as is" without any
 *                    warranty; without even the implied warranty of
 *                    merchantability or fitness for a particular purpose.
 *                    See the Gnu Lesser General Public License for more
 *                    details.
 */

 
package org.sfc.io;

import java.io.IOException;
import java.io.OutputStream;

/**
 * This class is a wrapper for <code>OutputStream</code>s that makes them
 * reference counted.
 * @author Thomas Weise 
 */

final class DefaultOutputStream extends ReferenceCountedOutputStream
  { 
/**
 * The internal output-stream.
 */

  private final OutputStream  m_os;
    
/**
 * Create a reference counted <code>OutputStream</code>.
 * 
 * @param p_original  The underlying object.
 */

  DefaultOutputStream  (final  OutputStream p_original)
    {
    super();
    this.m_os = p_original;
    }
    
/**
 * The internal dispose method.
 * @throws  IOException If the underlying was closed and caused an
 *                      IOException.
 */

  @Override
  protected final void  dispose () throws IOException
    {
    try
      {
      this.m_os.close();
      }
    finally
      {
      super.dispose();
      }
    }

  
/**
 * Writes the specified <code>byte</code> to this output stream. 
 * <p>
 * The <code>write</code> method of <code>DefaultOutputStream</code> 
 * calls the <code>write</code> method of its underlying output stream, 
 * that is, it performs <tt>out.write(b)</tt>.
 * <p>
 * Implements the abstract <tt>write</tt> method of <tt>OutputStream</tt>. 
 *
 * @param     p_b   the <code>byte</code>.
 * @exception  IOException  if an I/O error occurs.
 */

  @Override
  public final  void write(int p_b) throws IOException
    {
    this.m_os.write(p_b);
    }

/**
 * Writes <code>b.length</code> bytes to this output stream. 
 * <p>
 * The <code>write</code> method of <code>DefaultOutputStream</code> 
 * calls its <code>write</code> method of three arguments with the 
 * arguments <code>b</code>, <code>0</code>, and 
 * <code>b.length</code>. 
 * <p>
 * Note that this method does not call the one-argument 
 * <code>write</code> method of its underlying stream with the single 
 * argument <code>b</code>. 
 *
 * @param      p_b   the data to be written.
 * @exception  IOException  if an I/O error occurs.
 * @see        DefaultOutputStream#write(byte[], int, int)
 */

  @Override
  public final  void write(final  byte[] p_b) throws IOException
    {
    this.m_os.write(p_b);
    }

/**
 * Writes <code>len</code> bytes from the specified 
 * <code>byte</code> array starting at offset <code>off</code> to 
 * this output stream. 
 * <p>
 * The <code>write</code> method of <code>DefaultOutputStream</code> 
 * calls the <code>write</code> method of one argument on each 
 * <code>byte</code> to output. 
 * <p>
 * Note that this method does not call the <code>write</code> method 
 * of its underlying input stream with the same arguments. Subclasses 
 * of <code>DefaultOutputStream</code> should provide a more efficient 
 * implementation of this method. 
 *
 * @param      p_b     the data.
 * @param      p_off   the start offset in the data.
 * @param      p_len   the number of bytes to write.
 * @exception  IOException  if an I/O error occurs.
 * @see        DefaultOutputStream#write(int)
 */

  @Override
  public final  void write(final  byte[]  p_b,
                           final  int   p_off,
                           final  int   p_len) throws IOException
    {
    this.m_os.write(p_b, p_off, p_len);
    }

/**
 * Flushes this output stream and forces any buffered output bytes 
 * to be written out to the stream. 
 * <p>
 * The <code>flush</code> method of <code>DefaultOutputStream</code> 
 * calls the <code>flush</code> method of its underlying output stream. 
 *
 * @exception  IOException  if an I/O error occurs.
 */

  @Override
  public final  void flush() throws IOException
    {
    this.m_os.flush();
    }
  }

File Information:

file name:DefaultOutputStream.java
package:org.sfc.io
qualified name:org.sfc.io.DefaultOutputStream.java
file type:Java Source File
download location:download http://dgpf.sourceforge.net/source/org/sfc/io/DefaultOutputStream.java
size:4.797 KB (4913 B)
uploaded: 2018-01-07 12:03:36 GMT+0000
last update: 2006-03-07 04:20:28 GMT+0000
last access: 2018-04-24 02:59:49 GMT+0000

statistics online since 2006-01-02.   RSS Feed
Contact us by sending an email to tweise@gmx.de to receive further information, to report errors, or to join our project.
All content on this site (http://dgpf.sourceforge.net/) is LGPL-licensed.
http://dgpf.sourceforge.net/scripts/source/source.php last modified at 2018-01-07 12:03:34 GMT+0000 served at 2018-04-24 02:59:49 GMT+0000.
Valid CSS Valid XHTML 1.1
Valid RSS SourceForge.net Logo