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

Unified Diff: content/browser/service_worker/service_worker_cache_storage.h

Issue 460683002: Change threading in ServiceWorkerCacheStorage (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: AsWeakPtr Created 6 years, 4 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_cache_storage.h
diff --git a/content/browser/service_worker/service_worker_cache_storage.h b/content/browser/service_worker/service_worker_cache_storage.h
index 291d02958698ea56f71e610303ce06b9f0ef7e70..a518e7b855e5357dbb345aeecb79c5a785f4135d 100644
--- a/content/browser/service_worker/service_worker_cache_storage.h
+++ b/content/browser/service_worker/service_worker_cache_storage.h
@@ -11,20 +11,20 @@
#include "base/callback.h"
#include "base/files/file_path.h"
#include "base/id_map.h"
-#include "base/threading/thread_checker.h"
+#include "base/memory/weak_ptr.h"
namespace base {
-class MessageLoopProxy;
+class SequencedTaskRunner;
}
namespace content {
-
class ServiceWorkerCache;
// TODO(jkarlin): Constrain the total bytes used per origin.
-// The set of caches for a given origin. It is owned by the
-// ServiceWorkerCacheStorageManager. Provided callbacks are called on the
-// |callback_loop| provided in the constructor.
+
+// ServiceWorkerCacheStorage holds the set of caches for a given origin. It is
+// owned by the ServiceWorkerCacheStorageManager. This class expects to be run
+// on the IO thread.
class ServiceWorkerCacheStorage {
public:
enum CacheStorageError {
@@ -41,10 +41,9 @@ class ServiceWorkerCacheStorage {
typedef base::Callback<void(const std::vector<std::string>&,
CacheStorageError)> StringsAndErrorCallback;
- ServiceWorkerCacheStorage(
- const base::FilePath& origin_path,
- bool memory_only,
- const scoped_refptr<base::MessageLoopProxy>& callback_loop);
+ ServiceWorkerCacheStorage(const base::FilePath& origin_path,
+ bool memory_only,
+ base::SequencedTaskRunner* cache_task_runner);
virtual ~ServiceWorkerCacheStorage();
@@ -73,10 +72,6 @@ class ServiceWorkerCacheStorage {
// TODO(jkarlin): Add match() function.
- void InitializeCacheCallback(const ServiceWorkerCache* cache,
- const CacheAndErrorCallback& callback,
- bool success);
-
private:
class MemoryLoader;
class SimpleCacheLoader;
@@ -88,15 +83,62 @@ class ServiceWorkerCacheStorage {
ServiceWorkerCache* GetLoadedCache(const std::string& cache_name) const;
- void LazyInit();
- void InitCache(ServiceWorkerCache* cache);
-
+ // Initializer and its callback are below.
+ void LazyInit(const base::Closure& closure);
+ void LazyInitDidLoadIndex(
+ const base::Closure& callback,
+ scoped_ptr<std::vector<std::string> > indexed_cache_names);
+ void LazyInitIterateAndLoadCacheName(
+ const base::Closure& callback,
+ scoped_ptr<std::vector<std::string> > indexed_cache_names,
+ const std::vector<std::string>::const_iterator& iter,
+ scoped_ptr<ServiceWorkerCache> cache);
+ void LazyInitDone();
+
+ void DidCreateBackend(base::WeakPtr<ServiceWorkerCache> cache,
+ const CacheAndErrorCallback& callback,
+ bool success);
+
+ void AddCacheToMaps(scoped_ptr<ServiceWorkerCache> cache);
+
+ // The CreateCache callbacks are below.
+ void CreateCacheDidCreateCache(const std::string& cache_name,
+ const CacheAndErrorCallback& callback,
+ scoped_ptr<ServiceWorkerCache> cache);
+ void CreateCacheDidWriteIndex(const CacheAndErrorCallback& callback,
+ base::WeakPtr<ServiceWorkerCache> cache,
+ bool success);
+
+ // The DeleteCache callbacks are below.
+ void DeleteCacheDidWriteIndex(const std::string& cache_name,
+ const BoolAndErrorCallback& callback,
+ bool success);
+ void DeleteCacheDidCleanUp(const BoolAndErrorCallback& callback,
+ bool success);
+
+ // Whether or not we've loaded the list of cache names into memory.
bool initialized_;
+
+ // The list of operations waiting on initialization.
+ std::vector<base::Closure> init_callbacks_;
+
+ // The map of ServiceWorkerCache objects to their integer ids that
+ // ServiceWorkers reference. Owns the cache objects.
CacheMap cache_map_;
+
+ // The map of cache names to their integer ids.
NameMap name_map_;
+
+ // The file path for this CacheStorage.
base::FilePath origin_path_;
- scoped_refptr<base::MessageLoopProxy> callback_loop_;
- scoped_ptr<CacheLoader> cache_loader_;
+
+ // The TaskRunner to run file IO on.
+ scoped_refptr<base::SequencedTaskRunner> cache_task_runner_;
+
+ // Performs backend specific operations (memory vs disk).
+ scoped_refptr<CacheLoader> cache_loader_;
+
+ base::WeakPtrFactory<ServiceWorkerCacheStorage> weak_factory_;
DISALLOW_COPY_AND_ASSIGN(ServiceWorkerCacheStorage);
};

Powered by Google App Engine
This is Rietveld 408576698