Skip to content
Merged
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Next Next commit
Fix issue #110 and issue #168.
  • Loading branch information
Chase Geigle committed Feb 27, 2013
commit c6c1607b36849398ae040da4bb03bb95047c9ed3
29 changes: 28 additions & 1 deletion boost/network/protocol/http/message/async_message.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -118,7 +118,34 @@ namespace boost { namespace network { namespace http {
}

string_type const body() const {
return body_.get();
string_type body;
string_type partial_parsed = body_.get();

typename headers_range<basic_response<Tag> >::type transfer_encoding_range = headers().equal_range("Transfer-Encoding");
if (!empty(transfer_encoding_range) && boost::iequals(boost::begin(transfer_encoding_range)->second, "chunked")) {
typename string_type::iterator begin = partial_parsed.begin();
string_type crlf = "\r\n";
for (typename string_type::iterator iter = std::search(begin, partial_parsed.end(), crlf.begin(), crlf.end());
iter != partial_parsed.end();
iter = std::search(begin, partial_parsed.end(), crlf.begin(), crlf.end())) {
string_type line(begin, iter);
if (line.empty()) break;
std::stringstream stream(line);
int len;
stream >> std::hex >> len;
iter += 2;
if (!len) break;
if (len <= partial_parsed.end() - iter) {
body.insert(body.end(), iter, iter + len);
iter += len;
}
begin = iter;
}
} else {
std::swap(body, partial_parsed);
}

return body;
}

void body(boost::shared_future<string_type> const & future) const {
Expand Down