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

Side by Side Diff: Source/modules/push_messaging/PushPermissionStatusCallbacks.h

Issue 1233173002: Have ScriptPromiseResolver on the Oilpan heap always. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: fix webusb ScriptPromiseResolver usage Created 5 years, 4 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 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 PushPermissionStatusCallbacks_h 5 #ifndef PushPermissionStatusCallbacks_h
6 #define PushPermissionStatusCallbacks_h 6 #define PushPermissionStatusCallbacks_h
7 7
8 #include "platform/heap/Handle.h" 8 #include "platform/heap/Handle.h"
9 #include "public/platform/modules/push_messaging/WebPushPermissionStatus.h" 9 #include "public/platform/modules/push_messaging/WebPushPermissionStatus.h"
10 #include "public/platform/modules/push_messaging/WebPushProvider.h" 10 #include "public/platform/modules/push_messaging/WebPushProvider.h"
11 #include "wtf/Noncopyable.h" 11 #include "wtf/Noncopyable.h"
12 #include "wtf/PassRefPtr.h"
13 #include "wtf/RefPtr.h"
14 12
15 namespace WTF { 13 namespace WTF {
16 class String; 14 class String;
17 } 15 }
18 16
19 namespace blink { 17 namespace blink {
20 18
21 class ScriptPromiseResolver; 19 class ScriptPromiseResolver;
22 20
23 // Will resolve the underlying promise depending on the permission received. 21 // Will resolve the underlying promise depending on the permission received.
24 class PushPermissionStatusCallbacks final : public WebPushPermissionStatusCallba cks { 22 class PushPermissionStatusCallbacks final : public WebPushPermissionStatusCallba cks {
25 WTF_MAKE_NONCOPYABLE(PushPermissionStatusCallbacks); 23 WTF_MAKE_NONCOPYABLE(PushPermissionStatusCallbacks);
26 24
27 public: 25 public:
28 explicit PushPermissionStatusCallbacks(PassRefPtrWillBeRawPtr<ScriptPromiseR esolver>); 26 explicit PushPermissionStatusCallbacks(ScriptPromiseResolver*);
29 ~PushPermissionStatusCallbacks() override; 27 ~PushPermissionStatusCallbacks() override;
30 28
31 void onSuccess(WebPushPermissionStatus*) override; 29 void onSuccess(WebPushPermissionStatus*) override;
32 30
33 // Called if for some reason the status of the push permission cannot be che cked. 31 // Called if for some reason the status of the push permission cannot be che cked.
34 void onError(WebPushError*) override; 32 void onError(WebPushError*) override;
35 33
36 private: 34 private:
37 static WTF::String permissionString(WebPushPermissionStatus); 35 static WTF::String permissionString(WebPushPermissionStatus);
38 RefPtrWillBePersistent<ScriptPromiseResolver> m_resolver; 36 Persistent<ScriptPromiseResolver> m_resolver;
39 }; 37 };
40 38
41 } // namespace blink 39 } // namespace blink
42 40
43 #endif // PushPermissionStatusCallbacks_h 41 #endif // PushPermissionStatusCallbacks_h
OLDNEW
« no previous file with comments | « Source/modules/push_messaging/PushManager.cpp ('k') | Source/modules/push_messaging/PushPermissionStatusCallbacks.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698