Index: mojo/examples/html_viewer/weburlloader_impl.cc |
diff --git a/mojo/examples/html_viewer/weburlloader_impl.cc b/mojo/examples/html_viewer/weburlloader_impl.cc |
index d2d4e364b35925bae22ac298e97a04aa7c4442f5..ae0651df6cbc7488cb4a7118ae7acdf3fe35f09d 100644 |
--- a/mojo/examples/html_viewer/weburlloader_impl.cc |
+++ b/mojo/examples/html_viewer/weburlloader_impl.cc |
@@ -47,7 +47,6 @@ WebURLLoaderImpl::WebURLLoaderImpl(NetworkService* network_service) |
: client_(NULL), |
weak_factory_(this) { |
network_service->CreateURLLoader(Get(&url_loader_)); |
- url_loader_.set_client(this); |
} |
WebURLLoaderImpl::~WebURLLoaderImpl() { |
@@ -64,25 +63,25 @@ void WebURLLoaderImpl::loadSynchronously( |
void WebURLLoaderImpl::loadAsynchronously(const blink::WebURLRequest& request, |
blink::WebURLLoaderClient* client) { |
client_ = client; |
+ url_ = request.url(); |
URLRequestPtr url_request(URLRequest::New()); |
- url_request->url = request.url().spec(); |
+ url_request->url = url_.spec(); |
url_request->auto_follow_redirects = false; |
// TODO(darin): Copy other fields. |
if (request.extraData()) { |
WebURLRequestExtraData* extra_data = |
static_cast<WebURLRequestExtraData*>(request.extraData()); |
- response_body_stream_ = extra_data->synthetic_response_body_stream.Pass(); |
base::ThreadTaskRunnerHandle::Get()->PostTask( |
FROM_HERE, |
base::Bind(&WebURLLoaderImpl::OnReceivedResponse, |
weak_factory_.GetWeakPtr(), |
base::Passed(&extra_data->synthetic_response))); |
} else { |
- DataPipe pipe; |
- url_loader_->Start(url_request.Pass(), pipe.producer_handle.Pass()); |
- response_body_stream_ = pipe.consumer_handle.Pass(); |
+ url_loader_->Start(url_request.Pass(), |
+ base::Bind(&WebURLLoaderImpl::OnReceivedResponse, |
+ weak_factory_.GetWeakPtr())); |
} |
} |
@@ -90,53 +89,63 @@ void WebURLLoaderImpl::cancel() { |
url_loader_.reset(); |
response_body_stream_.reset(); |
- NetworkErrorPtr network_error(NetworkError::New()); |
- network_error->code = net::ERR_ABORTED; |
+ URLResponsePtr failed_response(URLResponse::New()); |
+ failed_response->url = url_.spec(); |
+ failed_response->error = NetworkError::New(); |
+ failed_response->error->code = net::ERR_ABORTED; |
base::ThreadTaskRunnerHandle::Get()->PostTask( |
FROM_HERE, |
- base::Bind(&WebURLLoaderImpl::OnReceivedError, |
+ base::Bind(&WebURLLoaderImpl::OnReceivedResponse, |
weak_factory_.GetWeakPtr(), |
- base::Passed(&network_error))); |
+ base::Passed(&failed_response))); |
} |
void WebURLLoaderImpl::setDefersLoading(bool defers_loading) { |
NOTIMPLEMENTED(); |
} |
-void WebURLLoaderImpl::OnReceivedRedirect(URLResponsePtr url_response, |
- const String& new_url, |
- const String& new_method) { |
- blink::WebURLRequest new_request; |
- new_request.initialize(); |
- new_request.setURL(GURL(new_url)); |
- |
- client_->willSendRequest(this, new_request, ToWebURLResponse(url_response)); |
- // TODO(darin): Check if new_request was rejected. |
- |
- url_loader_->FollowRedirect(); |
-} |
- |
void WebURLLoaderImpl::OnReceivedResponse(URLResponsePtr url_response) { |
- client_->didReceiveResponse(this, ToWebURLResponse(url_response)); |
+ url_ = GURL(url_response->url); |
- // Start streaming data |
- ReadMore(); |
+ if (url_response->error) { |
+ OnReceivedError(url_response.Pass()); |
+ } else if (url_response->redirect_url) { |
+ OnReceivedRedirect(url_response.Pass()); |
+ } else { |
+ client_->didReceiveResponse(this, ToWebURLResponse(url_response)); |
+ |
+ // Start streaming data |
+ response_body_stream_ = url_response->body.Pass(); |
+ ReadMore(); |
+ } |
} |
-void WebURLLoaderImpl::OnReceivedError(NetworkErrorPtr error) { |
+void WebURLLoaderImpl::OnReceivedError(URLResponsePtr url_response) { |
blink::WebURLError web_error; |
web_error.domain = blink::WebString::fromUTF8(net::kErrorDomain); |
- web_error.reason = error->code; |
- web_error.unreachableURL = GURL(); // TODO(darin): Record this. |
+ web_error.reason = url_response->error->code; |
+ web_error.unreachableURL = GURL(url_response->url); |
web_error.staleCopyInCache = false; |
- web_error.isCancellation = error->code == net::ERR_ABORTED ? true : false; |
+ web_error.isCancellation = |
+ url_response->error->code == net::ERR_ABORTED ? true : false; |
client_->didFail(this, web_error); |
} |
-void WebURLLoaderImpl::OnReceivedEndOfResponseBody() { |
- // This is the signal that the response body was not truncated. |
+void WebURLLoaderImpl::OnReceivedRedirect(URLResponsePtr url_response) { |
+ blink::WebURLRequest new_request; |
+ new_request.initialize(); |
+ new_request.setURL(GURL(url_response->redirect_url)); |
+ new_request.setHTTPMethod( |
+ blink::WebString::fromUTF8(url_response->redirect_method)); |
+ |
+ client_->willSendRequest(this, new_request, ToWebURLResponse(url_response)); |
+ // TODO(darin): Check if new_request was rejected. |
+ |
+ url_loader_->FollowRedirect( |
+ base::Bind(&WebURLLoaderImpl::OnReceivedResponse, |
+ weak_factory_.GetWeakPtr())); |
} |
void WebURLLoaderImpl::ReadMore() { |