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

Unified Diff: chrome/browser/ui/cocoa/bookmarks/bookmark_model_observer_for_cocoa.mm

Issue 6542027: Out of line cleanups for Mac. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Killer rebase. :( Created 9 years, 10 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/ui/cocoa/bookmarks/bookmark_model_observer_for_cocoa.mm
diff --git a/chrome/browser/ui/cocoa/bookmarks/bookmark_model_observer_for_cocoa.mm b/chrome/browser/ui/cocoa/bookmarks/bookmark_model_observer_for_cocoa.mm
new file mode 100644
index 0000000000000000000000000000000000000000..334549754c8e8b73ef6ac6f457f735084ff880fa
--- /dev/null
+++ b/chrome/browser/ui/cocoa/bookmarks/bookmark_model_observer_for_cocoa.mm
@@ -0,0 +1,64 @@
+// Copyright (c) 2011 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.
+
+#include "chrome/browser/ui/cocoa/bookmarks/bookmark_model_observer_for_cocoa.h"
+
+BookmarkModelObserverForCocoa::BookmarkModelObserverForCocoa(
+ const BookmarkNode* node,
+ BookmarkModel* model,
+ NSObject* object,
+ SEL selector) {
+ DCHECK(model);
+ node_ = node;
+ model_ = model;
+ object_ = object;
+ selector_ = selector;
+ model_->AddObserver(this);
+}
+
+BookmarkModelObserverForCocoa::~BookmarkModelObserverForCocoa() {
+ model_->RemoveObserver(this);
+}
+
+void BookmarkModelObserverForCocoa::BookmarkModelBeingDeleted(
+ BookmarkModel* model) {
+ Notify();
+}
+
+void BookmarkModelObserverForCocoa::BookmarkNodeMoved(
+ BookmarkModel* model,
+ const BookmarkNode* old_parent,
+ int old_index,
+ const BookmarkNode* new_parent,
+ int new_index) {
+ // Editors often have a tree of parents, so movement of folders
+ // must cause a cancel.
+ Notify();
+}
+
+void BookmarkModelObserverForCocoa::BookmarkNodeRemoved(
+ BookmarkModel* model,
+ const BookmarkNode* parent,
+ int old_index,
+ const BookmarkNode* node) {
+ // See comment in BookmarkNodeMoved.
+ Notify();
+}
+
+void BookmarkModelObserverForCocoa::BookmarkNodeChanged(
+ BookmarkModel* model,
+ const BookmarkNode* node) {
+ if ((node_ == node) || (!node_))
+ Notify();
+}
+
+void BookmarkModelObserverForCocoa::BookmarkImportBeginning(
+ BookmarkModel* model) {
+ // Be conservative.
+ Notify();
+}
+
+void BookmarkModelObserverForCocoa::Notify() {
+ [object_ performSelector:selector_ withObject:nil];
+}

Powered by Google App Engine
This is Rietveld 408576698