本文整理汇总了C++中StreamBuffer::in_avail方法的典型用法代码示例。如果您正苦于以下问题:C++ StreamBuffer::in_avail方法的具体用法?C++ StreamBuffer::in_avail怎么用?C++ StreamBuffer::in_avail使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类StreamBuffer
的用法示例。
在下文中一共展示了StreamBuffer::in_avail方法的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: onInput
void Socket::onInput(StreamBuffer& sb)
{
log_debug("onInput");
sb.endRead();
if (sb.in_avail() == 0 || sb.device()->eof())
{
close();
return;
}
while (sb.in_avail() > 0)
{
if (_responder.advance(sb.sbumpc()))
{
_responder.finalize(_stream);
buffer().beginWrite();
onOutput(sb);
return;
}
}
sb.beginRead();
}
示例2: onOutput
bool Socket::onOutput(StreamBuffer& sb)
{
log_trace("onOutput");
log_debug("send data to " << getPeerAddr());
try
{
sb.endWrite();
if ( sb.out_avail() )
{
sb.beginWrite();
}
else
{
if (sb.in_avail())
onInput(sb);
else
sb.beginRead();
}
}
catch (const std::exception& e)
{
log_warn("exception occured when processing request: " << e.what());
close();
return false;
}
return true;
}
示例3: onOutput
bool Socket::onOutput(StreamBuffer& sb)
{
log_trace("onOutput");
log_debug("send data to " << getPeerAddr());
try
{
sb.endWrite();
if ( sb.out_avail() )
{
sb.beginWrite();
_timer.start(_server.writeTimeout());
}
else
{
bool keepAlive = _request.header().keepAlive()
&& _reply.header().keepAlive();
if (keepAlive)
{
log_debug("do keep alive");
_timer.start(_server.keepAliveTimeout());
_request.clear();
_reply.clear();
_parser.reset(false);
if (sb.in_avail())
onInput(sb);
else
_stream.buffer().beginRead();
}
else
{
log_debug("don't do keep alive");
close();
return false;
}
}
}
catch (const std::exception& e)
{
log_warn("exception occured when processing request: " << e.what());
close();
timeout(*this);
return false;
}
return true;
}
示例4: onInput
void Socket::onInput(StreamBuffer& sb)
{
log_debug("onInput");
sb.endRead();
if (sb.in_avail() == 0 || sb.device()->eof())
{
close();
return;
}
if (_responder.onInput(_stream))
{
sb.beginWrite();
onOutput(sb);
}
else
{
sb.beginRead();
}
}
示例5: processBodyAvailable
void ClientImpl::processBodyAvailable(StreamBuffer& sb)
{
log_trace("processBodyAvailable");
if (_chunkedEncoding)
{
if (_chunkedIStream.rdbuf()->in_avail() > 0)
{
if (!_chunkedIStream.eod())
{
log_debug("read chunked encoding body");
while (_chunkedIStream.good()
&& _chunkedIStream.rdbuf()->in_avail() > 0
&& !_chunkedIStream.eod())
{
log_debug("bodyAvailable");
_client->bodyAvailable(*_client);
}
log_debug("in_avail=" << _chunkedIStream.rdbuf()->in_avail() << " eod=" << _chunkedIStream.eod());
if (_chunkedIStream.eod())
{
_parser.readHeader();
}
}
if (_chunkedIStream.eod() && sb.in_avail() > 0)
{
log_debug("read chunked encoding post headers");
_parser.advance(sb);
if (_parser.fail())
throw std::runtime_error("http parser failed"); // TODO define exception class
if( _parser.end() )
{
log_debug("reply finished");
if (!_replyHeader.keepAlive())
{
log_debug("close socket - no keep alive");
_socket.close();
}
_client->replyFinished(*_client);
}
}
if (_chunkedIStream.fail())
throw IOError("error reading HTTP reply body");
}
else if( _chunkedIStream.eod() )
{
if( _replyHeader.hasHeader("Trailer") )
_parser.readHeader();
else
_client->replyFinished(*_client);
}
if (_socket.enabled())
{
if ((!_chunkedIStream.eod() || !_parser.end()))
{
log_debug("call beginRead");
sb.beginRead();
}
}
else
{
cancel();
}
}
else
{
log_debug("content-length(pre)=" << _contentLength);
while (_stream.good() && _contentLength > 0 && sb.in_avail() > 0)
{
_contentLength -= _client->bodyAvailable(*_client); // TODO: may throw exception
log_debug("content-length(post)=" << _contentLength);
}
if (_stream.fail())
throw IOError("error reading HTTP reply body");
if( _contentLength <= 0 )
{
log_debug("reply finished");
if (!_replyHeader.keepAlive())
{
log_debug("close socket - no keep alive");
_socket.close();
}
_client->replyFinished(*_client);
}
else if (_socket.enabled() && _stream.good())
{
//.........这里部分代码省略.........
示例6: processHeaderAvailable
void ClientImpl::processHeaderAvailable(StreamBuffer& sb)
{
_parser.advance(sb);
if (_parser.fail())
throw std::runtime_error("http parser failed"); // TODO define exception class
if( _parser.end() )
{
_chunkedEncoding = _replyHeader.chunkedTransferEncoding();
_client->headerReceived(*_client);
_readHeader = false;
if (_chunkedEncoding)
{
log_debug("chunked transfer encoding used");
_chunkedIStream.reset();
if( sb.in_avail() > 0 )
{
processBodyAvailable(sb);
}
else
{
sb.beginRead();
}
}
else
{
_contentLength = _replyHeader.contentLength();
log_debug("header received - content-length=" << _contentLength);
if (_contentLength > 0)
{
if( sb.in_avail() > 0 )
{
processBodyAvailable(sb);
}
else
{
sb.beginRead();
}
}
else
{
if (!_replyHeader.keepAlive())
{
log_debug("close socket - no keep alive");
_socket.close();
}
_client->replyFinished(*_client);
}
}
}
else
{
sb.beginRead();
}
}
示例7: onInput
void Socket::onInput(StreamBuffer& sb)
{
log_debug("onInput");
sb.endRead();
if (sb.in_avail() == 0 || sb.device()->eof())
{
close();
return;
}
_timer.start(_server.readTimeout());
if ( _responder == 0 )
{
_parser.advance(sb);
if (_parser.fail())
{
_responder = _server.getDefaultResponder(_request);
_responder->replyError(_reply.body(), _request, _reply,
std::runtime_error("invalid http header"));
_responder->release();
_responder = 0;
sendReply();
onOutput(sb);
return;
}
if (_parser.end())
{
log_info("request " << _request.method() << ' ' << _request.header().query()
<< " from client " << getPeerAddr());
_responder = _server.getResponder(_request);
try
{
_responder->beginRequest(_stream, _request);
}
catch (const std::exception& e)
{
_reply.setHeader("Connection", "close");
_responder->replyError(_reply.body(), _request, _reply, e);
_responder->release();
_responder = 0;
sendReply();
onOutput(sb);
return;
}
_contentLength = _request.header().contentLength();
log_debug("content length of request is " << _contentLength);
if (_contentLength == 0)
{
_timer.stop();
doReply();
return;
}
}
else
{
sb.beginRead();
}
}
if (_responder)
{
if (sb.in_avail() > 0)
{
try
{
std::size_t s = _responder->readBody(_stream);
assert(s > 0);
_contentLength -= s;
}
catch (const std::exception& e)
{
_reply.setHeader("Connection", "close");
_responder->replyError(_reply.body(), _request, _reply, e);
_responder->release();
_responder = 0;
sendReply();
onOutput(sb);
return;
}
}
if (_contentLength <= 0)
{
_timer.stop();
doReply();
}
else
{
sb.beginRead();
}
//.........这里部分代码省略.........