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

Unified Diff: chrome/browser/notifier/synced_notification.h

Issue 11745024: Synced Notification Sync Change Processor (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: SyncedNotifications - first round of CR comment fixes. Created 7 years, 11 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/notifier/synced_notification.h
diff --git a/chrome/browser/notifier/synced_notification.h b/chrome/browser/notifier/synced_notification.h
new file mode 100644
index 0000000000000000000000000000000000000000..e11ee0e1715e3515a1d4f1accd26b9a83c5210be
--- /dev/null
+++ b/chrome/browser/notifier/synced_notification.h
@@ -0,0 +1,76 @@
+// Copyright (c) 2012 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+// This class represents the data for a single Synced Notification.
+// It should map 1-1 to all the data in synced_notification_sepcifics.proto,
+// and the data and render protobufs that the specifics protobuf contains.
+
+#ifndef CHROME_BROWSER_NOTIFIER_SYNCED_NOTIFICATION_H_
+#define CHROME_BROWSER_NOTIFIER_SYNCED_NOTIFICATION_H_
+
+#include "sync/api/sync_data.h"
+#include "sync/protocol/sync.pb.h"
+#include "sync/protocol/synced_notification_specifics.pb.h"
+
+namespace sync_pb {
+
+class SyncedNotificationSpecifics;
+
+class SyncedNotification {
+ public:
+ explicit SyncedNotification(const syncer::SyncData sync_data);
dcheng 2013/01/18 21:56:13 Pass by const reference please.
Pete Williamson 2013/01/23 01:45:55 Done.
+
+ ~SyncedNotification();
+
+ // Here are some helper functions to get individual data parts out of a
+ // syncedNotification protobuf.
+ const std::string get_title() const;
dcheng 2013/01/18 21:56:13 GetTitle. Ditto for everything else.
Pete Williamson 2013/01/23 01:45:55 Done.
+ const std::string get_app_id() const;
+ const std::string get_coalescing_key() const;
+ const std::string get_origin_url() const;
+ const std::string get_icon_url() const;
+
+ const std::string get_first_external_id() const;
+ const std::string get_notification_id() const;
+ const std::string get_body() const;
+
+ bool Equals(const SyncedNotification& other) const;
+
+ void set_has_local_changes(bool has_local_changes) {
+ has_local_changes_ = has_local_changes;
+ }
+
+ bool has_local_changes() const {
+ return has_local_changes_;
+ }
+
+ syncer::SyncData* mutable_sync_data() {
+ return &sync_data_;
+ }
+
+ void NotificationHasBeenRead();
+
+ void NotificationHasBeenDeleted();
+
+ // This gets a pointer to the SyncedNotificationSpecifics part
+ // of the sync data. This is owned by the SyncedNotification class
+ // (actually refcounted, so it is jointly owned with sync).
+ // Don't free this pointer!
+ const sync_pb::SyncedNotificationSpecifics* GetSyncedNotificationSpecifics();
+
+ private:
+ // helper function to mark a notification as read or dismissed.
+ bool SetReadState(
+ SyncedNotificationCoalescedNotification_ReadState readState);
+ // This keeps the SyncNotificationSpecifics alive by putting
+ // it into the contained sync entity.
dcheng 2013/01/18 21:56:13 I really don't understand what this comment means.
Nicolas Zea 2013/01/18 23:09:25 Is the only reason you keep around the sync data t
Pete Williamson 2013/01/23 01:45:55 Moved comment to the .cc file
Pete Williamson 2013/01/23 01:45:55 My thinking in keeping it around is that I need to
Nicolas Zea 2013/01/25 00:18:45 I think it would be better to compare by having tw
Pete Williamson 2013/01/25 19:58:36 As it turns out, there is another reason to keep t
+ syncer::SyncData sync_data_;
dcheng 2013/01/18 21:56:13 Extra space.
Pete Williamson 2013/01/23 01:45:55 Done.
+ // Set this to true if we make any changes to the client data.
+ bool has_local_changes_;
dcheng 2013/01/18 21:56:13 DISALLOW_COPY_AND_ASSIGN.
Pete Williamson 2013/01/23 01:45:55 Done.
+};
+
+
+} // namespace sync_pb
+
+#endif // CHROME_BROWSER_NOTIFIER_SYNCED_NOTIFICATION_H_

Powered by Google App Engine
This is Rietveld 408576698