| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2010 Google Inc. All rights reserved. | 2 * Copyright (C) 2010 Google Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
| 6 * are met: | 6 * are met: |
| 7 * | 7 * |
| 8 * 1. Redistributions of source code must retain the above copyright | 8 * 1. Redistributions of source code must retain the above copyright |
| 9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
| 10 * 2. Redistributions in binary form must reproduce the above copyright | 10 * 2. Redistributions in binary form must reproduce the above copyright |
| (...skipping 22 matching lines...) Expand all Loading... |
| 33 #include "core/events/EventListener.h" | 33 #include "core/events/EventListener.h" |
| 34 #include "modules/EventModules.h" | 34 #include "modules/EventModules.h" |
| 35 #include "modules/EventTargetModules.h" | 35 #include "modules/EventTargetModules.h" |
| 36 #include "modules/ModulesExport.h" | 36 #include "modules/ModulesExport.h" |
| 37 #include "modules/indexeddb/IDBMetadata.h" | 37 #include "modules/indexeddb/IDBMetadata.h" |
| 38 #include "modules/indexeddb/IndexedDB.h" | 38 #include "modules/indexeddb/IndexedDB.h" |
| 39 #include "platform/heap/Handle.h" | 39 #include "platform/heap/Handle.h" |
| 40 #include "public/platform/modules/indexeddb/WebIDBDatabase.h" | 40 #include "public/platform/modules/indexeddb/WebIDBDatabase.h" |
| 41 #include "public/platform/modules/indexeddb/WebIDBTypes.h" | 41 #include "public/platform/modules/indexeddb/WebIDBTypes.h" |
| 42 #include "wtf/HashSet.h" | 42 #include "wtf/HashSet.h" |
| 43 #include "wtf/Vector.h" |
| 43 | 44 |
| 44 namespace blink { | 45 namespace blink { |
| 45 | 46 |
| 46 class DOMException; | 47 class DOMException; |
| 47 class ExceptionState; | 48 class ExceptionState; |
| 48 class IDBDatabase; | 49 class IDBDatabase; |
| 50 class IDBIndex; |
| 49 class IDBObjectStore; | 51 class IDBObjectStore; |
| 50 class IDBOpenDBRequest; | 52 class IDBOpenDBRequest; |
| 51 | 53 |
| 52 class MODULES_EXPORT IDBTransaction final : public EventTargetWithInlineData, | 54 class MODULES_EXPORT IDBTransaction final : public EventTargetWithInlineData, |
| 53 public ActiveScriptWrappable, | 55 public ActiveScriptWrappable, |
| 54 public ActiveDOMObject { | 56 public ActiveDOMObject { |
| 55 USING_GARBAGE_COLLECTED_MIXIN(IDBTransaction); | 57 USING_GARBAGE_COLLECTED_MIXIN(IDBTransaction); |
| 56 DEFINE_WRAPPERTYPEINFO(); | 58 DEFINE_WRAPPERTYPEINFO(); |
| 57 | 59 |
| 58 public: | 60 public: |
| (...skipping 28 matching lines...) Expand all Loading... |
| 87 // Implement the IDBTransaction IDL | 89 // Implement the IDBTransaction IDL |
| 88 const String& mode() const; | 90 const String& mode() const; |
| 89 DOMStringList* objectStoreNames() const; | 91 DOMStringList* objectStoreNames() const; |
| 90 IDBDatabase* db() const { return m_database.get(); } | 92 IDBDatabase* db() const { return m_database.get(); } |
| 91 DOMException* error() const { return m_error; } | 93 DOMException* error() const { return m_error; } |
| 92 IDBObjectStore* objectStore(const String& name, ExceptionState&); | 94 IDBObjectStore* objectStore(const String& name, ExceptionState&); |
| 93 void abort(ExceptionState&); | 95 void abort(ExceptionState&); |
| 94 | 96 |
| 95 void registerRequest(IDBRequest*); | 97 void registerRequest(IDBRequest*); |
| 96 void unregisterRequest(IDBRequest*); | 98 void unregisterRequest(IDBRequest*); |
| 97 void objectStoreCreated(const String&, IDBObjectStore*); | 99 |
| 98 void objectStoreDeleted(const String&); | 100 // The methods below are called right before the changes are applied to the |
| 101 // database's metadata. We use this unusual sequencing because some of the |
| 102 // methods below need to access the metadata values before the change, and |
| 103 // following the same lifecycle for all methods makes the code easier to |
| 104 // reason about. |
| 105 void objectStoreCreated(const String& name, IDBObjectStore*); |
| 106 void objectStoreDeleted(const int64_t objectStoreId, const String& name); |
| 99 void objectStoreRenamed(const String& oldName, const String& newName); | 107 void objectStoreRenamed(const String& oldName, const String& newName); |
| 108 // Called when deleting an index whose IDBIndex had been created. |
| 109 void indexDeleted(IDBIndex*); |
| 110 |
| 100 void setActive(bool); | 111 void setActive(bool); |
| 101 void setError(DOMException*); | 112 void setError(DOMException*); |
| 102 | 113 |
| 103 DEFINE_ATTRIBUTE_EVENT_LISTENER(abort); | 114 DEFINE_ATTRIBUTE_EVENT_LISTENER(abort); |
| 104 DEFINE_ATTRIBUTE_EVENT_LISTENER(complete); | 115 DEFINE_ATTRIBUTE_EVENT_LISTENER(complete); |
| 105 DEFINE_ATTRIBUTE_EVENT_LISTENER(error); | 116 DEFINE_ATTRIBUTE_EVENT_LISTENER(error); |
| 106 | 117 |
| 107 void onAbort(DOMException*); | 118 void onAbort(DOMException*); |
| 108 void onComplete(); | 119 void onComplete(); |
| 109 | 120 |
| 110 // EventTarget | 121 // EventTarget |
| 111 const AtomicString& interfaceName() const override; | 122 const AtomicString& interfaceName() const override; |
| 112 ExecutionContext* getExecutionContext() const override; | 123 ExecutionContext* getExecutionContext() const override; |
| 113 | 124 |
| 114 // ScriptWrappable | 125 // ScriptWrappable |
| 115 bool hasPendingActivity() const final; | 126 bool hasPendingActivity() const final; |
| 116 | 127 |
| 117 // ActiveDOMObject | 128 // ActiveDOMObject |
| 118 void contextDestroyed() override; | 129 void contextDestroyed() override; |
| 119 | 130 |
| 131 // Object store IDs are allocated sequentially, so we can tell if an object |
| 132 // store was created in this transaction by comparing its ID against the |
| 133 // database's maximum object store ID at the time when the transaction was |
| 134 // started. |
| 135 int64_t oldMaxObjectStoreId() const { |
| 136 DCHECK(isVersionChange()); |
| 137 return m_oldDatabaseMetadata.maxObjectStoreId; |
| 138 } |
| 139 |
| 120 protected: | 140 protected: |
| 121 // EventTarget | 141 // EventTarget |
| 122 DispatchEventResult dispatchEventInternal(Event*) override; | 142 DispatchEventResult dispatchEventInternal(Event*) override; |
| 123 | 143 |
| 124 private: | 144 private: |
| 145 using IDBObjectStoreMap = HeapHashMap<String, Member<IDBObjectStore>>; |
| 146 |
| 125 IDBTransaction(ScriptState*, | 147 IDBTransaction(ScriptState*, |
| 126 int64_t, | 148 int64_t, |
| 127 const HashSet<String>&, | 149 const HashSet<String>&, |
| 128 WebIDBTransactionMode, | 150 WebIDBTransactionMode, |
| 129 IDBDatabase*, | 151 IDBDatabase*, |
| 130 IDBOpenDBRequest*, | 152 IDBOpenDBRequest*, |
| 131 const IDBDatabaseMetadata&); | 153 const IDBDatabaseMetadata&); |
| 132 | 154 |
| 133 void enqueueEvent(Event*); | 155 void enqueueEvent(Event*); |
| 134 | 156 |
| (...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 176 #endif // DCHECK_IS_ON() | 198 #endif // DCHECK_IS_ON() |
| 177 | 199 |
| 178 // Caches the IDBObjectStore instances returned by the objectStore() method. | 200 // Caches the IDBObjectStore instances returned by the objectStore() method. |
| 179 // | 201 // |
| 180 // The spec requires that a transaction's objectStore() returns the same | 202 // The spec requires that a transaction's objectStore() returns the same |
| 181 // IDBObjectStore instance for a specific store, so this cache is necessary | 203 // IDBObjectStore instance for a specific store, so this cache is necessary |
| 182 // for correctness. | 204 // for correctness. |
| 183 // | 205 // |
| 184 // objectStore() throws for completed/aborted transactions, so this is not | 206 // objectStore() throws for completed/aborted transactions, so this is not |
| 185 // used after a transaction is finished, and can be cleared. | 207 // used after a transaction is finished, and can be cleared. |
| 186 using IDBObjectStoreMap = HeapHashMap<String, Member<IDBObjectStore>>; | |
| 187 IDBObjectStoreMap m_objectStoreMap; | 208 IDBObjectStoreMap m_objectStoreMap; |
| 188 | 209 |
| 189 // Used to mark stores created in an aborted upgrade transaction as | 210 // The metadata of object stores when they are opened by this transaction. |
| 190 // deleted. | 211 // |
| 191 HeapHashSet<Member<IDBObjectStore>> m_createdObjectStores; | 212 // Only valid for versionchange transactions. |
| 213 HeapHashMap<Member<IDBObjectStore>, RefPtr<IDBObjectStoreMetadata>> |
| 214 m_oldStoreMetadata; |
| 192 | 215 |
| 193 // Used to notify object stores (which are no longer in m_objectStoreMap) | 216 // The metadata of deleted object stores without IDBObjectStore instances. |
| 194 // when the transaction is finished. | 217 // |
| 195 HeapHashSet<Member<IDBObjectStore>> m_deletedObjectStores; | 218 // Only valid for versionchange transactions. |
| 219 Vector<RefPtr<IDBObjectStoreMetadata>> m_deletedObjectStores; |
| 196 | 220 |
| 197 // Holds stores created, deleted, or used during upgrade transactions to | 221 // Tracks the indexes deleted by this transaction. |
| 198 // reset metadata in case of abort. | 222 // |
| 199 HeapHashMap<Member<IDBObjectStore>, IDBObjectStoreMetadata> | 223 // This set only includes indexes that were created before this transaction, |
| 200 m_objectStoreCleanupMap; | 224 // and were deleted during this transaction. Once marked for deletion, these |
| 225 // indexes are removed from their object stores' index maps, so we need to |
| 226 // stash them somewhere else in case the transaction gets aborted. |
| 227 // |
| 228 // This set does not include indexes created and deleted during this |
| 229 // transaction, because we don't need to change their metadata when the |
| 230 // transaction aborts, as they will still be marked for deletion. |
| 231 // |
| 232 // Only valid for versionchange transactions. |
| 233 HeapVector<Member<IDBIndex>> m_deletedIndexes; |
| 201 | 234 |
| 235 // Shallow snapshot of the database metadata when the transaction starts. |
| 236 // |
| 237 // This does not include a snapshot of the database's object store / index |
| 238 // metadata. |
| 239 // |
| 240 // Only valid for versionchange transactions. |
| 202 IDBDatabaseMetadata m_oldDatabaseMetadata; | 241 IDBDatabaseMetadata m_oldDatabaseMetadata; |
| 203 }; | 242 }; |
| 204 | 243 |
| 205 } // namespace blink | 244 } // namespace blink |
| 206 | 245 |
| 207 #endif // IDBTransaction_h | 246 #endif // IDBTransaction_h |
| OLD | NEW |