diff options
author | darin@chromium.org <darin@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-06-09 18:45:04 +0000 |
---|---|---|
committer | darin@chromium.org <darin@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-06-09 18:45:04 +0000 |
commit | f92eb0034a4b0a8249f739df38b82add5e36044f (patch) | |
tree | d7749b8bf473f61d86a50ce04736950d1862c574 /webkit/glue/multipart_response_delegate.cc | |
parent | b72eb73e72040cdaaa8957ca7a7417f9b89843fe (diff) | |
download | chromium_src-f92eb0034a4b0a8249f739df38b82add5e36044f.zip chromium_src-f92eb0034a4b0a8249f739df38b82add5e36044f.tar.gz chromium_src-f92eb0034a4b0a8249f739df38b82add5e36044f.tar.bz2 |
Start using WebURLLoader, et. al. from the WebKit API.
Moves our ResourceHandle to webkit/api/src/ResourceHandle.cpp
from webkit/glue/resource_handle_impl.cc. A portion of
resource_handle_impl.cc was moved into weburlloader_impl.{h,cc},
which now contains our implementation of WebURLLoader.
The annoying parts of this CL involve WebPluginImpl. I had to
convert it over to using WebURLLoader instead of ResourceHandle
so that MultipartResourceDelegate can be shared.
There is some complexity in WebURLRequest / WebURLResponse to
make it cheap to wrap a ResourceRequest / ResourceResponse. I
think this is worth it since there is a lot of conversion between
the two types.
Originally reviewed here:
http://codereview.chromium.org/113928
BUG=10038
TEST=covered by existing tests
R=dglazkov
Review URL: http://codereview.chromium.org/118438
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@17962 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/glue/multipart_response_delegate.cc')
-rw-r--r-- | webkit/glue/multipart_response_delegate.cc | 162 |
1 files changed, 89 insertions, 73 deletions
diff --git a/webkit/glue/multipart_response_delegate.cc b/webkit/glue/multipart_response_delegate.cc index 9e8e67d..2000b61 100644 --- a/webkit/glue/multipart_response_delegate.cc +++ b/webkit/glue/multipart_response_delegate.cc @@ -2,32 +2,64 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -#include "config.h" -#include <string> - -#include "base/compiler_specific.h" - -MSVC_PUSH_WARNING_LEVEL(0); -#include "HTTPHeaderMap.h" -#include "ResourceHandle.h" -#include "ResourceHandleClient.h" -#include "PlatformString.h" -MSVC_POP_WARNING(); +#include "webkit/glue/multipart_response_delegate.h" -#undef LOG #include "base/logging.h" #include "base/string_util.h" -#include "webkit/glue/multipart_response_delegate.h" -#include "webkit/glue/glue_util.h" #include "net/base/net_util.h" +#include "webkit/api/public/WebHTTPHeaderVisitor.h" +#include "webkit/api/public/WebString.h" +#include "webkit/api/public/WebURL.h" +#include "webkit/api/public/WebURLLoaderClient.h" +#include "webkit/glue/glue_util.h" + +using WebKit::WebHTTPHeaderVisitor; +using WebKit::WebString; +using WebKit::WebURLLoader; +using WebKit::WebURLLoaderClient; +using WebKit::WebURLResponse; + +namespace webkit_glue { + +namespace { + +// The list of response headers that we do not copy from the original +// response when generating a WebURLResponse for a MIME payload. +const char* kReplaceHeaders[] = { + "content-type", + "content-length", + "content-disposition", + "content-range", + "range", + "set-cookie" +}; + +class HeaderCopier : public WebHTTPHeaderVisitor { + public: + HeaderCopier(WebURLResponse* response) + : response_(response) { + } + virtual void visitHeader(const WebString& name, const WebString& value) { + const std::string& name_utf8 = WebStringToStdString(name); + for (size_t i = 0; i < arraysize(kReplaceHeaders); ++i) { + if (LowerCaseEqualsASCII(name_utf8, kReplaceHeaders[i])) + return; + } + response_->setHTTPHeaderField(name, value); + } + private: + WebURLResponse* response_; +}; + +} // namespace MultipartResponseDelegate::MultipartResponseDelegate( - WebCore::ResourceHandleClient* client, - WebCore::ResourceHandle* job, - const WebCore::ResourceResponse& response, + WebURLLoaderClient* client, + WebURLLoader* loader, + const WebURLResponse& response, const std::string& boundary) : client_(client), - job_(job), + loader_(loader), original_response_(response), boundary_("--"), first_received_data_(true), @@ -41,7 +73,8 @@ MultipartResponseDelegate::MultipartResponseDelegate( } } -void MultipartResponseDelegate::OnReceivedData(const char* data, int data_len) { +void MultipartResponseDelegate::OnReceivedData(const char* data, + int data_len) { // stop_sending_ means that we've already received the final boundary token. // The server should stop sending us data at this point, but if it does, we // just throw it away. @@ -49,8 +82,7 @@ void MultipartResponseDelegate::OnReceivedData(const char* data, int data_len) { return; // TODO(tc): Figure out what to use for length_received. Maybe we can just - // pass the value on from our caller. See note in - // resource_handle_win.cc:ResourceHandleInternal::OnReceivedData. + // pass the value on from our caller. int length_received = -1; data_.append(data, data_len); @@ -98,8 +130,10 @@ void MultipartResponseDelegate::OnReceivedData(const char* data, int data_len) { while ((boundary_pos = FindBoundary()) != std::string::npos) { if (boundary_pos > 0) { // Send the last data chunk. - client_->didReceiveData(job_, data_.substr(0, boundary_pos).data(), - static_cast<int>(boundary_pos), length_received); + client_->didReceiveData(loader_, + data_.substr(0, boundary_pos).data(), + static_cast<int>(boundary_pos), + length_received); } size_t boundary_end_pos = boundary_pos + boundary_.length(); if (boundary_end_pos < data_.length() && '-' == data_[boundary_end_pos]) { @@ -128,12 +162,15 @@ void MultipartResponseDelegate::OnCompletedRequest() { // TODO(tc): Figure out what to use for length_received. Maybe we can just // pass the value on from our caller. int length_received = -1; - client_->didReceiveData(job_, data_.data(), - static_cast<int>(data_.length()), length_received); + client_->didReceiveData(loader_, + data_.data(), + static_cast<int>(data_.length()), + length_received); } } -int MultipartResponseDelegate::PushOverLine(const std::string& data, size_t pos) { +int MultipartResponseDelegate::PushOverLine(const std::string& data, + size_t pos) { int offset = 0; if (pos < data.length() && (data[pos] == '\r' || data[pos] == '\n')) { ++offset; @@ -175,47 +212,28 @@ bool MultipartResponseDelegate::ParseHeaders() { headers.append(data_.substr(0, line_end_pos)); data_ = data_.substr(line_end_pos); - // Create a ResourceResponse based on the original set of headers + the + // Create a WebURLResponse based on the original set of headers + the // replacement headers. We only replace the same few headers that gecko // does. See netwerk/streamconv/converters/nsMultiMixedConv.cpp. std::string mime_type = net::GetSpecificHeader(headers, "content-type"); std::string charset = net::GetHeaderParamValue(mime_type, "charset"); - WebCore::ResourceResponse response(original_response_.url(), - webkit_glue::StdStringToString(mime_type.c_str()), - -1, - charset.c_str(), - WebCore::String()); - const WebCore::HTTPHeaderMap& orig_headers = - original_response_.httpHeaderFields(); - for (WebCore::HTTPHeaderMap::const_iterator it = orig_headers.begin(); - it != orig_headers.end(); ++it) { - if (!(equalIgnoringCase("content-type", it->first) || - equalIgnoringCase("content-length", it->first) || - equalIgnoringCase("content-disposition", it->first) || - equalIgnoringCase("content-range", it->first) || - equalIgnoringCase("range", it->first) || - equalIgnoringCase("set-cookie", it->first))) { - response.setHTTPHeaderField(it->first, it->second); - } - } - static const char* replace_headers[] = { - "Content-Type", - "Content-Length", - "Content-Disposition", - "Content-Range", - "Range", - "Set-Cookie" - }; - for (size_t i = 0; i < arraysize(replace_headers); ++i) { - std::string name(replace_headers[i]); + WebURLResponse response(original_response_.url()); + response.setMIMEType(StdStringToWebString(mime_type)); + response.setTextEncodingName(StdStringToWebString(charset)); + + HeaderCopier copier(&response); + original_response_.visitHTTPHeaderFields(&copier); + + for (size_t i = 0; i < arraysize(kReplaceHeaders); ++i) { + std::string name(kReplaceHeaders[i]); std::string value = net::GetSpecificHeader(headers, name); if (!value.empty()) { - response.setHTTPHeaderField(webkit_glue::StdStringToString(name.c_str()), - webkit_glue::StdStringToString(value.c_str())); + response.setHTTPHeaderField(StdStringToWebString(name), + StdStringToWebString(value)); } } // Send the response! - client_->didReceiveResponse(job_, response); + client_->didReceiveResponse(loader_, response); return true; } @@ -239,29 +257,27 @@ size_t MultipartResponseDelegate::FindBoundary() { } bool MultipartResponseDelegate::ReadMultipartBoundary( - const WebCore::ResourceResponse& response, + const WebURLResponse& response, std::string* multipart_boundary) { - WebCore::String content_type = response.httpHeaderField("Content-Type"); - std::string content_type_as_string = - webkit_glue::StringToStdString(content_type); + std::string content_type = WebStringToStdString( + response.httpHeaderField(WebString::fromUTF8("Content-Type"))); - size_t boundary_start_offset = content_type_as_string.find("boundary="); + size_t boundary_start_offset = content_type.find("boundary="); if (boundary_start_offset == std::wstring::npos) { return false; } boundary_start_offset += strlen("boundary="); - size_t boundary_end_offset = - content_type_as_string.find(';', boundary_start_offset); + size_t boundary_end_offset = content_type.find(';', boundary_start_offset); if (boundary_end_offset == std::string::npos) - boundary_end_offset = content_type_as_string.length(); + boundary_end_offset = content_type.length(); size_t boundary_length = boundary_end_offset - boundary_start_offset; *multipart_boundary = - content_type_as_string.substr(boundary_start_offset, boundary_length); + content_type.substr(boundary_start_offset, boundary_length); // The byte range response can have quoted boundary strings. This is legal // as per MIME specifications. Individual data fragements however don't // contain quoted boundary strings. @@ -270,16 +286,14 @@ bool MultipartResponseDelegate::ReadMultipartBoundary( } bool MultipartResponseDelegate::ReadContentRanges( - const WebCore::ResourceResponse& response, + const WebURLResponse& response, int* content_range_lower_bound, int* content_range_upper_bound) { - std::string content_range = - webkit_glue::StringToStdString( - response.httpHeaderField("Content-Range")); + std::string content_range = WebStringToStdString( + response.httpHeaderField(WebString::fromUTF8("Content-Range"))); - size_t byte_range_lower_bound_start_offset = - content_range.find(" "); + size_t byte_range_lower_bound_start_offset = content_range.find(" "); if (byte_range_lower_bound_start_offset == std::string::npos) { return false; } @@ -321,3 +335,5 @@ bool MultipartResponseDelegate::ReadContentRanges( return false; return true; } + +} // namespace webkit_glue |