Javadocs and comments.

This commit is contained in:
Simone Bordet 2014-05-20 21:24:55 +02:00
parent 4234048d81
commit c4f7d38e86
1 changed files with 19 additions and 1 deletions

View File

@ -29,6 +29,10 @@ public abstract class Parser
private State state = State.HEADER; private State state = State.HEADER;
private int padding; private int padding;
/**
* @param buffer the bytes to parse
* @return true if the caller should stop parsing, false if the caller should continue parsing
*/
public boolean parse(ByteBuffer buffer) public boolean parse(ByteBuffer buffer)
{ {
while (true) while (true)
@ -53,10 +57,17 @@ public abstract class Parser
{ {
ContentParser.Result result = contentParser.parse(buffer); ContentParser.Result result = contentParser.parse(buffer);
if (result == ContentParser.Result.PENDING) if (result == ContentParser.Result.PENDING)
{
// Not enough data, signal to read/parse more.
return false; return false;
else if (result == ContentParser.Result.ASYNC) }
if (result == ContentParser.Result.ASYNC)
{
// The content will be processed asynchronously, signal to stop
// parsing; the async operation will eventually resume parsing.
return true; return true;
} }
}
padding = headerParser.getPaddingLength(); padding = headerParser.getPaddingLength();
state = State.PADDING; state = State.PADDING;
break; break;
@ -99,6 +110,13 @@ public abstract class Parser
public void onHeaders(int request); public void onHeaders(int request);
/**
* @param request the request id
* @param stream the stream type
* @param buffer the content bytes
* @return true to signal to the parser to stop parsing, false to continue parsing
* @see Parser#parse(java.nio.ByteBuffer)
*/
public boolean onContent(int request, FCGI.StreamType stream, ByteBuffer buffer); public boolean onContent(int request, FCGI.StreamType stream, ByteBuffer buffer);
public void onEnd(int request); public void onEnd(int request);