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

Unified Diff: public/platform/WebServiceWorkerCacheStorage.h

Issue 380923002: Introducing the WebServiceWorkerCacheStorage. (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: api fixes Created 6 years, 5 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: public/platform/WebServiceWorkerCacheStorage.h
diff --git a/public/platform/WebServiceWorkerCacheStorage.h b/public/platform/WebServiceWorkerCacheStorage.h
new file mode 100644
index 0000000000000000000000000000000000000000..5a6a2f778a37ccc2276d73f94d7de6ce29728053
--- /dev/null
+++ b/public/platform/WebServiceWorkerCacheStorage.h
@@ -0,0 +1,47 @@
+// Copyright 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef WebServiceWorkerCacheStorage_h
+#define WebServiceWorkerCacheStorage_h
+
+#include "WebCommon.h"
+#include "public/platform/WebCallbacks.h"
+#include "public/platform/WebString.h"
+#include "public/platform/WebVector.h"
+#include <string>
+#include <vector>
+
+namespace WebCore { class ServiceWorker; }
+
+namespace blink {
+
+// An interface to the CacheStorage API, implemented by the embedder and passed in to blink.
+class WebServiceWorkerCacheStorage {
+public:
+ enum ErrorReason {
jkarlin 2014/07/23 12:03:32 Please add 'CacheStorageErrorNoError' as the first
gavinp 2014/07/25 07:44:03 (your name still shows OOO from your vacation...)
+ CacheStorageErrorNotImplemented,
+ CacheStorageErrorNotFound,
+ CacheStorageErrorExists,
+ CacheStorageErrorLast = CacheStorageErrorExists
jkarlin 2014/07/24 13:20:16 Please append CacheStorageErrorStorage to the enum
gavinp 2014/07/25 07:44:03 Tricky decision. I can see the argument; this fail
+ };
+
+ typedef WebCallbacks<void, ErrorReason> CacheStorageCallbacks;
+ typedef WebCallbacks<int /* cacheID */, ErrorReason> CacheStorageWithCacheCallbacks;
+ typedef WebCallbacks<WebVector<WebString>, ErrorReason> CacheStorageKeysCallbacks;
+
+ WebServiceWorkerCacheStorage() { }
+ virtual ~WebServiceWorkerCacheStorage() { }
+
+ // Ownership of the CacheStorage*Callbacks methods passes to the WebServiceWorkerCacheStorage
+ // instance, which will delete it after calling onSuccess or onFailure.
+ virtual void dispatchCreate(CacheStorageWithCacheCallbacks*, const WebString& key) = 0;
+ virtual void dispatchRename(CacheStorageCallbacks*, const WebString& oldKey, const WebString& newKey) = 0;
+ virtual void dispatchGet(CacheStorageWithCacheCallbacks*, const WebString& key) = 0;
+ virtual void dispatchDelete(CacheStorageCallbacks*, const WebString& key) = 0;
+ virtual void dispatchKeys(CacheStorageKeysCallbacks*) = 0;
+};
+
+} // namespace blink
+
+#endif // WebServiceWorkerCacheStorage_h

Powered by Google App Engine
This is Rietveld 408576698