View Javadoc

1   /*
2    * Copyright (c) 2003 Peter Antman, Teknik i Media  <peter.antman@tim.se>
3    *
4    * $Id: ByteCachedOutputStream.java,v 1.1.1.1 2004/05/19 12:07:30 pra Exp $
5    *
6    * This library is free software; you can redistribute it and/or
7    * modify it under the terms of the GNU Lesser General Public
8    * License as published by the Free Software Foundation; either
9    * version 2 of the License, or (at your option) any later version
10   * 
11   * This library is distributed in the hope that it will be useful,
12   * but WITHOUT ANY WARRANTY; without even the implied warranty of
13   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14   * Lesser General Public License for more details.
15   * 
16   * You should have received a copy of the GNU Lesser General Public
17   * License along with this library; if not, write to the Free Software
18   * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19   */
20  package org.backsource.utils.io;
21  import java.io.BufferedOutputStream;
22  import java.io.ByteArrayOutputStream;
23  import java.io.IOException;
24  /***
25   * A CachedOutoutStream.
26   *
27   *<p>for now this is just a BufferedOutputStream that uses a
28   * ByteArrayOutputStream as its sink, which is available here.</p>
29   *
30   * @author <a href="mailto:pra@tim.se">Peter Antman</a>
31   * @version $Revision: 1.1.1.1 $
32   */
33  
34  public class ByteCachedOutputStream extends  CachedOutputStream {
35     ByteArrayOutputStream sink;
36     //OutputStream delegator;
37     
38     public ByteCachedOutputStream (){
39        super( new ByteArrayOutputStream()  );
40        sink = (ByteArrayOutputStream)out;
41     }
42     
43     /***
44      * return the underlying byte array.
45      */
46     public Object getSink() throws IOException {
47        flush();
48        return sink.toByteArray();
49     }
50     
51  }// CachedOutputStream