gnu.inet.http

Class ByteArrayRequestBodyWriter

Implemented Interfaces:
RequestBodyWriter

public class ByteArrayRequestBodyWriter
extends Object
implements RequestBodyWriter

A simple request body writer using a byte array.

Field Summary

protected byte[]
content
The content.
protected int
pos
The position within the content at which the next read will occur.

Constructor Summary

ByteArrayRequestBodyWriter(byte[] content)
Constructs a new byte array request body writer with the specified content.

Method Summary

int
getContentLength()
Returns the total number of bytes that will be written in a single pass by this writer.
void
reset()
Initialises the writer.
int
write(byte[] buffer)
Writes body content to the supplied buffer.

Field Details

content

protected byte[] content
The content.


pos

protected int pos
The position within the content at which the next read will occur.

Constructor Details

ByteArrayRequestBodyWriter

public ByteArrayRequestBodyWriter(byte[] content)
Constructs a new byte array request body writer with the specified content.

Parameters:
content - the content buffer

Method Details

getContentLength

public int getContentLength()
Returns the total number of bytes that will be written in a single pass by this writer.
Specified by:
getContentLength in interface RequestBodyWriter


reset

public void reset()
Initialises the writer. This will be called before each pass.
Specified by:
reset in interface RequestBodyWriter


write

public int write(byte[] buffer)
Writes body content to the supplied buffer.
Specified by:
write in interface RequestBodyWriter

Parameters:
buffer - the content buffer

Returns:
the number of bytes written


* ByteArrayRequestBodyWriter.java * Copyright (C) 2004 The Free Software Foundation * * This file is part of GNU inetlib, a library. * * GNU inetlib is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * GNU inetlib is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * * Linking this library statically or dynamically with other modules is * making a combined work based on this library. Thus, the terms and * conditions of the GNU General Public License cover the whole * combination. * * As a special exception, the copyright holders of this library give you * permission to link this library with independent modules to produce an * executable, regardless of the license terms of these independent * modules, and to copy and distribute the resulting executable under * terms of your choice, provided that you also meet, for each linked * independent module, the terms and conditions of the license of that * module. An independent module is a module which is not derived from * or based on this library. If you modify this library, you may extend * this exception to your version of the library, but you are not * obliged to do so. If you do not wish to do so, delete this * exception statement from your version.