Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(307)

Unified Diff: content/browser/loader/mojo_async_resource_handler.cc

Issue 2629513003: Implement CachedMetadata handling on MojoAsyncResourceHandler (Closed)
Patch Set: fix Created 3 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/browser/loader/mojo_async_resource_handler.cc
diff --git a/content/browser/loader/mojo_async_resource_handler.cc b/content/browser/loader/mojo_async_resource_handler.cc
index 0d103654468e3923424646aa51031246b07daeef..70fa94a7387857a683bfcd544ed4aaea9ed7ce0d 100644
--- a/content/browser/loader/mojo_async_resource_handler.cc
+++ b/content/browser/loader/mojo_async_resource_handler.cc
@@ -181,6 +181,14 @@ bool MojoAsyncResourceHandler::OnResponseStarted(ResourceResponse* response,
url_loader_client_->OnReceiveResponse(response->head,
std::move(downloaded_file_ptr));
+
+ net::IOBufferWithSize* metadata = GetResponseMetadata(request());
+ if (metadata) {
+ const uint8_t* ptr = reinterpret_cast<const uint8_t*>(metadata->data());
+
+ url_loader_client_->OnReceiveCachedMetadata(
+ std::vector<uint8_t>(ptr, ptr + metadata->size()));
+ }
return true;
}
@@ -323,6 +331,11 @@ MojoResult MojoAsyncResourceHandler::EndWrite(uint32_t written) {
return mojo::EndWriteDataRaw(shared_writer_->writer(), written);
}
+net::IOBufferWithSize* MojoAsyncResourceHandler::GetResponseMetadata(
+ net::URLRequest* request) {
+ return request->response_info().metadata.get();
+}
+
void MojoAsyncResourceHandler::OnResponseCompleted(
const net::URLRequestStatus& status,
bool* defer) {

Powered by Google App Engine
This is Rietveld 408576698