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

Side by Side Diff: chrome/browser/notifications/notification_object_proxy.h

Issue 433273002: NotificationObjectProxy should own the DesktopNotificationDelegateImpl (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 CHROME_BROWSER_NOTIFICATIONS_NOTIFICATION_OBJECT_PROXY_H_ 5 #ifndef CHROME_BROWSER_NOTIFICATIONS_NOTIFICATION_OBJECT_PROXY_H_
6 #define CHROME_BROWSER_NOTIFICATIONS_NOTIFICATION_OBJECT_PROXY_H_ 6 #define CHROME_BROWSER_NOTIFICATIONS_NOTIFICATION_OBJECT_PROXY_H_
7 7
8 #include <string> 8 #include <string>
9 9
10 #include "base/memory/scoped_ptr.h"
10 #include "chrome/browser/notifications/notification_delegate.h" 11 #include "chrome/browser/notifications/notification_delegate.h"
11 12
12 namespace content { 13 namespace content {
13 class DesktopNotificationDelegate; 14 class DesktopNotificationDelegate;
14 class RenderFrameHost; 15 class RenderFrameHost;
15 } 16 }
16 17
17 // A NotificationObjectProxy stands in for the JavaScript Notification object 18 // A NotificationObjectProxy stands in for the JavaScript Notification object
18 // which corresponds to a notification toast on the desktop. It can be signaled 19 // which corresponds to a notification toast on the desktop. It can be signaled
19 // when various events occur regarding the desktop notification, and the 20 // when various events occur regarding the desktop notification, and the
20 // attached JS listeners will be invoked in the renderer or worker process. 21 // attached JS listeners will be invoked in the renderer or worker process.
21 class NotificationObjectProxy 22 class NotificationObjectProxy
22 : public NotificationDelegate { 23 : public NotificationDelegate {
23 public: 24 public:
24 // Creates a Proxy object with the necessary callback information. 25 // Creates a Proxy object with the necessary callback information. The Proxy
26 // will take ownership of |delegate|.
25 NotificationObjectProxy(content::RenderFrameHost* render_frame_host, 27 NotificationObjectProxy(content::RenderFrameHost* render_frame_host,
26 content::DesktopNotificationDelegate* delegate); 28 content::DesktopNotificationDelegate* delegate);
jochen (gone - plz use gerrit) 2014/08/04 09:11:24 you could make the parameter a scoped_ptr<> to mak
Peter Beverloo 2014/08/04 11:33:34 Done. Plumbed through the ContentBrowserClient as
27 29
28 // NotificationDelegate implementation. 30 // NotificationDelegate implementation.
29 virtual void Display() OVERRIDE; 31 virtual void Display() OVERRIDE;
30 virtual void Error() OVERRIDE; 32 virtual void Error() OVERRIDE;
31 virtual void Close(bool by_user) OVERRIDE; 33 virtual void Close(bool by_user) OVERRIDE;
32 virtual void Click() OVERRIDE; 34 virtual void Click() OVERRIDE;
33 virtual std::string id() const OVERRIDE; 35 virtual std::string id() const OVERRIDE;
34 virtual int process_id() const OVERRIDE; 36 virtual int process_id() const OVERRIDE;
35 virtual content::WebContents* GetWebContents() const OVERRIDE; 37 virtual content::WebContents* GetWebContents() const OVERRIDE;
36 38
37 protected: 39 protected:
38 friend class base::RefCountedThreadSafe<NotificationObjectProxy>; 40 friend class base::RefCountedThreadSafe<NotificationObjectProxy>;
39 41
40 virtual ~NotificationObjectProxy() {} 42 virtual ~NotificationObjectProxy();
41 43
42 private: 44 private:
43 // Callback information to find the JS Notification object where it lives. 45 // Callback information to find the JS Notification object where it lives.
44 int render_process_id_; 46 int render_process_id_;
45 int render_frame_id_; 47 int render_frame_id_;
46 content::DesktopNotificationDelegate* delegate_; 48 scoped_ptr<content::DesktopNotificationDelegate> delegate_;
47 bool displayed_; 49 bool displayed_;
48 std::string id_; 50 std::string id_;
49 }; 51 };
50 52
51 #endif // CHROME_BROWSER_NOTIFICATIONS_NOTIFICATION_OBJECT_PROXY_H_ 53 #endif // CHROME_BROWSER_NOTIFICATIONS_NOTIFICATION_OBJECT_PROXY_H_
OLDNEW
« no previous file with comments | « chrome/browser/notifications/notification_browsertest.cc ('k') | chrome/browser/notifications/notification_object_proxy.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698