| 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
|
|
|