OLD | NEW |
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 #include "chrome/browser/ui/search/search_model.h" | 5 #include "chrome/browser/ui/search/search_model.h" |
6 | 6 |
7 #include "chrome/browser/ui/search/search.h" | 7 #include "chrome/browser/ui/search/search.h" |
8 #include "chrome/browser/ui/search/search_model_observer.h" | 8 #include "chrome/browser/ui/search/search_model_observer.h" |
9 #include "chrome/browser/ui/tab_contents/tab_contents.h" | 9 #include "chrome/browser/ui/tab_contents/tab_contents.h" |
10 | 10 |
11 namespace chrome { | 11 namespace chrome { |
12 namespace search { | 12 namespace search { |
13 | 13 |
14 SearchModel::SearchModel(TabContents* contents) | 14 SearchModel::SearchModel(TabContents* contents) |
15 : contents_(contents) { | 15 : contents_(contents) { |
16 } | 16 } |
17 | 17 |
18 SearchModel::~SearchModel() { | 18 SearchModel::~SearchModel() { |
19 } | 19 } |
20 | 20 |
21 void SearchModel::SetMode(const Mode& mode) { | 21 void SearchModel::SetMode(const Mode& new_mode) { |
22 if (!contents_) | 22 if (!contents_) |
23 return; | 23 return; |
24 | 24 |
25 DCHECK(IsInstantExtendedAPIEnabled(contents_->profile())) | 25 DCHECK(IsInstantExtendedAPIEnabled(contents_->profile())) |
26 << "Please do not try to set the SearchModel mode without first " | 26 << "Please do not try to set the SearchModel mode without first " |
27 << "checking if Search is enabled."; | 27 << "checking if Search is enabled."; |
28 | 28 |
29 if (mode_ == mode) | 29 if (mode_ == new_mode) |
30 return; | 30 return; |
31 | 31 |
32 mode_ = mode; | 32 const Mode old_mode = mode_; |
| 33 mode_ = new_mode; |
33 | 34 |
34 FOR_EACH_OBSERVER(SearchModelObserver, observers_, ModeChanged(mode_)); | 35 FOR_EACH_OBSERVER(SearchModelObserver, observers_, |
| 36 ModeChanged(old_mode, mode_)); |
35 | 37 |
36 // Animation is transient, it is cleared after observers are notified. | 38 // Animation is transient, it is cleared after observers are notified. |
37 mode_.animate = false; | 39 mode_.animate = false; |
38 } | 40 } |
39 | 41 |
40 void SearchModel::MaybeChangeMode(Mode::Type from_mode, Mode::Type to_mode) { | 42 void SearchModel::MaybeChangeMode(Mode::Type from_mode, Mode::Type to_mode) { |
41 if (mode_.mode == from_mode) { | 43 if (mode_.mode == from_mode) { |
42 Mode mode(to_mode, true); | 44 Mode mode(to_mode, true); |
43 SetMode(mode); | 45 SetMode(mode); |
44 } | 46 } |
45 } | 47 } |
46 | 48 |
47 void SearchModel::AddObserver(SearchModelObserver* observer) { | 49 void SearchModel::AddObserver(SearchModelObserver* observer) { |
48 observers_.AddObserver(observer); | 50 observers_.AddObserver(observer); |
49 } | 51 } |
50 | 52 |
51 void SearchModel::RemoveObserver(SearchModelObserver* observer) { | 53 void SearchModel::RemoveObserver(SearchModelObserver* observer) { |
52 observers_.RemoveObserver(observer); | 54 observers_.RemoveObserver(observer); |
53 } | 55 } |
54 | 56 |
55 } // namespace search | 57 } // namespace search |
56 } // namespace chrome | 58 } // namespace chrome |
OLD | NEW |