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

Side by Side Diff: third_party/WebKit/Source/modules/indexeddb/IDBObserver.h

Issue 2125213002: [IndexedDB] Propogating changes to observers : Renderer (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@lifetime
Patch Set: IDBDatabase weakptr introduced on IDBObserver Created 4 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 unified diff | Download patch
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 IDBObserver_h 5 #ifndef IDBObserver_h
6 #define IDBObserver_h 6 #define IDBObserver_h
7 7
8 #include "bindings/core/v8/ScriptWrappable.h" 8 #include "bindings/core/v8/ScriptWrappable.h"
9 #include "modules/ModulesExport.h" 9 #include "modules/ModulesExport.h"
10 #include "platform/heap/Handle.h" 10 #include "platform/heap/Handle.h"
11 #include "public/platform/modules/indexeddb/WebIDBTypes.h"
11 #include <set> 12 #include <set>
12 13
13 namespace blink { 14 namespace blink {
14 15
15 class ExceptionState; 16 class ExceptionState;
16 class IDBDatabase; 17 class IDBDatabase;
17 class IDBObserverCallback; 18 class IDBObserverCallback;
18 class IDBObserverInit; 19 class IDBObserverInit;
19 class IDBTransaction; 20 class IDBTransaction;
21 struct WebIDBObservation;
20 22
21 class MODULES_EXPORT IDBObserver final : public GarbageCollectedFinalized<IDBObs erver>, public ScriptWrappable { 23 class MODULES_EXPORT IDBObserver final : public GarbageCollectedFinalized<IDBObs erver>, public ScriptWrappable {
22 DEFINE_WRAPPERTYPEINFO(); 24 DEFINE_WRAPPERTYPEINFO();
23 25
24 public: 26 public:
25 static IDBObserver* create(IDBObserverCallback&, const IDBObserverInit&); 27 static IDBObserver* create(IDBObserverCallback&, const IDBObserverInit&);
26 28
27 ~IDBObserver(); 29 ~IDBObserver();
30
28 // API methods 31 // API methods
Marijn Kruisselbrink 2016/07/11 23:10:40 I'm not sure what the "API methods" and "API Attri
palakj1 2016/07/13 00:43:51 Removed. Not aware of the right comments to put he
29 void observe(IDBDatabase*, IDBTransaction*, ExceptionState&); 32 void observe(IDBDatabase*, IDBTransaction*, ExceptionState&);
30 void unobserve(IDBDatabase*, ExceptionState&); 33 void unobserve(IDBDatabase*, ExceptionState&);
31 void removeObserver(int32_t id); 34 void removeObserver(int32_t id);
35 void onChange(int32_t id, const std::vector<WebIDBObservation>&, const std:: vector<int32_t>& observation_index);
36
37 // API Attributes
38 bool transaction() const { return m_transaction; }
39 bool noRecords() const { return m_noRecords; }
40 bool values() const { return m_values; }
32 41
33 DECLARE_TRACE(); 42 DECLARE_TRACE();
34 43
35 private: 44 private:
36 IDBObserver(IDBObserverCallback&, const IDBObserverInit&); 45 IDBObserver(IDBObserverCallback&, const IDBObserverInit&);
37 46
38 Member<IDBObserverCallback> m_callback; 47 Member<IDBObserverCallback> m_callback;
39 bool m_transaction; 48 bool m_transaction;
40 bool m_values; 49 bool m_values;
41 bool m_noRecords; 50 bool m_noRecords;
42 std::set<int32_t> m_observerIds; 51 std::map<int32_t, WeakMember<IDBDatabase>> m_observerIds;
Marijn Kruisselbrink 2016/07/11 23:10:40 You should not use stl containers to hold referenc
palakj1 2016/07/13 00:43:51 Changed stl container to heaphashmap. As discussed
43 }; 52 };
44 53
45 } // namespace blink 54 } // namespace blink
46 55
47 #endif // IDBObserver_h 56 #endif // IDBObserver_h
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698