[Mac] Clean up the menu controller.

This commit is contained in:
Cheng Zhao 2013-08-14 23:03:02 +08:00
parent f908619630
commit 63b85bccab
3 changed files with 5 additions and 36 deletions

View file

@ -24,8 +24,7 @@ MenuMac::~MenuMac() {
void MenuMac::Popup(NativeWindow* native_window) { void MenuMac::Popup(NativeWindow* native_window) {
scoped_nsobject<AtomMenuController> menu_controller( scoped_nsobject<AtomMenuController> menu_controller(
[[AtomMenuController alloc] initWithModel:model_.get() [[AtomMenuController alloc] initWithModel:model_.get()]);
useWithPopUpButtonCell:NO]);
NSWindow* window = native_window->GetNativeWindow(); NSWindow* window = native_window->GetNativeWindow();
content::WebContents* web_contents = native_window->GetWebContents(); content::WebContents* web_contents = native_window->GetWebContents();
@ -82,8 +81,7 @@ v8::Handle<v8::Value> Menu::SetApplicationMenu(const v8::Arguments &args) {
return node::ThrowError("Menu is destroyed"); return node::ThrowError("Menu is destroyed");
scoped_nsobject<AtomMenuController> menu_controller( scoped_nsobject<AtomMenuController> menu_controller(
[[AtomMenuController alloc] initWithModel:menu->model_.get() [[AtomMenuController alloc] initWithModel:menu->model_.get()]);
useWithPopUpButtonCell:NO]);
[NSApp setMainMenu:[menu_controller menu]]; [NSApp setMainMenu:[menu_controller menu]];
// Ensure the menu_controller_ is destroyed after main menu is set. // Ensure the menu_controller_ is destroyed after main menu is set.

View file

@ -25,14 +25,10 @@ class MenuModel;
@protected @protected
ui::MenuModel* model_; // weak ui::MenuModel* model_; // weak
scoped_nsobject<NSMenu> menu_; scoped_nsobject<NSMenu> menu_;
BOOL useWithPopUpButtonCell_; // If YES, 0th item is blank
BOOL isMenuOpen_; BOOL isMenuOpen_;
} }
@property(nonatomic, assign) ui::MenuModel* model; @property(nonatomic, assign) ui::MenuModel* model;
// Note that changing this will have no effect if you use
// |-initWithModel:useWithPopUpButtonCell:| or after the first call to |-menu|.
@property(nonatomic) BOOL useWithPopUpButtonCell;
// NIB-based initializer. This does not create a menu. Clients can set the // NIB-based initializer. This does not create a menu. Clients can set the
// properties of the object and the menu will be created upon the first call to // properties of the object and the menu will be created upon the first call to
@ -40,12 +36,8 @@ class MenuModel;
- (id)init; - (id)init;
// Builds a NSMenu from the pre-built model (must not be nil). Changes made // Builds a NSMenu from the pre-built model (must not be nil). Changes made
// to the contents of the model after calling this will not be noticed. If // to the contents of the model after calling this will not be noticed.
// the menu will be displayed by a NSPopUpButtonCell, it needs to be of a - (id)initWithModel:(ui::MenuModel*)model;
// slightly different form (0th item is empty). Note this attribute of the menu
// cannot be changed after it has been created.
- (id)initWithModel:(ui::MenuModel*)model
useWithPopUpButtonCell:(BOOL)useWithCell;
// Programmatically close the constructed menu. // Programmatically close the constructed menu.
- (void)cancel; - (void)cancel;
@ -75,10 +67,6 @@ class MenuModel;
atIndex:(NSInteger)index atIndex:(NSInteger)index
fromModel:(ui::MenuModel*)model; fromModel:(ui::MenuModel*)model;
- (NSMenu*)menuFromModel:(ui::MenuModel*)model; - (NSMenu*)menuFromModel:(ui::MenuModel*)model;
// Returns the maximum width for the menu item. Returns -1 to indicate
// that there's no maximum width.
- (int)maxWidthForMenuModel:(ui::MenuModel*)model
modelIndex:(int)modelIndex;
@end @end
#endif // ATOM_BROWSER_UI_ATOM_MENU_CONTROLLER_MAC_H_ #endif // ATOM_BROWSER_UI_ATOM_MENU_CONTROLLER_MAC_H_

View file

@ -68,18 +68,15 @@ int EventFlagsFromNSEvent(NSEvent* event) {
@implementation AtomMenuController @implementation AtomMenuController
@synthesize model = model_; @synthesize model = model_;
@synthesize useWithPopUpButtonCell = useWithPopUpButtonCell_;
- (id)init { - (id)init {
self = [super init]; self = [super init];
return self; return self;
} }
- (id)initWithModel:(ui::MenuModel*)model - (id)initWithModel:(ui::MenuModel*)model {
useWithPopUpButtonCell:(BOOL)useWithCell {
if ((self = [super init])) { if ((self = [super init])) {
model_ = model; model_ = model;
useWithPopUpButtonCell_ = useWithCell;
[self menu]; [self menu];
} }
return self; return self;
@ -120,11 +117,6 @@ int EventFlagsFromNSEvent(NSEvent* event) {
return menu; return menu;
} }
- (int)maxWidthForMenuModel:(ui::MenuModel*)model
modelIndex:(int)modelIndex {
return -1;
}
// Adds a separator item at the given index. As the separator doesn't need // Adds a separator item at the given index. As the separator doesn't need
// anything from the model, this method doesn't need the model index as the // anything from the model, this method doesn't need the model index as the
// other method below does. // other method below does.
@ -241,15 +233,6 @@ int EventFlagsFromNSEvent(NSEvent* event) {
if (!menu_ && model_) { if (!menu_ && model_) {
menu_.reset([[self menuFromModel:model_] retain]); menu_.reset([[self menuFromModel:model_] retain]);
[menu_ setDelegate:self]; [menu_ setDelegate:self];
// If this is to be used with a NSPopUpButtonCell, add an item at the 0th
// position that's empty. Doing it after the menu has been constructed won't
// complicate creation logic, and since the tags are model indexes, they
// are unaffected by the extra item.
if (useWithPopUpButtonCell_) {
scoped_nsobject<NSMenuItem> blankItem(
[[NSMenuItem alloc] initWithTitle:@"" action:nil keyEquivalent:@""]);
[menu_ insertItem:blankItem atIndex:0];
}
} }
return menu_.get(); return menu_.get();
} }