diff options
author | sky@google.com <sky@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-08-29 18:45:30 +0000 |
---|---|---|
committer | sky@google.com <sky@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-08-29 18:45:30 +0000 |
commit | a1ee67ffb7efbae40801fcaabfccb01f944f57c5 (patch) | |
tree | 3e1cd36eba920b181e8ec0771c7235dd79b21abc /chrome/browser/tabs | |
parent | 809ad6ea402a6a15af7da6d527360da10b9e66a8 (diff) | |
download | chromium_src-a1ee67ffb7efbae40801fcaabfccb01f944f57c5.zip chromium_src-a1ee67ffb7efbae40801fcaabfccb01f944f57c5.tar.gz chromium_src-a1ee67ffb7efbae40801fcaabfccb01f944f57c5.tar.bz2 |
Fixes bug where it was possible for tab to get the wrong title. Came
across this in investigating another problem.
BUG=1307747
TEST=Create > 3 tabs. In the last one open the html file attached to
1305707. Click on the button. Rapidly drag the first tab in and
out of the tab strip and make sure none of the remaining tabs get the wrong title.
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@1538 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/tabs')
-rw-r--r-- | chrome/browser/tabs/tab_strip.cc | 44 | ||||
-rw-r--r-- | chrome/browser/tabs/tab_strip.h | 12 |
2 files changed, 47 insertions, 9 deletions
diff --git a/chrome/browser/tabs/tab_strip.cc b/chrome/browser/tabs/tab_strip.cc index b012443..d38be5a 100644 --- a/chrome/browser/tabs/tab_strip.cc +++ b/chrome/browser/tabs/tab_strip.cc @@ -65,17 +65,28 @@ class TabStrip::TabAnimation : public AnimationDelegate { public: friend class TabStrip; - TabAnimation(TabStrip* tabstrip) + // Possible types of animation. + enum Type { + INSERT, + REMOVE, + MOVE, + RESIZE + }; + + TabAnimation(TabStrip* tabstrip, Type type) : tabstrip_(tabstrip), animation_(this), start_selected_width_(0), start_unselected_width_(0), end_selected_width_(0), end_unselected_width_(0), - layout_on_completion_(false) { + layout_on_completion_(false), + type_(type) { } virtual ~TabAnimation() {} + Type type() const { return type_; } + void Start() { animation_.SetSlideDuration(GetDuration()); animation_.SetTweenType(SlideAnimation::EASE_OUT); @@ -171,6 +182,8 @@ class TabStrip::TabAnimation : public AnimationDelegate { // inconsistent state. bool layout_on_completion_; + const Type type_; + DISALLOW_EVIL_CONSTRUCTORS(TabAnimation); }; @@ -180,7 +193,7 @@ class TabStrip::TabAnimation : public AnimationDelegate { class InsertTabAnimation : public TabStrip::TabAnimation { public: explicit InsertTabAnimation(TabStrip* tabstrip, int index) - : TabAnimation(tabstrip), + : TabAnimation(tabstrip, INSERT), index_(index) { int tab_count = tabstrip->GetTabCount(); GenerateStartAndEndWidths(tab_count - 1, tab_count); @@ -221,12 +234,15 @@ class InsertTabAnimation : public TabStrip::TabAnimation { class RemoveTabAnimation : public TabStrip::TabAnimation { public: RemoveTabAnimation(TabStrip* tabstrip, int index, TabContents* contents) - : TabAnimation(tabstrip), + : TabAnimation(tabstrip, REMOVE), index_(index) { int tab_count = tabstrip->GetTabCount(); GenerateStartAndEndWidths(tab_count, tab_count - 1); } + // Returns the index of the tab being removed. + int index() const { return index_; } + virtual ~RemoveTabAnimation() { } @@ -322,7 +338,7 @@ class RemoveTabAnimation : public TabStrip::TabAnimation { class MoveTabAnimation : public TabStrip::TabAnimation { public: MoveTabAnimation(TabStrip* tabstrip, int tab_a_index, int tab_b_index) - : TabAnimation(tabstrip), + : TabAnimation(tabstrip, MOVE), start_tab_a_bounds_(tabstrip_->GetIdealBounds(tab_b_index)), start_tab_b_bounds_(tabstrip_->GetIdealBounds(tab_a_index)) { tab_a_ = tabstrip_->GetTabAt(tab_a_index); @@ -376,8 +392,8 @@ class MoveTabAnimation : public TabStrip::TabAnimation { // to another. class ResizeLayoutAnimation : public TabStrip::TabAnimation { public: - ResizeLayoutAnimation(TabStrip* tabstrip) - : TabAnimation(tabstrip) { + explicit ResizeLayoutAnimation(TabStrip* tabstrip) + : TabAnimation(tabstrip, RESIZE) { int tab_count = tabstrip->GetTabCount(); GenerateStartAndEndWidths(tab_count, tab_count); InitStartState(); @@ -825,7 +841,9 @@ void TabStrip::TabMoved(TabContents* contents, int from_index, int to_index) { } void TabStrip::TabChangedAt(TabContents* contents, int index) { - Tab* tab = GetTabAt(index); + // Index is in terms of the model. Need to make sure we adjust that index in + // case we have an animation going. + Tab* tab = GetTabAtAdjustForAnimation(index); tab->UpdateData(contents); tab->UpdateFromModel(); } @@ -1085,6 +1103,16 @@ Tab* TabStrip::GetTabAt(int index) const { return tab_data_.at(index).tab; } +Tab* TabStrip::GetTabAtAdjustForAnimation(int index) const { + if (active_animation_.get() && + active_animation_->type() == TabAnimation::REMOVE && + index >= + static_cast<RemoveTabAnimation*>(active_animation_.get())->index()) { + index++; + } + return GetTabAt(index); +} + int TabStrip::GetTabCount() const { return static_cast<int>(tab_data_.size()); } diff --git a/chrome/browser/tabs/tab_strip.h b/chrome/browser/tabs/tab_strip.h index 930b60b..9d2ed08 100644 --- a/chrome/browser/tabs/tab_strip.h +++ b/chrome/browser/tabs/tab_strip.h @@ -172,9 +172,19 @@ class TabStrip : public ChromeViews::View, TabStrip(); void Init(); - // Retrieves the Tab at the specified index. + // Retrieves the Tab at the specified index. Take care in using this, you may + // need to use GetTabAtAdjustForAnimation. Tab* GetTabAt(int index) const; + // Returns the tab at the specified index. If a remove animation is on going + // and the index is >= the index of the tab being removed, the index is + // incremented. While a remove operation is on going the indices of the model + // do not line up with the indices of the view. This method adjusts the index + // accordingly. + // + // Use this instead of GetTabAt if the index comes from the model. + Tab* GetTabAtAdjustForAnimation(int index) const; + // Gets the number of Tabs in the collection. int GetTabCount() const; |