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

Side by Side Diff: content/browser/in_process_webkit/dom_storage_context.h

Issue 8929007: Restore sessionStorage when chrome restarts. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix: cloning storage areas. Created 8 years, 11 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CONTENT_BROWSER_IN_PROCESS_WEBKIT_DOM_STORAGE_CONTEXT_H_ 5 #ifndef CONTENT_BROWSER_IN_PROCESS_WEBKIT_DOM_STORAGE_CONTEXT_H_
6 #define CONTENT_BROWSER_IN_PROCESS_WEBKIT_DOM_STORAGE_CONTEXT_H_ 6 #define CONTENT_BROWSER_IN_PROCESS_WEBKIT_DOM_STORAGE_CONTEXT_H_
7 #pragma once 7 #pragma once
8 8
9 #include <map> 9 #include <map>
10 #include <set> 10 #include <set>
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after
60 DOMStorageArea* GetStorageArea(int64 id); 60 DOMStorageArea* GetStorageArea(int64 id);
61 61
62 // Called on WebKit thread when a session storage namespace can be deleted. 62 // Called on WebKit thread when a session storage namespace can be deleted.
63 void DeleteSessionStorageNamespace(int64 namespace_id); 63 void DeleteSessionStorageNamespace(int64 namespace_id);
64 64
65 // Get a namespace from an id. What's returned is owned by this class. If 65 // Get a namespace from an id. What's returned is owned by this class. If
66 // allocation_allowed is true, then this function will create the storage 66 // allocation_allowed is true, then this function will create the storage
67 // namespace if it hasn't been already. 67 // namespace if it hasn't been already.
68 DOMStorageNamespace* GetStorageNamespace(int64 id, bool allocation_allowed); 68 DOMStorageNamespace* GetStorageNamespace(int64 id, bool allocation_allowed);
69 69
70 // Creates a session storage namespace which is backed up by the existing
71 // |session_storage_directory|.
72 DOMStorageNamespace* RecreateSessionStorageNamespace(
73 int64 id,
74 const FilePath& session_storage_directory);
75
70 // Sometimes an event from one DOM storage message filter requires 76 // Sometimes an event from one DOM storage message filter requires
71 // communication to all of them. 77 // communication to all of them.
72 typedef std::set<DOMStorageMessageFilter*> MessageFilterSet; 78 typedef std::set<DOMStorageMessageFilter*> MessageFilterSet;
73 void RegisterMessageFilter(DOMStorageMessageFilter* message_filter); 79 void RegisterMessageFilter(DOMStorageMessageFilter* message_filter);
74 void UnregisterMessageFilter(DOMStorageMessageFilter* MessageFilter); 80 void UnregisterMessageFilter(DOMStorageMessageFilter* MessageFilter);
75 const MessageFilterSet* GetMessageFilterSet() const; 81 const MessageFilterSet* GetMessageFilterSet() const;
76 82
77 // Tells storage namespaces to purge any memory they do not need. 83 // Tells storage namespaces to purge any memory they do not need.
78 virtual void PurgeMemory(); 84 virtual void PurgeMemory();
79 85
80 // Delete any local storage files that have been touched since the cutoff 86 // Delete any local storage files that have been touched since the cutoff
81 // date that's supplied. Protected origins, per the SpecialStoragePolicy, 87 // date that's supplied. Protected origins, per the SpecialStoragePolicy,
82 // are not deleted by this method. 88 // are not deleted by this method.
83 void DeleteDataModifiedSince(const base::Time& cutoff); 89 void DeleteDataModifiedSince(const base::Time& cutoff);
84 90
85 // Deletes a single local storage file. 91 // Deletes a single local storage file.
86 void DeleteLocalStorageFile(const FilePath& file_path); 92 void DeleteLocalStorageFile(const FilePath& file_path);
87 93
88 // Deletes the local storage file for the given origin. 94 // Deletes the local storage file for the given origin.
89 void DeleteLocalStorageForOrigin(const string16& origin_id); 95 void DeleteLocalStorageForOrigin(const string16& origin_id);
90 96
91 // Deletes all local storage files. 97 // Deletes all local storage files.
92 void DeleteAllLocalStorageFiles(); 98 void DeleteAllLocalStorageFiles();
93 99
94 // The local storage directory. 100 // The local storage directory.
95 static const FilePath::CharType kLocalStorageDirectory[]; 101 static const FilePath::CharType kLocalStorageDirectory[];
96 102
103 // The session storage directory.
104 static const FilePath::CharType kSessionStorageDirectory[];
105
97 // The local storage file extension. 106 // The local storage file extension.
98 static const FilePath::CharType kLocalStorageExtension[]; 107 static const FilePath::CharType kLocalStorageExtension[];
99 108
100 // Get the file name of the local storage file for the given origin. 109 // Get the file name of the local storage file for the given origin.
101 FilePath GetLocalStorageFilePath(const string16& origin_id) const; 110 FilePath GetLocalStorageFilePath(const string16& origin_id) const;
102 111
103 void set_clear_local_state_on_exit_(bool clear_local_state) { 112 void set_clear_local_state_on_exit_(bool clear_local_state) {
104 clear_local_state_on_exit_ = clear_local_state; 113 clear_local_state_on_exit_ = clear_local_state;
105 } 114 }
106 115
107 // Disables the exit-time deletion for all data (also session-only data). 116 // Disables the exit-time deletion for all data (also session-only data).
108 void SaveSessionState() { 117 void SaveSessionState() {
109 save_session_state_ = true; 118 save_session_state_ = true;
110 } 119 }
111 120
112 void set_data_path_for_testing(const FilePath& data_path) { 121 void set_data_path_for_testing(const FilePath& data_path) {
113 data_path_ = data_path; 122 data_path_ = data_path;
114 } 123 }
115 124
125 // Deletes the session storages which are not in |needed_session_storages|.
126 void DeleteUnneededSessionStorages(
127 const std::set<std::string>& needed_session_storages);
128
116 private: 129 private:
117 130
118 FRIEND_TEST_ALL_PREFIXES(DOMStorageTest, SessionOnly); 131 FRIEND_TEST_ALL_PREFIXES(DOMStorageTest, SessionOnly);
119 FRIEND_TEST_ALL_PREFIXES(DOMStorageTest, SaveSessionState); 132 FRIEND_TEST_ALL_PREFIXES(DOMStorageTest, SaveSessionState);
120 133
121 // Get the local storage instance. The object is owned by this class. 134 // Get the local storage instance. The object is owned by this class.
122 DOMStorageNamespace* CreateLocalStorage(); 135 DOMStorageNamespace* CreateLocalStorage();
123 136
124 // Get a new session storage namespace. The object is owned by this class. 137 // Get a new session storage namespace. The object is owned by this class.
125 DOMStorageNamespace* CreateSessionStorage(int64 namespace_id); 138 DOMStorageNamespace* CreateSessionStorage(int64 namespace_id);
126 139
127 // Used internally to register storage namespaces we create. 140 // Used internally to register storage namespaces we create.
128 void RegisterStorageNamespace(DOMStorageNamespace* storage_namespace); 141 void RegisterStorageNamespace(DOMStorageNamespace* storage_namespace);
129 142
130 // The WebKit thread half of CloneSessionStorage above. Static because 143 // The WebKit thread half of CloneSessionStorage above. Static because
131 // DOMStorageContext isn't ref counted thus we can't use a runnable method. 144 // DOMStorageContext isn't ref counted thus we can't use a runnable method.
132 // That said, we know this is safe because this class is destroyed on the 145 // That said, we know this is safe because this class is destroyed on the
133 // WebKit thread, so there's no way it could be destroyed before this is run. 146 // WebKit thread, so there's no way it could be destroyed before this is run.
134 static void CompleteCloningSessionStorage(DOMStorageContext* context, 147 static void CompleteCloningSessionStorage(DOMStorageContext* context,
135 int64 existing_id, int64 clone_id); 148 int64 existing_id, int64 clone_id,
149 const FilePath& data_path);
136 150
137 // The last used storage_area_id and storage_namespace_id's. For the storage 151 // The last used storage_area_id and storage_namespace_id's. For the storage
138 // namespaces, IDs allocated on the UI thread are positive and count up while 152 // namespaces, IDs allocated on the UI thread are positive and count up while
139 // IDs allocated on the IO thread are negative and count down. This allows us 153 // IDs allocated on the IO thread are negative and count down. This allows us
140 // to allocate unique IDs on both without any locking. All storage area ids 154 // to allocate unique IDs on both without any locking. All storage area ids
141 // are allocated on the WebKit thread. 155 // are allocated on the WebKit thread.
142 int64 last_storage_area_id_; 156 int64 last_storage_area_id_;
143 int64 last_session_storage_namespace_id_on_ui_thread_; 157 int64 last_session_storage_namespace_id_on_ui_thread_;
144 int64 last_session_storage_namespace_id_on_io_thread_; 158 int64 last_session_storage_namespace_id_on_io_thread_;
145 159
(...skipping 22 matching lines...) Expand all
168 // Maps ids to StorageNamespaces. We own these objects. 182 // Maps ids to StorageNamespaces. We own these objects.
169 typedef std::map<int64, DOMStorageNamespace*> StorageNamespaceMap; 183 typedef std::map<int64, DOMStorageNamespace*> StorageNamespaceMap;
170 StorageNamespaceMap storage_namespace_map_; 184 StorageNamespaceMap storage_namespace_map_;
171 185
172 scoped_refptr<quota::SpecialStoragePolicy> special_storage_policy_; 186 scoped_refptr<quota::SpecialStoragePolicy> special_storage_policy_;
173 187
174 DISALLOW_IMPLICIT_CONSTRUCTORS(DOMStorageContext); 188 DISALLOW_IMPLICIT_CONSTRUCTORS(DOMStorageContext);
175 }; 189 };
176 190
177 #endif // CONTENT_BROWSER_IN_PROCESS_WEBKIT_DOM_STORAGE_CONTEXT_H_ 191 #endif // CONTENT_BROWSER_IN_PROCESS_WEBKIT_DOM_STORAGE_CONTEXT_H_
OLDNEW
« no previous file with comments | « content/browser/in_process_webkit/dom_storage_area.cc ('k') | content/browser/in_process_webkit/dom_storage_context.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698