| Index: chrome/browser/cocoa/base_bubble_controller.h | 
| diff --git a/chrome/browser/cocoa/base_bubble_controller.h b/chrome/browser/cocoa/base_bubble_controller.h | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..795f1a172c4c70f5662ed024387133c442fdcf33 | 
| --- /dev/null | 
| +++ b/chrome/browser/cocoa/base_bubble_controller.h | 
| @@ -0,0 +1,53 @@ | 
| +// Copyright (c) 2010 The Chromium Authors. All rights reserved. | 
| +// Use of this source code is governed by a BSD-style license that can be | 
| +// found in the LICENSE file. | 
| + | 
| +#import <Cocoa/Cocoa.h> | 
| + | 
| +#import "base/cocoa_protocols_mac.h" | 
| +#include "base/scoped_nsobject.h" | 
| +#include "base/scoped_ptr.h" | 
| + | 
| +@class InfoBubbleView; | 
| + | 
| +// Base class for bubble controllers. Manages a xib that contains an | 
| +// InfoBubbleWindow which contains an InfoBubbleView. Contains code to close | 
| +// the bubble window on clicks outside of the window, and the like. | 
| +// To use this class: | 
| +// 1. Create a new xib that contains a window. Change the window's class to | 
| +//    InfoBubbleWindow. Give it a child view that autosizes to the window's full | 
| +//    size, give it class InfoBubbleView. Make the controller the window's | 
| +//    delegate. | 
| +// 2. Create a subclass of BaseBubbleController. | 
| +// 3. Change the xib's File Owner to your subclass. | 
| +// 4. Hook up the File Owner's |bubble_| to the InfoBubbleView in the xib. | 
| +@interface BaseBubbleController : NSWindowController<NSWindowDelegate> { | 
| + @private | 
| +  NSWindow* parentWindow_;  // weak | 
| +  NSPoint anchor_; | 
| +  IBOutlet InfoBubbleView* bubble_;  // to set arrow position | 
| +} | 
| + | 
| +// Creates a bubble. |nibPath| is just the basename, e.g. @"FirstRunBubble". | 
| +// |anchoredAt| is in screen space. You need to call -showWindow: to make the | 
| +// bubble visible. It will autorelease itself when the user dismisses the | 
| +// bubble. | 
| +// This is the designated initializer. | 
| +- (id)initWithWindowNibPath:(NSString*)nibPath | 
| +               parentWindow:(NSWindow*)parentWindow | 
| +                 anchoredAt:(NSPoint)anchoredAt; | 
| + | 
| + | 
| +// Creates a bubble. |nibPath| is just the basename, e.g. @"FirstRunBubble". | 
| +// |view| must be in a window. The bubble will point at |offset| relative to | 
| +// |view|'s lower left corner. You need to call -showWindow: to make the | 
| +// bubble visible. It will autorelease itself when the user dismisses the | 
| +// bubble. | 
| +- (id)initWithWindowNibPath:(NSString*)nibPath | 
| +             relativeToView:(NSView*)view | 
| +                     offset:(NSPoint)offset; | 
| + | 
| + | 
| +@property (nonatomic, readonly) InfoBubbleView* bubble; | 
| + | 
| +@end | 
|  |