|
|
@@ -14,7 +14,7 @@ void HttpRequestParser::Reset()
|
|
|
m_state = State::MethodStart;
|
|
|
}
|
|
|
|
|
|
-Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
+Tribool::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
{
|
|
|
switch (m_state)
|
|
|
{
|
|
|
@@ -27,13 +27,13 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
{
|
|
|
m_state = State::Method;
|
|
|
request.method.push_back(input);
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
case State::Method:
|
|
|
if (input == ' ')
|
|
|
{
|
|
|
m_state = State::URI;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else if (!IsChar(input) || IsCtl(input) || IsTSpecial(input))
|
|
|
{
|
|
|
@@ -42,13 +42,13 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
else
|
|
|
{
|
|
|
request.method.push_back(input);
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
case State::URI:
|
|
|
if (input == ' ')
|
|
|
{
|
|
|
m_state = State::HttpVersionH;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else if (IsCtl(input))
|
|
|
{
|
|
|
@@ -57,13 +57,13 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
else
|
|
|
{
|
|
|
request.uri.push_back(input);
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
case State::HttpVersionH:
|
|
|
if (input == 'H')
|
|
|
{
|
|
|
m_state = State::HttpVersionT1;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
@@ -73,7 +73,7 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
if (input == 'T')
|
|
|
{
|
|
|
m_state = State::HttpVersionT2;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
@@ -83,7 +83,7 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
if (input == 'T')
|
|
|
{
|
|
|
m_state = State::HttpVersionP;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
@@ -93,7 +93,7 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
if (input == 'P')
|
|
|
{
|
|
|
m_state = State::HttpVersionSlash;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
@@ -105,7 +105,7 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
request.httpVersionMajor = 0;
|
|
|
request.httpVersionMinor = 0;
|
|
|
m_state = State::HttpVersionMajorStart;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
@@ -116,7 +116,7 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
{
|
|
|
request.httpVersionMajor = request.httpVersionMajor * 10 + input - '0';
|
|
|
m_state = State::HttpVersionMajor;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
@@ -126,12 +126,12 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
if (input == '.')
|
|
|
{
|
|
|
m_state = State::HttpVersionMinorStart;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else if (IsDigit(input))
|
|
|
{
|
|
|
request.httpVersionMajor = request.httpVersionMajor * 10 + input - '0';
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
@@ -142,7 +142,7 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
{
|
|
|
request.httpVersionMinor = request.httpVersionMinor * 10 + input - '0';
|
|
|
m_state = State::HttpVersionMinor;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
@@ -152,12 +152,12 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
if (input == '\r')
|
|
|
{
|
|
|
m_state = State::ExpectingNewline1;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else if (IsDigit(input))
|
|
|
{
|
|
|
request.httpVersionMinor = request.httpVersionMinor * 10 + input - '0';
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
@@ -167,7 +167,7 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
if (input == '\n')
|
|
|
{
|
|
|
m_state = State::HeaderLineStart;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
@@ -177,12 +177,12 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
if (input == '\r')
|
|
|
{
|
|
|
m_state = State::ExpectingNewline3;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else if (!request.headers.empty() && (input == ' ' || input == '\t'))
|
|
|
{
|
|
|
m_state = State::HeaderLws;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else if (!IsChar(input) || IsCtl(input) || IsTSpecial(input))
|
|
|
{
|
|
|
@@ -193,17 +193,17 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
request.headers.push_back(HttpHeader());
|
|
|
request.headers.back().name.push_back(input);
|
|
|
m_state = State::HeaderName;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
case State::HeaderLws:
|
|
|
if (input == '\r')
|
|
|
{
|
|
|
m_state = State::ExpectingNewline2;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else if (input == ' ' || input == '\t')
|
|
|
{
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else if (IsCtl(input))
|
|
|
{
|
|
|
@@ -213,13 +213,13 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
{
|
|
|
m_state = State::HeaderValue;
|
|
|
request.headers.back().value.push_back(input);
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
case State::HeaderName:
|
|
|
if (input == ':')
|
|
|
{
|
|
|
m_state = State::SpaceBeforeHeaderValue;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else if (!IsChar(input) || IsCtl(input) || IsTSpecial(input))
|
|
|
{
|
|
|
@@ -228,13 +228,13 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
else
|
|
|
{
|
|
|
request.headers.back().name.push_back(input);
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
case State::SpaceBeforeHeaderValue:
|
|
|
if (input == ' ')
|
|
|
{
|
|
|
m_state = State::HeaderValue;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
@@ -244,7 +244,7 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
if (input == '\r')
|
|
|
{
|
|
|
m_state = State::ExpectingNewline2;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else if (IsCtl(input))
|
|
|
{
|
|
|
@@ -253,13 +253,13 @@ Utilities::Tribool HttpRequestParser::Consume(HttpRequest& request, char input)
|
|
|
else
|
|
|
{
|
|
|
request.headers.back().value.push_back(input);
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
case State::ExpectingNewline2:
|
|
|
if (input == '\n')
|
|
|
{
|
|
|
m_state = State::HeaderLineStart;
|
|
|
- return Utilities::Tribool::Indeterminate;
|
|
|
+ return Tribool::Tribool::Indeterminate;
|
|
|
}
|
|
|
else
|
|
|
{
|