Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code

Delta Between Two Patch Sets: include/AdblockPlus/Notification.h

Issue 29419629: Issue 5164 - Remove NotificationPtr (Closed) Base URL: https://hg.adblockplus.org/libadblockplus/
Left Patch Set: Created April 21, 2017, 2:08 p.m.
Right Patch Set: Call the inherited assignment operator properly Created April 24, 2017, 8:16 p.m.
Left:
Right:
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
Left: Side by side diff | Download
Right: Side by side diff | Download
« no previous file with change/comment | « include/AdblockPlus/FilterEngine.h ('k') | src/FilterEngine.cpp » ('j') | no next file with change/comment »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
LEFTRIGHT
1 /* 1 /*
2 * This file is part of Adblock Plus <https://adblockplus.org/>, 2 * This file is part of Adblock Plus <https://adblockplus.org/>,
3 * Copyright (C) 2006-2017 eyeo GmbH 3 * Copyright (C) 2006-2017 eyeo GmbH
4 * 4 *
5 * Adblock Plus is free software: you can redistribute it and/or modify 5 * Adblock Plus is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 3 as 6 * it under the terms of the GNU General Public License version 3 as
7 * published by the Free Software Foundation. 7 * published by the Free Software Foundation.
8 * 8 *
9 * Adblock Plus is distributed in the hope that it will be useful, 9 * Adblock Plus is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after
45 std::string message; 45 std::string message;
46 }; 46 };
47 47
48 /** 48 /**
49 * Wrapper for an Adblock Plus notification object. 49 * Wrapper for an Adblock Plus notification object.
50 */ 50 */
51 class Notification: public JsValue, 51 class Notification: public JsValue,
52 public std::enable_shared_from_this<Notification> 52 public std::enable_shared_from_this<Notification>
53 { 53 {
54 friend class FilterEngine; 54 friend class FilterEngine;
55 public: 55 protected:
56 /** 56 /**
57 * Constructor. 57 * Constructor.
58 * @param jsValue `JsValue&&` notification JavaScript object. 58 * @param jsValue `JsValue&&` notification JavaScript object.
59 */ 59 */
60 explicit Notification(JsValue&& jsValue); 60 explicit Notification(JsValue&& jsValue);
sergei 2017/04/21 15:30:33 I don't think it's a good idea to make this constr
hub 2017/04/21 16:29:31 It was for the tests. I'll find a way.
61 public:
62 /**
63 * Copy constructor
64 */
65 Notification(const Notification& src);
66
67 /**
68 * Move constructor
69 */
70 Notification(Notification&& src);
71
72 /**
73 * Assignment operator
74 */
75 Notification& operator=(const Notification& src);
76
77 /**
78 * Move assignment operator
79 */
80 Notification& operator=(Notification&& src);
61 81
62 /** 82 /**
63 * Retrieves the type of this notification. 83 * Retrieves the type of this notification.
64 * @return Type of this notification. 84 * @return Type of this notification.
65 */ 85 */
66 NotificationType GetType() const; 86 NotificationType GetType() const;
67 87
68 /** 88 /**
69 * Retrieves the title and message of this notification. 89 * Retrieves the title and message of this notification.
70 * @return Translated texts. 90 * @return Translated texts.
71 */ 91 */
72 NotificationTexts GetTexts() const; 92 NotificationTexts GetTexts() const;
73 93
74 /** 94 /**
75 * Retrieves the URLs which should be mapped to the links in the message. 95 * Retrieves the URLs which should be mapped to the links in the message.
76 * @return List of links. 96 * @return List of links.
77 */ 97 */
78 std::vector<std::string> GetLinks() const; 98 std::vector<std::string> GetLinks() const;
79 99
80 /** 100 /**
81 * Marks this notification as shown. It is only relevant for question 101 * Marks this notification as shown. It is only relevant for question
82 * notifications. Other notifications are marked automatically. 102 * notifications. Other notifications are marked automatically.
83 */ 103 */
84 void MarkAsShown(); 104 void MarkAsShown();
85 private: 105 private:
86 }; 106 };
87 } 107 }
88 108
89 #endif 109 #endif
LEFTRIGHT

Powered by Google App Engine
This is Rietveld