OLD | NEW |
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 #include "components/enhanced_bookmarks/enhanced_bookmark_model.h" | 5 #include "components/enhanced_bookmarks/enhanced_bookmark_model.h" |
6 | 6 |
7 #include <iomanip> | 7 #include <iomanip> |
8 #include <sstream> | 8 #include <sstream> |
9 | 9 |
10 #include "base/base64.h" | 10 #include "base/base64.h" |
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
84 weak_ptr_factory_(this), | 84 weak_ptr_factory_(this), |
85 version_(version) { | 85 version_(version) { |
86 bookmark_model_->AddObserver(this); | 86 bookmark_model_->AddObserver(this); |
87 if (bookmark_model_->loaded()) { | 87 if (bookmark_model_->loaded()) { |
88 InitializeIdMap(); | 88 InitializeIdMap(); |
89 loaded_ = true; | 89 loaded_ = true; |
90 } | 90 } |
91 } | 91 } |
92 | 92 |
93 EnhancedBookmarkModel::~EnhancedBookmarkModel() { | 93 EnhancedBookmarkModel::~EnhancedBookmarkModel() { |
| 94 Shutdown(); |
94 } | 95 } |
95 | 96 |
96 void EnhancedBookmarkModel::Shutdown() { | 97 void EnhancedBookmarkModel::Shutdown() { |
97 FOR_EACH_OBSERVER(EnhancedBookmarkModelObserver, | 98 if (bookmark_model_) { |
98 observers_, | 99 FOR_EACH_OBSERVER(EnhancedBookmarkModelObserver, |
99 EnhancedBookmarkModelShuttingDown()); | 100 observers_, |
100 weak_ptr_factory_.InvalidateWeakPtrs(); | 101 EnhancedBookmarkModelShuttingDown()); |
101 bookmark_model_->RemoveObserver(this); | 102 weak_ptr_factory_.InvalidateWeakPtrs(); |
102 bookmark_model_ = NULL; | 103 bookmark_model_->RemoveObserver(this); |
| 104 bookmark_model_ = NULL; |
| 105 } |
103 } | 106 } |
104 | 107 |
105 void EnhancedBookmarkModel::AddObserver( | 108 void EnhancedBookmarkModel::AddObserver( |
106 EnhancedBookmarkModelObserver* observer) { | 109 EnhancedBookmarkModelObserver* observer) { |
107 observers_.AddObserver(observer); | 110 observers_.AddObserver(observer); |
108 } | 111 } |
109 | 112 |
110 void EnhancedBookmarkModel::RemoveObserver( | 113 void EnhancedBookmarkModel::RemoveObserver( |
111 EnhancedBookmarkModelObserver* observer) { | 114 EnhancedBookmarkModelObserver* observer) { |
112 observers_.RemoveObserver(observer); | 115 observers_.RemoveObserver(observer); |
(...skipping 373 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
486 if (!result) | 489 if (!result) |
487 return false; | 490 return false; |
488 | 491 |
489 std::string encoded; | 492 std::string encoded; |
490 base::Base64Encode(output, &encoded); | 493 base::Base64Encode(output, &encoded); |
491 bookmark_model_->SetNodeMetaInfo(node, kImageDataKey, encoded); | 494 bookmark_model_->SetNodeMetaInfo(node, kImageDataKey, encoded); |
492 return true; | 495 return true; |
493 } | 496 } |
494 | 497 |
495 } // namespace enhanced_bookmarks | 498 } // namespace enhanced_bookmarks |
OLD | NEW |