/*
* JBoss, Home of Professional Open Source.
* Copyright 2014 Red Hat, Inc., and individual contributors
* as indicated by the @author tags.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.undertow.client.http;
import io.undertow.util.HttpString;
Author: Emanuel Muckenhuber
/**
* @author Emanuel Muckenhuber
*/
class ResponseParseState {
//parsing states
public static final int VERSION = 0;
public static final int STATUS_CODE = 1;
public static final int REASON_PHRASE = 2;
public static final int AFTER_REASON_PHRASE = 3;
public static final int HEADER = 4;
public static final int HEADER_VALUE = 5;
public static final int PARSE_COMPLETE = 6;
The actual state of request parsing
/**
* The actual state of request parsing
*/
int state;
The current state in the tokenizer state machine.
/**
* The current state in the tokenizer state machine.
*/
int parseState;
If this state is a prefix or terminal match state this is set to the string
that is a candidate to be matched
/**
* If this state is a prefix or terminal match state this is set to the string
* that is a candidate to be matched
*/
HttpString current;
The bytes version of current
/**
* The bytes version of {@link #current}
*/
byte[] currentBytes;
If this state is a prefix match state then this holds the current position in the string.
/**
* If this state is a prefix match state then this holds the current position in the string.
*/
int pos;
If this is in NO_STATE
then this holds the current token that has been read so far. /**
* If this is in {@link #NO_STATE} then this holds the current token that has been read so far.
*/
final StringBuilder stringBuilder = new StringBuilder();
This has different meanings depending on the current state.
In state HEADER
it is a the first character of the header, that was read by HEADER_VALUE
to see if this was a continuation. In state HEADER_VALUE
if represents the last character that was seen. /**
* This has different meanings depending on the current state.
* <p/>
* In state {@link #HEADER} it is a the first character of the header, that was read by
* {@link #HEADER_VALUE} to see if this was a continuation.
* <p/>
* In state {@link #HEADER_VALUE} if represents the last character that was seen.
*/
byte leftOver;
This is used to store the next header value when parsing header key / value pairs,
/**
* This is used to store the next header value when parsing header key / value pairs,
*/
HttpString nextHeader;
ResponseParseState() {
this.parseState = 0;
this.pos = 0;
}
public boolean isComplete() {
return state == PARSE_COMPLETE;
}
public final void parseComplete() {
state = PARSE_COMPLETE;
}
}