diff options
author | mark@chromium.org <mark@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-06-24 20:39:16 +0000 |
---|---|---|
committer | mark@chromium.org <mark@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-06-24 20:39:16 +0000 |
commit | 402440030869a1f1d74119d8f7c9e2f65e0179a7 (patch) | |
tree | 7680a959cc89d75ceae641debf16f9436e773493 /chrome/browser/cocoa | |
parent | d0d8460e70cc8a125e61e1c2c6a21e37daca25ed (diff) | |
download | chromium_src-402440030869a1f1d74119d8f7c9e2f65e0179a7.zip chromium_src-402440030869a1f1d74119d8f7c9e2f65e0179a7.tar.gz chromium_src-402440030869a1f1d74119d8f7c9e2f65e0179a7.tar.bz2 |
Rewrite some tab controller stuff to maybe (but probably not) improve perf.
BUG=15232
TEST=watch perf graphs
Review URL: http://codereview.chromium.org/147103
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@19167 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/cocoa')
-rw-r--r-- | chrome/browser/cocoa/tab_controller.h | 22 | ||||
-rw-r--r-- | chrome/browser/cocoa/tab_controller.mm | 3 | ||||
-rw-r--r-- | chrome/browser/cocoa/tab_strip_controller.mm | 53 |
3 files changed, 39 insertions, 39 deletions
diff --git a/chrome/browser/cocoa/tab_controller.h b/chrome/browser/cocoa/tab_controller.h index 7795ec3..fed9189 100644 --- a/chrome/browser/cocoa/tab_controller.h +++ b/chrome/browser/cocoa/tab_controller.h @@ -7,6 +7,17 @@ #import <Cocoa/Cocoa.h> +// The loading/waiting state of the tab. +// TODO(pinkerton): this really doesn't belong here, but something needs to +// know the state and another parallel array in TabStripController doesn't seem +// like the right place either. In a perfect world, this class shouldn't know +// anything about states that are specific to a browser. +enum TabLoadingState { + DONE, + LOADING, + WAITING, +}; + @class TabView; @protocol TabControllerTarget; @@ -26,19 +37,12 @@ IBOutlet NSButton *backgroundButton_; IBOutlet NSView* iconView_; BOOL selected_; - BOOL loading_; - BOOL waiting_; + TabLoadingState loadingState_; id<TabControllerTarget> target_; // weak, where actions are sent SEL action_; // selector sent when tab is selected by clicking } -// The loading/waiting state of the tab. -// TODO(pinkerton): these really don't belong here, but something needs to -// know the state and another parallel array in TabStripController doesn't seem -// like the right place either. In a perfect world, this class shouldn't know -// anything about states that are specific to a browser. -@property(assign, nonatomic) BOOL loading; -@property(assign, nonatomic) BOOL waiting; +@property(assign, nonatomic) TabLoadingState loadingState; @property(assign, nonatomic) BOOL selected; @property(assign, nonatomic) id target; diff --git a/chrome/browser/cocoa/tab_controller.mm b/chrome/browser/cocoa/tab_controller.mm index 94d1ca2..f675b9c 100644 --- a/chrome/browser/cocoa/tab_controller.mm +++ b/chrome/browser/cocoa/tab_controller.mm @@ -8,8 +8,7 @@ @implementation TabController -@synthesize loading = loading_; -@synthesize waiting = waiting_; +@synthesize loadingState = loadingState_; @synthesize target = target_; @synthesize action = action_; diff --git a/chrome/browser/cocoa/tab_strip_controller.mm b/chrome/browser/cocoa/tab_strip_controller.mm index 45741cc..6f0cd24 100644 --- a/chrome/browser/cocoa/tab_strip_controller.mm +++ b/chrome/browser/cocoa/tab_strip_controller.mm @@ -444,41 +444,38 @@ NSString* const kTabStripNumberOfTabsChanged = @"kTabStripNumberOfTabsChanged"; // load, so we need to make sure we're not creating the throbber view over and // over. if (contents) { - static NSImage* throbberImage = [[NSImage imageNamed:@"throbber"] retain]; static NSImage* throbberWaitingImage = [[NSImage imageNamed:@"throbber_waiting"] retain]; + static NSImage* throbberLoadingImage = + [[NSImage imageNamed:@"throbber"] retain]; TabController* tabController = [tabArray_ objectAtIndex:index]; - NSImage* image = nil; + + TabLoadingState oldState = [tabController loadingState]; + + TabLoadingState newState = DONE; + NSImage* throbberImage = nil; if (contents->waiting_for_response()) { - throbberWaitingImage = throbberWaitingImage; -#if 0 - if (![tabController waiting]) { - image = throbberWaitingImage; - [tabController setWaiting:YES]; - } -#endif + newState = WAITING; + throbberImage = throbberWaitingImage; } else if (contents->is_loading()) { - if (![tabController loading]) { - image = throbberImage; - [tabController setLoading:YES]; - } + newState = LOADING; + throbberImage = throbberLoadingImage; } - if (image) { - NSRect frame = NSMakeRect(0, 0, 16, 16); -#if 0 - ThrobberView* throbber = - [[[ThrobberView alloc] initWithFrame:frame image:image] autorelease]; - [tabController setIconView:throbber]; -#endif - } - else if (!contents->is_loading()) { - // Set everything back to normal, we're done loading. -#if 0 - [tabController setIconView:[self favIconImageViewForContents:contents]]; -#endif - [tabController setWaiting:NO]; - [tabController setLoading:NO]; + + if (oldState != newState) { + NSView* iconView = nil; + if (newState == DONE) { + iconView = [self favIconImageViewForContents:contents]; + } else { + NSRect frame = NSMakeRect(0, 0, 16, 16); + iconView = [[[ThrobberView alloc] initWithFrame:frame + image:throbberImage] + autorelease]; + } + + [tabController setLoadingState:newState]; + [tabController setIconView:iconView]; } } |