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

Unified Diff: webkit/dom_storage/dom_storage_cached_area.h

Issue 10450009: DomStorageCachedArea + DomStorageProxy interface and unittests. These classes aren't used yet. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Created 8 years, 7 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: webkit/dom_storage/dom_storage_cached_area.h
===================================================================
--- webkit/dom_storage/dom_storage_cached_area.h (revision 0)
+++ webkit/dom_storage/dom_storage_cached_area.h (revision 0)
@@ -0,0 +1,81 @@
+// Copyright (c) 2012 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 WEBKIT_DOM_STORAGE_DOM_STORAGE_CACHED_AREA_H_
+#define WEBKIT_DOM_STORAGE_DOM_STORAGE_CACHED_AREA_H_
+#pragma once
+
+#include <map>
+
+#include "base/memory/ref_counted.h"
+#include "base/memory/weak_ptr.h"
+#include "base/nullable_string16.h"
+#include "googleurl/src/gurl.h"
+
+namespace dom_storage {
+
+class DomStorageMap;
+class DomStorageProxy;
+
+class DomStorageCachedArea : public base::RefCounted<DomStorageCachedArea> {
+ public:
+ DomStorageCachedArea(int64 namespace_id, const GURL& origin,
+ DomStorageProxy* proxy);
+
+ int64 namespace_id() const { return namespace_id_; }
+ const GURL& origin() const { return origin_; }
+
+ unsigned GetLength(int connection_id);
+ NullableString16 GetKey(int connection_id, unsigned index);
+ NullableString16 GetItem(int connection_id, const string16& key);
+ bool SetItem(int connection_id, const string16& key, const string16& value,
+ const GURL& page_url);
+ void RemoveItem(int connection_id, const string16& key,
+ const GURL& page_url);
+ void Clear(int connection_id, const GURL& page_url);
+
+ void ApplyMutation(const NullableString16& key,
+ const NullableString16& new_value);
+
+ private:
+ friend class DomStorageCachedAreaTest;
+ friend class base::RefCounted<DomStorageCachedArea>;
+ ~DomStorageCachedArea();
+
+ // Primes the cache, loading all values for the area.
jsbell 2012/05/24 20:20:22 Can you add a comment near the top of the class in
michaeln 2012/05/24 20:43:11 Done. // Unlike the other classes in the dom_stor
+ void Prime(int connection_id);
+ void PrimeIfNeeded(int connection_id) {
+ if (!map_)
+ Prime(connection_id);
+ }
+
+ // Resets the class back to its newly constructed state.
jsbell 2012/05/24 20:20:22 Nit: s/class/object/
michaeln 2012/05/24 20:43:11 Done.
+ void Reset();
+
+ // Async completion callbacks for proxied operations.
+ // These are used to maintain cache consistency by preventing
+ // mutation events from other processes from overwriting local
+ // changes made after the mutation.
+ void OnLoadComplete(bool success);
+ void OnSetItemComplete(const string16& key, bool success);
+ void OnClearComplete(bool success);
+ void OnRemoveItemComplete(const string16& key, bool success);
+
+ bool should_ignore_key_mutation(const string16& key) const {
+ return ignore_key_mutations_.find(key) != ignore_key_mutations_.end();
+ }
+
+ bool ignore_all_mutations_;
+ std::map<string16, int> ignore_key_mutations_;
+
+ int64 namespace_id_;
+ GURL origin_;
+ scoped_refptr<DomStorageMap> map_;
+ scoped_refptr<DomStorageProxy> proxy_;
+ base::WeakPtrFactory<DomStorageCachedArea> weak_factory_;
+};
+
+} // namespace dom_storage
+
+#endif // WEBKIT_DOM_STORAGE_DOM_STORAGE_CACHED_AREA_H_
Property changes on: webkit\dom_storage\dom_storage_cached_area.h
___________________________________________________________________
Added: svn:eol-style
+ LF
« no previous file with comments | « no previous file | webkit/dom_storage/dom_storage_cached_area.cc » ('j') | webkit/dom_storage/dom_storage_cached_area_unittest.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698