author | cli |
Sun Aug 29 17:04:25 2010 +0200 (2010-08-29) | |
changeset 34 | 9f0b95aafaa3 |
parent 3 | 2fdc9cc89502 |
permissions | -rw-r--r-- |
chris@1 | 1 |
/* |
chris@1 | 2 |
* SONEWS News Server |
chris@1 | 3 |
* see AUTHORS for the list of contributors |
chris@1 | 4 |
* |
chris@1 | 5 |
* This program is free software: you can redistribute it and/or modify |
chris@1 | 6 |
* it under the terms of the GNU General Public License as published by |
chris@1 | 7 |
* the Free Software Foundation, either version 3 of the License, or |
chris@1 | 8 |
* (at your option) any later version. |
chris@1 | 9 |
* |
chris@1 | 10 |
* This program is distributed in the hope that it will be useful, |
chris@1 | 11 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
chris@1 | 12 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
chris@1 | 13 |
* GNU General Public License for more details. |
chris@1 | 14 |
* |
chris@1 | 15 |
* You should have received a copy of the GNU General Public License |
chris@1 | 16 |
* along with this program. If not, see <http://www.gnu.org/licenses/>. |
chris@1 | 17 |
*/ |
chris@1 | 18 |
|
chris@1 | 19 |
package org.sonews.util.io; |
chris@1 | 20 |
|
chris@1 | 21 |
import java.io.ByteArrayOutputStream; |
chris@1 | 22 |
import java.io.IOException; |
chris@1 | 23 |
import java.io.InputStream; |
chris@1 | 24 |
import java.io.UnsupportedEncodingException; |
chris@3 | 25 |
import org.sonews.storage.Article; |
chris@1 | 26 |
|
chris@1 | 27 |
/** |
chris@1 | 28 |
* Capsulates an Article to provide a raw InputStream. |
chris@1 | 29 |
* @author Christian Lins |
chris@1 | 30 |
* @since sonews/0.5.0 |
chris@1 | 31 |
*/ |
chris@1 | 32 |
public class ArticleInputStream extends InputStream |
chris@1 | 33 |
{ |
chris@1 | 34 |
|
cli@11 | 35 |
private byte[] buf; |
cli@11 | 36 |
private int pos = 0; |
chris@1 | 37 |
|
chris@1 | 38 |
public ArticleInputStream(final Article art) |
chris@1 | 39 |
throws IOException, UnsupportedEncodingException |
chris@1 | 40 |
{ |
chris@1 | 41 |
final ByteArrayOutputStream out = new ByteArrayOutputStream(); |
chris@1 | 42 |
out.write(art.getHeaderSource().getBytes("UTF-8")); |
chris@1 | 43 |
out.write("\r\n\r\n".getBytes()); |
chris@3 | 44 |
out.write(art.getBody()); // Without CRLF |
chris@1 | 45 |
out.flush(); |
cli@11 | 46 |
this.buf = out.toByteArray(); |
chris@1 | 47 |
} |
chris@3 | 48 |
|
cli@11 | 49 |
/** |
cli@11 | 50 |
* This method reads one byte from the stream. The <code>pos</code> |
cli@11 | 51 |
* counter is advanced to the next byte to be read. The byte read is |
cli@11 | 52 |
* returned as an int in the range of 0-255. If the stream position |
cli@11 | 53 |
* is already at the end of the buffer, no byte is read and a -1 is |
cli@11 | 54 |
* returned in order to indicate the end of the stream. |
cli@11 | 55 |
* |
cli@11 | 56 |
* @return The byte read, or -1 if end of stream |
cli@11 | 57 |
*/ |
chris@3 | 58 |
@Override |
cli@11 | 59 |
public synchronized int read() |
chris@1 | 60 |
{ |
cli@11 | 61 |
if(pos < buf.length) |
chris@1 | 62 |
{ |
cli@11 | 63 |
return ((int)buf[pos++]) & 0xFF; |
chris@1 | 64 |
} |
chris@1 | 65 |
else |
chris@1 | 66 |
{ |
cli@11 | 67 |
return -1; |
chris@1 | 68 |
} |
chris@1 | 69 |
} |
chris@1 | 70 |
|
chris@1 | 71 |
} |