summaryrefslogtreecommitdiffstats
path: root/chrome/browser/cocoa/history_menu_cocoa_controller.mm
diff options
context:
space:
mode:
authorben@chromium.org <ben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-08-19 03:52:11 +0000
committerben@chromium.org <ben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-08-19 03:52:11 +0000
commit1a6b30a619cba771cb9c4ed4da9c3778634567ad (patch)
tree4ced69ac8eb511a6f9bc7949348551ee62b57989 /chrome/browser/cocoa/history_menu_cocoa_controller.mm
parenta8815b3277284778247545728bc41a077ff55b43 (diff)
downloadchromium_src-1a6b30a619cba771cb9c4ed4da9c3778634567ad.zip
chromium_src-1a6b30a619cba771cb9c4ed4da9c3778634567ad.tar.gz
chromium_src-1a6b30a619cba771cb9c4ed4da9c3778634567ad.tar.bz2
This changelist represents the necessary merger of two others:
http://codereview.chromium.org/172082 Create new event_utils.h file for Cocoa-specific event to WindowOpenDisposition cracking. Hook this up to BookmarkBarController so that clicks to bookmark items use the oracle function to determine where the bookmark should be opened. BUG=17301 TEST=Cmd+Click etc on bookmark items should work. See bug and unit test attached. http://codereview.chromium.org/174021 Convert users of the "get last active browser, get selected tab contents, open url" pattern to just call OpenURL on Browser directly. Makes GetOrCreateTabbedBrowser public on Browser, and makes it static so it can be called with a provided profile. BUG=none TEST=Try opening links from the bookmark/history menus on mac, with and without an existing window open, with an active incognito window, etc. The links should all open in the last active non-incognito window, or create a new non-incognito window if none is open. Review URL: http://codereview.chromium.org/173044 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@23693 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/cocoa/history_menu_cocoa_controller.mm')
-rw-r--r--chrome/browser/cocoa/history_menu_cocoa_controller.mm22
1 files changed, 6 insertions, 16 deletions
diff --git a/chrome/browser/cocoa/history_menu_cocoa_controller.mm b/chrome/browser/cocoa/history_menu_cocoa_controller.mm
index b6523ab..89dd2f8 100644
--- a/chrome/browser/cocoa/history_menu_cocoa_controller.mm
+++ b/chrome/browser/cocoa/history_menu_cocoa_controller.mm
@@ -7,10 +7,10 @@
#import "chrome/browser/cocoa/history_menu_cocoa_controller.h"
#include "chrome/browser/browser_list.h"
#include "chrome/browser/browser_process.h"
+#include "chrome/browser/cocoa/event_utils.h"
#include "chrome/browser/history/history.h"
#include "chrome/browser/history/history_types.h"
#include "chrome/browser/tab_contents/tab_contents.h"
-#import "chrome/common/cocoa_utils.h"
#include "webkit/glue/window_open_disposition.h"
@implementation HistoryMenuCocoaController
@@ -25,21 +25,11 @@
// Open the URL of the given history item in the current tab.
- (void)openURLForItem:(HistoryMenuBridge::HistoryItem&)node {
- Browser* browser = BrowserList::GetLastActive();
-
- if (!browser) { // No windows open?
- Browser::OpenEmptyWindow(bridge_->profile());
- browser = BrowserList::GetLastActive();
- }
- DCHECK(browser);
- TabContents* tab_contents = browser->GetSelectedTabContents();
- DCHECK(tab_contents);
-
- // A TabContents is a PageNavigator, so we can OpenURL() on it.
- WindowOpenDisposition disposition = event_utils::DispositionFromEventFlags(
- [[NSApp currentEvent] modifierFlags]);
- tab_contents->OpenURL(node.url, GURL(), disposition,
- PageTransition::AUTO_BOOKMARK);
+ Browser* browser = Browser::GetOrCreateTabbedBrowser(bridge_->profile());
+ WindowOpenDisposition disposition =
+ event_utils::WindowOpenDispositionFromNSEvent([NSApp currentEvent]);
+ browser->OpenURL(node.url, GURL(), disposition,
+ PageTransition::AUTO_BOOKMARK);
}
- (HistoryMenuBridge::HistoryItem)itemForTag:(NSInteger)tag {