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

Unified Diff: content/browser/service_worker/service_worker_script_cache_map.cc

Issue 931173002: Implement EmbeddedWorkerContextClient.setCachedMetadata/clearCachedMetadata (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: fix clang failure Created 5 years, 10 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/service_worker/service_worker_script_cache_map.cc
diff --git a/content/browser/service_worker/service_worker_script_cache_map.cc b/content/browser/service_worker/service_worker_script_cache_map.cc
index 6c74466e41c8198b6cae2910be076c7de737d425..925fe6e3b4764821dd6f3132f81396e0d0334151 100644
--- a/content/browser/service_worker/service_worker_script_cache_map.cc
+++ b/content/browser/service_worker/service_worker_script_cache_map.cc
@@ -6,17 +6,19 @@
#include "base/logging.h"
#include "content/browser/service_worker/service_worker_context_core.h"
+#include "content/browser/service_worker/service_worker_disk_cache.h"
#include "content/browser/service_worker/service_worker_storage.h"
#include "content/browser/service_worker/service_worker_version.h"
#include "content/common/service_worker/service_worker_types.h"
+#include "net/base/io_buffer.h"
+#include "net/base/net_errors.h"
namespace content {
ServiceWorkerScriptCacheMap::ServiceWorkerScriptCacheMap(
ServiceWorkerVersion* owner,
base::WeakPtr<ServiceWorkerContextCore> context)
- : owner_(owner),
- context_(context) {
+ : owner_(owner), context_(context), weak_factory_(this) {
}
ServiceWorkerScriptCacheMap::~ServiceWorkerScriptCacheMap() {
@@ -90,4 +92,40 @@ void ServiceWorkerScriptCacheMap::SetResources(
}
}
+void ServiceWorkerScriptCacheMap::WriteMetadata(
+ const GURL& url,
+ const std::vector<char>& data,
+ const net::CompletionCallback& callback) {
+ ResourceMap::iterator found = resource_map_.find(url);
+ if (found == resource_map_.end() ||
+ found->second.resource_id == kInvalidServiceWorkerResponseId) {
+ callback.Run(net::ERR_FILE_NOT_FOUND);
+ return;
+ }
+ scoped_refptr<net::IOBuffer> buffer(new net::IOBuffer(data.size()));
+ if (data.size())
+ memmove(buffer->data(), &data[0], data.size());
+ scoped_ptr<ServiceWorkerResponseMetadataWriter> writer;
+ writer = context_->storage()->CreateResponseMetadataWriter(
+ found->second.resource_id);
+ ServiceWorkerResponseMetadataWriter* raw_writer = writer.get();
+ raw_writer->WriteMetadata(
+ buffer.get(), data.size(),
+ base::Bind(&ServiceWorkerScriptCacheMap::OnMetadataWritten,
+ weak_factory_.GetWeakPtr(), Passed(&writer), callback));
+}
+
+void ServiceWorkerScriptCacheMap::ClearMetadata(
+ const GURL& url,
+ const net::CompletionCallback& callback) {
+ WriteMetadata(url, std::vector<char>(), callback);
+}
+
+void ServiceWorkerScriptCacheMap::OnMetadataWritten(
+ scoped_ptr<ServiceWorkerResponseMetadataWriter> writer,
+ const net::CompletionCallback& callback,
+ int result) {
+ callback.Run(result);
+}
+
} // namespace content

Powered by Google App Engine
This is Rietveld 408576698