| Index: chrome/browser/ui/cocoa/tab_contents/tab_contents_controller.mm | 
| diff --git a/chrome/browser/ui/cocoa/tab_contents/tab_contents_controller.mm b/chrome/browser/ui/cocoa/tab_contents/tab_contents_controller.mm | 
| index 2e48592786533cdf038494992a8c5fbf5e1682c3..c3a0e1df6806594868e4473dd3481d164c27657d 100644 | 
| --- a/chrome/browser/ui/cocoa/tab_contents/tab_contents_controller.mm | 
| +++ b/chrome/browser/ui/cocoa/tab_contents/tab_contents_controller.mm | 
| @@ -11,16 +11,45 @@ | 
| #include "content/public/browser/render_view_host.h" | 
| #include "content/public/browser/render_widget_host_view.h" | 
| #include "content/public/browser/web_contents.h" | 
| +#include "content/public/browser/web_contents_observer.h" | 
| #include "content/public/browser/web_contents_view.h" | 
|  | 
| using content::WebContents; | 
| +using content::WebContentsObserver; | 
| + | 
| +class FullscreenObserver : public WebContentsObserver { | 
| + public: | 
| +  explicit FullscreenObserver(TabContentsController* controller) | 
| +      : controller_(controller) {} | 
| + | 
| +  void Observe(content::WebContents* new_web_contents) { | 
| +    WebContentsObserver::Observe(new_web_contents); | 
| +  } | 
| + | 
| +  virtual void DidShowFullscreenWidget(int routing_id) OVERRIDE { | 
| +    [controller_ toggleFullscreenWidget:YES]; | 
| +  } | 
| + | 
| +  virtual void DidDestroyFullscreenWidget(int routing_id) OVERRIDE { | 
| +    [controller_ toggleFullscreenWidget:NO]; | 
| +  } | 
| + | 
| + private: | 
| +  TabContentsController* const controller_; | 
| +}; | 
|  | 
| @implementation TabContentsController | 
| @synthesize webContents = contents_; | 
|  | 
| -- (id)initWithContents:(WebContents*)contents { | 
| +- (id)initWithContents:(WebContents*)contents | 
| +andAutoEmbedFullscreen:(BOOL)enableEmbeddedFullscreen { | 
| if ((self = [super initWithNibName:nil bundle:nil])) { | 
| contents_ = contents; | 
| +    if (enableEmbeddedFullscreen) { | 
| +      fullscreenObserver_.reset(new FullscreenObserver(self)); | 
| +      fullscreenObserver_->Observe(contents_); | 
| +    } | 
| +    isEmbeddingFullscreenWidget_ = NO; | 
| } | 
| return self; | 
| } | 
| @@ -40,10 +69,8 @@ using content::WebContents; | 
| - (void)ensureContentsSizeDoesNotChange { | 
| NSView* contentsContainer = [self view]; | 
| NSArray* subviews = [contentsContainer subviews]; | 
| -  if ([subviews count] > 0) { | 
| -    [contents_->GetView()->GetNativeView() | 
| -        setAutoresizingMask:NSViewNotSizable]; | 
| -  } | 
| +  if ([subviews count] > 0) | 
| +    [[subviews objectAtIndex:0] setAutoresizingMask:NSViewNotSizable]; | 
| } | 
|  | 
| // Call when the tab view is properly sized and the render widget host view | 
| @@ -53,7 +80,16 @@ using content::WebContents; | 
| return; | 
| NSView* contentsContainer = [self view]; | 
| NSArray* subviews = [contentsContainer subviews]; | 
| -  NSView* contentsNativeView = contents_->GetView()->GetNativeView(); | 
| +  NSView* contentsNativeView; | 
| +  content::RenderWidgetHostView* const fullscreen_view = | 
| +      isEmbeddingFullscreenWidget_ ? | 
| +      contents_->GetFullscreenRenderWidgetHostView() : NULL; | 
| +  if (fullscreen_view) { | 
| +    contentsNativeView = fullscreen_view->GetNativeView(); | 
| +  } else { | 
| +    isEmbeddingFullscreenWidget_ = NO; | 
| +    contentsNativeView = contents_->GetView()->GetNativeView(); | 
| +  } | 
| [contentsNativeView setFrame:[contentsContainer frame]]; | 
| if ([subviews count] == 0) { | 
| [contentsContainer addSubview:contentsNativeView]; | 
| @@ -66,11 +102,19 @@ using content::WebContents; | 
| // The rendering path with overlapping views disabled causes bugs when | 
| // transitioning between composited and non-composited mode. | 
| // http://crbug.com/279472 | 
| -  contents_->GetView()->SetAllowOverlappingViews(true); | 
| +  if (!fullscreen_view) | 
| +    contents_->GetView()->SetAllowOverlappingViews(true); | 
| } | 
|  | 
| - (void)changeWebContents:(WebContents*)newContents { | 
| contents_ = newContents; | 
| +  if (fullscreenObserver_) { | 
| +    fullscreenObserver_->Observe(contents_); | 
| +    isEmbeddingFullscreenWidget_ = | 
| +        contents_ && contents_->GetFullscreenRenderWidgetHostView(); | 
| +  } else { | 
| +    isEmbeddingFullscreenWidget_ = NO; | 
| +  } | 
| } | 
|  | 
| // Returns YES if the tab represented by this controller is the front-most. | 
| @@ -114,9 +158,15 @@ using content::WebContents; | 
| // the view may have, so avoid changing the view hierarchy unless | 
| // the view is different. | 
| if ([self webContents] != updatedContents) { | 
| -    contents_ = updatedContents; | 
| +    [self changeWebContents:updatedContents]; | 
| [self ensureContentsVisible]; | 
| } | 
| } | 
|  | 
| +- (void)toggleFullscreenWidget:(BOOL)enterFullscreen { | 
| +  isEmbeddingFullscreenWidget_ = enterFullscreen && | 
| +      contents_ && contents_->GetFullscreenRenderWidgetHostView(); | 
| +  [self ensureContentsVisible]; | 
| +} | 
| + | 
| @end | 
|  |