OLD | NEW |
---|---|
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. Use of this | 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. Use of this |
2 // source code is governed by a BSD-style license that can be found in the | 2 // source code is governed by a BSD-style license that can be found in the |
3 // LICENSE file. | 3 // LICENSE file. |
4 | 4 |
5 #include "content/browser/in_process_webkit/dom_storage_namespace.h" | 5 #include "content/browser/in_process_webkit/dom_storage_namespace.h" |
6 | 6 |
7 #include "base/file_path.h" | 7 #include "base/file_path.h" |
8 #include "content/browser/in_process_webkit/dom_storage_area.h" | 8 #include "content/browser/in_process_webkit/dom_storage_area.h" |
9 #include "content/browser/in_process_webkit/dom_storage_context.h" | 9 #include "content/browser/in_process_webkit/dom_storage_context.h" |
10 #include "content/browser/in_process_webkit/dom_storage_message_filter.h" | 10 #include "content/browser/in_process_webkit/dom_storage_message_filter.h" |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
47 DOMStorageNamespace::~DOMStorageNamespace() { | 47 DOMStorageNamespace::~DOMStorageNamespace() { |
48 // TODO(jorlow): If the DOMStorageContext is being destructed, there's no need | 48 // TODO(jorlow): If the DOMStorageContext is being destructed, there's no need |
49 // to do these calls. Maybe we should add a fast path? | 49 // to do these calls. Maybe we should add a fast path? |
50 for (OriginToStorageAreaMap::iterator iter(origin_to_storage_area_.begin()); | 50 for (OriginToStorageAreaMap::iterator iter(origin_to_storage_area_.begin()); |
51 iter != origin_to_storage_area_.end(); ++iter) { | 51 iter != origin_to_storage_area_.end(); ++iter) { |
52 dom_storage_context_->UnregisterStorageArea(iter->second); | 52 dom_storage_context_->UnregisterStorageArea(iter->second); |
53 delete iter->second; | 53 delete iter->second; |
54 } | 54 } |
55 } | 55 } |
56 | 56 |
57 DOMStorageArea* DOMStorageNamespace::GetStorageArea(const string16& origin) { | 57 DOMStorageArea* DOMStorageNamespace::GetStorageArea( |
58 const string16& origin, | |
59 bool enforce_session_only_storage) { | |
58 // We may have already created it for another dispatcher host. | 60 // We may have already created it for another dispatcher host. |
59 OriginToStorageAreaMap::iterator iter = origin_to_storage_area_.find(origin); | 61 DOMStorageArea* storage_area = GetExistingStorageArea(origin); |
60 if (iter != origin_to_storage_area_.end()) | 62 if (storage_area) |
61 return iter->second; | 63 return storage_area; |
62 | 64 |
63 // We need to create a new one. | 65 // Also, our session-only sibling might have it. (This is independent of what |
64 int64 id = dom_storage_context_->AllocateStorageAreaId(); | 66 // the content settings say; it might be that the settings were changed after |
65 DCHECK(!dom_storage_context_->GetStorageArea(id)); | 67 // the DOMStorageArea was created.) |
66 DOMStorageArea* storage_area = new DOMStorageArea(origin, id, this); | 68 if (session_only_local_storage_.get()) { |
67 origin_to_storage_area_[origin] = storage_area; | 69 storage_area = session_only_local_storage_->GetExistingStorageArea(origin); |
68 dom_storage_context_->RegisterStorageArea(storage_area); | 70 if (storage_area) |
69 return storage_area; | 71 return storage_area; |
72 } | |
73 | |
74 // Else, we need to create a new DOMStorageArea. | |
75 if (enforce_session_only_storage && ShouldHaveSessionOnlyLocalStorage()) { | |
76 EnsureSessionOnlyLocalStorageCreated(); | |
77 return session_only_local_storage_->CreateStorageArea(origin); | |
78 } | |
79 return CreateStorageArea(origin); | |
70 } | 80 } |
71 | 81 |
72 DOMStorageNamespace* DOMStorageNamespace::Copy(int64 id) { | 82 DOMStorageNamespace* DOMStorageNamespace::Copy(int64 id) { |
73 DCHECK(dom_storage_type_ == DOM_STORAGE_SESSION); | 83 DCHECK(dom_storage_type_ == DOM_STORAGE_SESSION); |
74 DCHECK(!dom_storage_context_->GetStorageNamespace(id, false)); | 84 DCHECK(!dom_storage_context_->GetStorageNamespace(id, false)); |
75 DOMStorageNamespace* new_storage_namespace = new DOMStorageNamespace( | 85 DOMStorageNamespace* new_storage_namespace = new DOMStorageNamespace( |
76 dom_storage_context_, id, data_dir_path_, dom_storage_type_); | 86 dom_storage_context_, id, data_dir_path_, dom_storage_type_); |
77 // If we haven't used the namespace yet, there's nothing to copy. | 87 // If we haven't used the namespace yet, there's nothing to copy. |
78 if (storage_namespace_.get()) | 88 if (storage_namespace_.get()) |
79 new_storage_namespace->storage_namespace_.reset(storage_namespace_->copy()); | 89 new_storage_namespace->storage_namespace_.reset(storage_namespace_->copy()); |
(...skipping 20 matching lines...) Expand all Loading... | |
100 | 110 |
101 if (dom_storage_type_ == DOM_STORAGE_LOCAL) { | 111 if (dom_storage_type_ == DOM_STORAGE_LOCAL) { |
102 storage_namespace_.reset( | 112 storage_namespace_.reset( |
103 WebStorageNamespace::createLocalStorageNamespace(data_dir_path_, | 113 WebStorageNamespace::createLocalStorageNamespace(data_dir_path_, |
104 WebStorageNamespace::m_localStorageQuota)); | 114 WebStorageNamespace::m_localStorageQuota)); |
105 } else { | 115 } else { |
106 storage_namespace_.reset(WebStorageNamespace::createSessionStorageNamespace( | 116 storage_namespace_.reset(WebStorageNamespace::createSessionStorageNamespace( |
107 WebStorageNamespace::m_sessionStorageQuota)); | 117 WebStorageNamespace::m_sessionStorageQuota)); |
108 } | 118 } |
109 } | 119 } |
120 | |
121 DOMStorageArea* DOMStorageNamespace::GetExistingStorageArea( | |
122 const string16& origin) { | |
123 OriginToStorageAreaMap::iterator iter = origin_to_storage_area_.find(origin); | |
124 if (iter != origin_to_storage_area_.end()) | |
125 return iter->second; | |
126 return NULL; | |
127 } | |
128 | |
129 DOMStorageArea* DOMStorageNamespace::CreateStorageArea(const string16& origin) { | |
130 int64 id = dom_storage_context_->AllocateStorageAreaId(); | |
131 DCHECK(!dom_storage_context_->GetStorageArea(id)); | |
132 DOMStorageArea* storage_area = new DOMStorageArea(origin, id, this); | |
133 origin_to_storage_area_[origin] = storage_area; | |
134 dom_storage_context_->RegisterStorageArea(storage_area); | |
135 return storage_area; | |
136 } | |
137 | |
138 bool DOMStorageNamespace::ShouldHaveSessionOnlyLocalStorage() const { | |
139 if (dom_storage_type_ == DOM_STORAGE_LOCAL && !data_dir_path_.isEmpty()) { | |
140 // This DOMStorageNamespace represents a permanent localStorage; it should | |
141 // have a sibling DOMStorageNamespace that represents the corresponding | |
142 // session-only storage. | |
143 return true; | |
michaeln
2011/08/04 20:21:51
maybe simplify as
return (type == LOCAL) && !path.
marja
2011/08/05 13:15:53
Done.
| |
144 } | |
145 return false; | |
146 } | |
147 | |
148 void DOMStorageNamespace::EnsureSessionOnlyLocalStorageCreated() { | |
149 if (session_only_local_storage_.get() == NULL) { | |
150 session_only_local_storage_.reset( | |
151 new DOMStorageNamespace(dom_storage_context_, | |
152 id_, | |
153 WebString(), | |
154 dom_storage_type_)); | |
155 } | |
156 } | |
OLD | NEW |