diff options
88 files changed, 746 insertions, 3946 deletions
diff --git a/chrome/app/chrome_dll_resource.h b/chrome/app/chrome_dll_resource.h index 9022381..7835826 100644 --- a/chrome/app/chrome_dll_resource.h +++ b/chrome/app/chrome_dll_resource.h @@ -205,7 +205,6 @@ #define IDC_ABOUT 40018 #define IDC_HELP_PAGE 40019 #define IDC_SHOW_APP_MENU 40020 -#define IDC_SHOW_EXTENSION_SHELF 40021 #define IDC_MANAGE_EXTENSIONS 40022 #define IDC_AUTOFILL_DEFAULT 40023 #define IDC_DEV_TOOLS_INSPECT 40025 diff --git a/chrome/browser/browser.cc b/chrome/browser/browser.cc index a5f65d2..03568cb 100644 --- a/chrome/browser/browser.cc +++ b/chrome/browser/browser.cc @@ -44,7 +44,7 @@ #include "chrome/browser/extensions/crashed_extension_infobar.h" #include "chrome/browser/extensions/extension_browser_event_router.h" #include "chrome/browser/extensions/extension_disabled_infobar_delegate.h" -#include "chrome/browser/extensions/extension_shelf_model.h" +#include "chrome/browser/extensions/extension_host.h" #include "chrome/browser/extensions/extension_tabs_module.h" #include "chrome/browser/extensions/extensions_service.h" #include "chrome/browser/find_bar.h" @@ -355,9 +355,6 @@ Browser* Browser::CreateForDevTools(Profile* profile) { void Browser::CreateBrowserWindow() { DCHECK(!window_); - if (SupportsWindowFeature(FEATURE_EXTENSIONSHELF)) - extension_shelf_model_.reset(new ExtensionShelfModel(this)); - window_ = BrowserWindow::CreateBrowserWindow(this); #if defined(OS_WIN) @@ -1159,7 +1156,6 @@ bool Browser::SupportsWindowFeatureImpl(WindowFeature feature, if (type() == TYPE_NORMAL) { features |= FEATURE_BOOKMARKBAR; - features |= FEATURE_EXTENSIONSHELF; } if (!hide_ui_for_fullscreen) { @@ -1731,12 +1727,6 @@ void Browser::ToggleBookmarkBar() { window_->ToggleBookmarkBar(); } -void Browser::ToggleExtensionShelf() { - UserMetrics::RecordAction(UserMetricsAction("ToggleExtensionShelf"), - profile_); - window_->ToggleExtensionShelf(); -} - void Browser::OpenBookmarkManager() { UserMetrics::RecordAction(UserMetricsAction("ShowBookmarkManager"), profile_); ShowBookmarkManagerTab(); @@ -1949,7 +1939,6 @@ void Browser::RegisterUserPrefs(PrefService* prefs) { prefs->RegisterIntegerPref(prefs::kDeleteTimePeriod, 0); prefs->RegisterBooleanPref(prefs::kCheckDefaultBrowser, true); prefs->RegisterBooleanPref(prefs::kShowOmniboxSearchHint, true); - prefs->RegisterBooleanPref(prefs::kShowExtensionShelf, true); prefs->RegisterBooleanPref(prefs::kWebAppCreateOnDesktop, true); prefs->RegisterBooleanPref(prefs::kWebAppCreateInAppsMenu, true); prefs->RegisterBooleanPref(prefs::kWebAppCreateInQuickLaunchBar, true); @@ -2128,7 +2117,6 @@ void Browser::ExecuteCommandWithDisposition( case IDC_REPORT_BUG: OpenBugReportDialog(); break; case IDC_SHOW_BOOKMARK_BAR: ToggleBookmarkBar(); break; - case IDC_SHOW_EXTENSION_SHELF: ToggleExtensionShelf(); break; case IDC_SHOW_BOOKMARK_MANAGER: OpenBookmarkManager(); break; case IDC_SHOW_APP_MENU: ShowAppMenu(); break; @@ -2692,10 +2680,6 @@ void Browser::ToolbarSizeChanged(TabContents* source, bool is_animating) { } } -void Browser::ExtensionShelfSizeChanged() { - window_->SelectedTabExtensionShelfSizeChanged(); -} - void Browser::URLStarredChanged(TabContents* source, bool starred) { if (source == GetSelectedTabContents()) window_->SetStarredState(starred); @@ -3240,7 +3224,6 @@ void Browser::InitCommandState() { command_updater_.UpdateCommandEnabled(IDC_TASK_MANAGER, true); command_updater_.UpdateCommandEnabled(IDC_SHOW_HISTORY, true); command_updater_.UpdateCommandEnabled(IDC_SHOW_BOOKMARK_MANAGER, true); - command_updater_.UpdateCommandEnabled(IDC_SHOW_EXTENSION_SHELF, true); command_updater_.UpdateCommandEnabled(IDC_SHOW_DOWNLOADS, true); command_updater_.UpdateCommandEnabled(IDC_HELP_PAGE, true); command_updater_.UpdateCommandEnabled(IDC_IMPORT_SETTINGS, true); @@ -3418,11 +3401,9 @@ void Browser::ScheduleUIUpdate(const TabContents* source, TabStripModelObserver::TITLE_NOT_LOADING); } - if (changed_flags & TabContents::INVALIDATE_BOOKMARK_BAR || - changed_flags & TabContents::INVALIDATE_EXTENSION_SHELF) { + if (changed_flags & TabContents::INVALIDATE_BOOKMARK_BAR) { window()->ShelfVisibilityChanged(); - changed_flags &= ~(TabContents::INVALIDATE_BOOKMARK_BAR | - TabContents::INVALIDATE_EXTENSION_SHELF); + changed_flags &= ~TabContents::INVALIDATE_BOOKMARK_BAR; } // If the only updates were synchronously handled above, we're done. diff --git a/chrome/browser/browser.h b/chrome/browser/browser.h index ff3bb03..57da415 100644 --- a/chrome/browser/browser.h +++ b/chrome/browser/browser.h @@ -32,7 +32,6 @@ class BrowserWindow; class Extension; -class ExtensionShelfModel; class FindBarController; class PrefService; class Profile; @@ -87,8 +86,7 @@ class Browser : public TabStripModelDelegate, FEATURE_LOCATIONBAR = 8, FEATURE_BOOKMARKBAR = 16, FEATURE_INFOBAR = 32, - FEATURE_DOWNLOADSHELF = 64, - FEATURE_EXTENSIONSHELF = 128 + FEATURE_DOWNLOADSHELF = 64 }; // Maximized state on creation. @@ -175,9 +173,6 @@ class Browser : public TabStripModelDelegate, ToolbarModel* toolbar_model() { return &toolbar_model_; } const SessionID& session_id() const { return session_id_; } CommandUpdater* command_updater() { return &command_updater_; } - ExtensionShelfModel* extension_shelf_model() { - return extension_shelf_model_.get(); - } // Get the FindBarController for this browser, creating it if it does not // yet exist. @@ -384,10 +379,6 @@ class Browser : public TabStripModelDelegate, // part of an animation. void ToolbarSizeChanged(bool is_animating); - // Notification that the extension shelf has changed size (as a result of - // becoming detached or attached). - void ExtensionShelfSizeChanged(); - // Replaces the state of the currently selected tab with the session // history restored from the SessionRestore system. void ReplaceRestoredTab( @@ -508,7 +499,6 @@ class Browser : public TabStripModelDelegate, void OpenBugReportDialog(); void ToggleBookmarkBar(); - void ToggleExtensionShelf(); void OpenBookmarkManager(); void ShowAppMenu(); @@ -985,9 +975,6 @@ class Browser : public TabStripModelDelegate, // The model for the toolbar view. ToolbarModel toolbar_model_; - // The model for the extension shelf. - scoped_ptr<ExtensionShelfModel> extension_shelf_model_; - // UI update coalescing and handling //////////////////////////////////////// typedef std::map<const TabContents*, int> UpdateMap; diff --git a/chrome/browser/browser_resources.grd b/chrome/browser/browser_resources.grd index 40a11a1..63137c2 100644 --- a/chrome/browser/browser_resources.grd +++ b/chrome/browser/browser_resources.grd @@ -35,7 +35,6 @@ without changes to the corresponding grd file. eadee --> <if expr="os != 'darwin'"> <include name="IDR_EXTENSIONS_INFOBAR_CSS" file="resources\extensions_infobar.css" flattenhtml="true" type="BINDATA" /> </if> - <include name="IDR_EXTENSIONS_TOOLSTRIP_THEME_CSS" file="resources\extensions_toolstrip.css" flattenhtml="true" type="BINDATA" /> <include name="IDR_EXTENSIONS_UI_HTML" file="resources\extensions_ui.html" flattenhtml="true" type="BINDATA" /> <include name="IDR_GAIA_LOGIN_HTML" file="sync\resources\gaia_login.html" flattenhtml="true" type="BINDATA" /> <include name="IDR_GMAIL_APP_MANIFEST" file="resources\gmail_app\manifest.json" type="BINDATA" /> diff --git a/chrome/browser/browser_window.h b/chrome/browser/browser_window.h index 0b679ab..6554713 100644 --- a/chrome/browser/browser_window.h +++ b/chrome/browser/browser_window.h @@ -87,17 +87,14 @@ class BrowserWindow { // BrowserView. virtual void SelectedTabToolbarSizeChanged(bool is_animating) = 0; - // Notification for the Extension Shelf changing its size. - virtual void SelectedTabExtensionShelfSizeChanged() = 0; - // Inform the frame that the selected tab favicon or title has changed. Some // frames may need to refresh their title bar. virtual void UpdateTitleBar() = 0; - // Invoked when the visibility of the bookmark bar or extension shelf changes. - // NOTE: this is NOT sent when the user toggles the visibility of one of - // these shelves, but rather when the user transitions from a page that forces - // the shelves to be visibile to one that doesn't have them visible (or + // Invoked when the visibility of the bookmark bar. + // NOTE: this is NOT sent when the user toggles the visibility of this, + // but rather when the user transitions from a page that forces + // it to be visibile to one that doesn't have it visible (or // vice-versa). // TODO(sky): see about routing visibility pref changing through here too. virtual void ShelfVisibilityChanged() = 0; @@ -190,9 +187,6 @@ class BrowserWindow { // Shows or hides the bookmark bar depending on its current visibility. virtual void ToggleBookmarkBar() = 0; - // Shows or hides the extension shelf depending on its current visibility. - virtual void ToggleExtensionShelf() = 0; - // Shows the About Chrome dialog box. virtual views::Window* ShowAboutChromeDialog() = 0; diff --git a/chrome/browser/cocoa/browser_window_cocoa.h b/chrome/browser/cocoa/browser_window_cocoa.h index 68e7061..354b9d5 100644 --- a/chrome/browser/cocoa/browser_window_cocoa.h +++ b/chrome/browser/cocoa/browser_window_cocoa.h @@ -42,7 +42,6 @@ class BrowserWindowCocoa : public BrowserWindow, virtual BrowserWindowTesting* GetBrowserWindowTesting(); virtual StatusBubble* GetStatusBubble(); virtual void SelectedTabToolbarSizeChanged(bool is_animating); - virtual void SelectedTabExtensionShelfSizeChanged(); virtual void UpdateTitleBar(); virtual void ShelfVisibilityChanged(); virtual void UpdateDevTools(); @@ -70,7 +69,6 @@ class BrowserWindowCocoa : public BrowserWindow, virtual void ConfirmAddSearchProvider(const TemplateURL* template_url, Profile* profile); virtual void ToggleBookmarkBar(); - virtual void ToggleExtensionShelf(); virtual views::Window* ShowAboutChromeDialog(); virtual void ShowUpdateChromeDialog(); virtual void ShowTaskManager(); diff --git a/chrome/browser/cocoa/browser_window_cocoa.mm b/chrome/browser/cocoa/browser_window_cocoa.mm index 33bbc73..d7c1828 100644 --- a/chrome/browser/cocoa/browser_window_cocoa.mm +++ b/chrome/browser/cocoa/browser_window_cocoa.mm @@ -141,10 +141,6 @@ void BrowserWindowCocoa::SelectedTabToolbarSizeChanged(bool is_animating) { // sort on Mac. } -void BrowserWindowCocoa::SelectedTabExtensionShelfSizeChanged() { - NOTIMPLEMENTED(); -} - void BrowserWindowCocoa::UpdateTitleBar() { NSString* newTitle = base::SysUTF16ToNSString(browser_->GetWindowTitleForCurrentTab()); @@ -276,10 +272,6 @@ void BrowserWindowCocoa::ToggleBookmarkBar() { bookmark_utils::ToggleWhenVisible(browser_->profile()); } -void BrowserWindowCocoa::ToggleExtensionShelf() { - NOTIMPLEMENTED(); -} - void BrowserWindowCocoa::AddFindBar( FindBarCocoaController* find_bar_cocoa_controller) { return [controller_ addFindBar:find_bar_cocoa_controller]; diff --git a/chrome/browser/cocoa/view_id_util_browsertest.mm b/chrome/browser/cocoa/view_id_util_browsertest.mm index 2f887f9..ca7f765 100644 --- a/chrome/browser/cocoa/view_id_util_browsertest.mm +++ b/chrome/browser/cocoa/view_id_util_browsertest.mm @@ -53,10 +53,6 @@ class ViewIDTest : public InProcessBrowserTest { } for (int i = VIEW_ID_TOOLBAR; i < VIEW_ID_PREDEFINED_COUNT; ++i) { - // Extension shelf is being removed, http://crbug.com/30178. - if (i == VIEW_ID_DEV_EXTENSION_SHELF) - continue; - // Mac implementation does not support following ids yet. if (i == VIEW_ID_STAR_BUTTON || i == VIEW_ID_AUTOCOMPLETE || diff --git a/chrome/browser/dom_ui/dom_ui.cc b/chrome/browser/dom_ui/dom_ui.cc index a4f3583..983539e 100644 --- a/chrome/browser/dom_ui/dom_ui.cc +++ b/chrome/browser/dom_ui/dom_ui.cc @@ -38,7 +38,6 @@ std::wstring GetJavascript(const std::wstring& function_name, DOMUI::DOMUI(TabContents* contents) : hide_favicon_(false), force_bookmark_bar_visible_(false), - force_extension_shelf_visible_(false), focus_location_bar_by_default_(false), should_hide_url_(false), link_transition_type_(PageTransition::LINK), diff --git a/chrome/browser/dom_ui/dom_ui.h b/chrome/browser/dom_ui/dom_ui.h index 4d35723..3aadbd5 100644 --- a/chrome/browser/dom_ui/dom_ui.h +++ b/chrome/browser/dom_ui/dom_ui.h @@ -64,12 +64,6 @@ class DOMUI { return force_bookmark_bar_visible_; } - // Returns true if the extension shelf should be forced to being visible - // (if it contains any items), overriding the user's preference. - bool force_extension_shelf_visible() const { - return force_extension_shelf_visible_; - } - // Returns true if the location bar should be focused by default rather than // the page contents. Some pages will want to use this to encourage the user // to type in the URL bar. @@ -129,7 +123,6 @@ class DOMUI { // bool options default to false. See the public getters for more information. bool hide_favicon_; bool force_bookmark_bar_visible_; - bool force_extension_shelf_visible_; bool focus_location_bar_by_default_; bool should_hide_url_; string16 overridden_title_; // Defaults to empty string. diff --git a/chrome/browser/dom_ui/new_tab_ui.cc b/chrome/browser/dom_ui/new_tab_ui.cc index ffde24a..7d83e821 100644 --- a/chrome/browser/dom_ui/new_tab_ui.cc +++ b/chrome/browser/dom_ui/new_tab_ui.cc @@ -445,7 +445,6 @@ NewTabUI::NewTabUI(TabContents* contents) // Override some options on the DOM UI. hide_favicon_ = true; force_bookmark_bar_visible_ = true; - force_extension_shelf_visible_ = true; focus_location_bar_by_default_ = true; should_hide_url_ = true; overridden_title_ = l10n_util::GetStringUTF16(IDS_NEW_TAB_TITLE); diff --git a/chrome/browser/extensions/extension_browsertest.cc b/chrome/browser/extensions/extension_browsertest.cc index a30f352..8660cb1 100644 --- a/chrome/browser/extensions/extension_browsertest.cc +++ b/chrome/browser/extensions/extension_browsertest.cc @@ -44,11 +44,6 @@ void ExtensionBrowserTest::SetUpCommandLine(CommandLine* command_line) { PathService::Get(chrome::DIR_TEST_DATA, &test_data_dir_); test_data_dir_ = test_data_dir_.AppendASCII("extensions"); - // There are a number of tests that still use toolstrips. Rather than - // selectively enabling each of them, enable toolstrips for all extension - // tests. - command_line->AppendSwitch(switches::kEnableExtensionToolstrips); - #if defined(OS_CHROMEOS) // This makes sure that we create the Default profile first, with no // ExtensionsService and then the real profile with one, as we do when diff --git a/chrome/browser/extensions/extension_browsertests_misc.cc b/chrome/browser/extensions/extension_browsertests_misc.cc index 8b7c9a2..038d07f 100644 --- a/chrome/browser/extensions/extension_browsertests_misc.cc +++ b/chrome/browser/extensions/extension_browsertests_misc.cc @@ -20,7 +20,6 @@ #include "chrome/browser/renderer_host/site_instance.h" #include "chrome/browser/tab_contents/tab_contents.h" #if defined(TOOLKIT_VIEWS) -#include "chrome/browser/views/extensions/extension_shelf.h" #include "chrome/browser/views/frame/browser_view.h" #endif #include "chrome/common/chrome_paths.h" @@ -73,110 +72,6 @@ static ExtensionHost* FindHostWithPath(ExtensionProcessManager* manager, return host; } -#if defined(OS_LINUX) && defined(TOOLKIT_VIEWS) -// See http://crbug.com/30151. -#define Toolstrip DISABLED_Toolstrip -#endif - -// Tests that toolstrips initializes properly and can run basic extension js. -IN_PROC_BROWSER_TEST_F(ExtensionBrowserTest, Toolstrip) { - FilePath extension_test_data_dir = test_data_dir_.AppendASCII("good"). - AppendASCII("Extensions").AppendASCII("behllobkkfkfnphdnhnkndlbkcpglgmj"). - AppendASCII("1.0.0.0"); - ASSERT_TRUE(LoadExtension(extension_test_data_dir)); - - // At this point, there should be three ExtensionHosts loaded because this - // extension has two toolstrips and one background page. Find the one that is - // hosting toolstrip1.html. - ExtensionProcessManager* manager = - browser()->profile()->GetExtensionProcessManager(); - ExtensionHost* host = FindHostWithPath(manager, "/toolstrip1.html", 3); - - // Tell it to run some JavaScript that tests that basic extension code works. - bool result = false; - ui_test_utils::ExecuteJavaScriptAndExtractBool( - host->render_view_host(), L"", L"testTabsAPI()", &result); - EXPECT_TRUE(result); - - // Test for compact language detection API. First navigate to a (static) html - // file with a French sentence. Then, run the test API in toolstrip1.html to - // actually call the language detection API through the existing extension, - // and verify that the language returned is indeed French. - FilePath language_url = extension_test_data_dir.AppendASCII( - "french_sentence.html"); - ui_test_utils::NavigateToURL(browser(), net::FilePathToFileURL(language_url)); - - ui_test_utils::ExecuteJavaScriptAndExtractBool( - host->render_view_host(), L"", L"testTabsLanguageAPI()", &result); - EXPECT_TRUE(result); -} - -IN_PROC_BROWSER_TEST_F(ExtensionBrowserTest, ExtensionViews) { - FilePath extension_test_data_dir = test_data_dir_.AppendASCII("good"). - AppendASCII("Extensions").AppendASCII("behllobkkfkfnphdnhnkndlbkcpglgmj"). - AppendASCII("1.0.0.0"); - ASSERT_TRUE(LoadExtension(extension_test_data_dir)); - - // At this point, there should be three ExtensionHosts loaded because this - // extension has two toolstrips and one background page. Find the one that is - // hosting toolstrip1.html. - ExtensionProcessManager* manager = - browser()->profile()->GetExtensionProcessManager(); - ExtensionHost* host = FindHostWithPath(manager, "/toolstrip1.html", 3); - - FilePath gettabs_url = extension_test_data_dir.AppendASCII( - "test_gettabs.html"); - ui_test_utils::NavigateToURL( - browser(), - GURL(gettabs_url.value())); - - bool result = false; - ui_test_utils::ExecuteJavaScriptAndExtractBool( - host->render_view_host(), L"", L"testgetToolstripsAPI()", &result); - EXPECT_TRUE(result); - - result = false; - ui_test_utils::ExecuteJavaScriptAndExtractBool( - host->render_view_host(), L"", L"testgetBackgroundPageAPI()", &result); - EXPECT_TRUE(result); - - ui_test_utils::NavigateToURL( - browser(), - GURL("chrome-extension://behllobkkfkfnphdnhnkndlbkcpglgmj/" - "test_gettabs.html")); - result = false; - ui_test_utils::ExecuteJavaScriptAndExtractBool( - host->render_view_host(), L"", L"testgetExtensionTabsAPI()", &result); - EXPECT_TRUE(result); -} - -#if defined(TOOLKIT_VIEWS) -// http://crbug.com/29897 - for other UI toolkits? - -// Tests that the ExtensionShelf initializes properly, notices that -// an extension loaded and has a view available, and then sets that up -// properly. -IN_PROC_BROWSER_TEST_F(ExtensionBrowserTest, Shelf) { - // When initialized, there are no extension views and the preferred height - // should be zero. - BrowserView* browser_view = static_cast<BrowserView*>(browser()->window()); - ExtensionShelf* shelf = browser_view->extension_shelf(); - ASSERT_TRUE(shelf); - EXPECT_EQ(shelf->GetChildViewCount(), 0); - EXPECT_EQ(shelf->GetPreferredSize().height(), 0); - - ASSERT_TRUE(LoadExtension( - test_data_dir_.AppendASCII("good").AppendASCII("Extensions") - .AppendASCII("behllobkkfkfnphdnhnkndlbkcpglgmj") - .AppendASCII("1.0.0.0"))); - - // There should now be two extension views and preferred height of the view - // should be non-zero. - EXPECT_EQ(shelf->GetChildViewCount(), 2); - EXPECT_NE(shelf->GetPreferredSize().height(), 0); -} -#endif // defined(TOOLKIT_VIEWS) - // Tests that extension resources can be loaded from origins which the // extension specifies in permissions but not from others. IN_PROC_BROWSER_TEST_F(ExtensionBrowserTest, OriginPrivileges) { @@ -700,7 +595,7 @@ IN_PROC_BROWSER_TEST_F(ExtensionBrowserTest, LastError) { // Get the ExtensionHost that is hosting our toolstrip page. ExtensionProcessManager* manager = browser()->profile()->GetExtensionProcessManager(); - ExtensionHost* host = FindHostWithPath(manager, "/toolstrip.html", 1); + ExtensionHost* host = FindHostWithPath(manager, "/bg.html", 1); bool result = false; ui_test_utils::ExecuteJavaScriptAndExtractBool( diff --git a/chrome/browser/extensions/extension_function_dispatcher.cc b/chrome/browser/extensions/extension_function_dispatcher.cc index 8371346..a4c255a 100644 --- a/chrome/browser/extensions/extension_function_dispatcher.cc +++ b/chrome/browser/extensions/extension_function_dispatcher.cc @@ -44,7 +44,6 @@ #include "chrome/browser/extensions/extension_tabs_module.h" #include "chrome/browser/extensions/extension_tabs_module_constants.h" #include "chrome/browser/extensions/extension_test_api.h" -#include "chrome/browser/extensions/extension_toolstrip_api.h" #if defined(OS_CHROMEOS) #include "chrome/browser/extensions/extension_tts_api.h" #endif @@ -183,10 +182,6 @@ void FactoryRegistry::ResetFunctions() { // Idle RegisterFunction<ExtensionIdleQueryStateFunction>(); - // Toolstrips. - RegisterFunction<ToolstripExpandFunction>(); - RegisterFunction<ToolstripCollapseFunction>(); - // I18N. RegisterFunction<GetAcceptLanguagesFunction>(); @@ -400,8 +395,8 @@ Browser* ExtensionFunctionDispatcher::GetCurrentBrowser( include_incognito); // NOTE(rafaelw): This can return NULL in some circumstances. In particular, - // a toolstrip or background_page onload chrome.tabs api call can make it - // into here before the browser is sufficiently initialized to return here. + // a background_page onload chrome.tabs api call can make it into here + // before the browser is sufficiently initialized to return here. // A similar situation may arise during shutdown. // TODO(rafaelw): Delay creation of background_page until the browser // is available. http://code.google.com/p/chromium/issues/detail?id=13284 diff --git a/chrome/browser/extensions/extension_host.cc b/chrome/browser/extensions/extension_host.cc index 49e84ba..895fd2f 100644 --- a/chrome/browser/extensions/extension_host.cc +++ b/chrome/browser/extensions/extension_host.cc @@ -59,8 +59,6 @@ using WebKit::WebDragOperationsMask; // static bool ExtensionHost::enable_dom_automation_ = false; -static const char* kToolstripTextColorSubstitution = "$TEXT_COLOR$"; - // Helper class that rate-limits the creation of renderer processes for // ExtensionHosts, to avoid blocking the UI. class ExtensionHost::ProcessCreationQueue { @@ -249,12 +247,6 @@ void ExtensionHost::Observe(NotificationType type, DCHECK(extension_->GetBackgroundPageReady()); NavigateToURL(url_); break; - case NotificationType::BROWSER_THEME_CHANGED: - if (extension_host_type_ == ViewType::EXTENSION_TOOLSTRIP || - extension_host_type_ == ViewType::EXTENSION_MOLE) { - InsertThemedToolstripCSS(); - } - break; case NotificationType::RENDERER_PROCESS_CREATED: LOG(INFO) << "Sending EXTENSION_PROCESS_CREATED"; NotificationService::current()->Notify( @@ -325,8 +317,7 @@ void ExtensionHost::DidNavigate(RenderViewHost* render_view_host, // In both cases, we preserve the old URL and reset the EFD to NULL. This // will leave the host in kind of a bad state with poor UI and errors, but // it's better than the alternative. - // TODO(erikkay) Perhaps we should display log errors or display a big 404 - // in the toolstrip or something like that. + // TODO(erikkay) Perhaps we should display errors in developer mode. if (params.url.host() != extension_->id()) { extension_function_dispatcher_.reset(NULL); return; @@ -350,36 +341,6 @@ void ExtensionHost::InsertInfobarCSS() { L"", css.as_string(), "InfobarThemeCSS"); } -void ExtensionHost::InsertThemedToolstripCSS() { - DCHECK(!is_background_page()); - - static const base::StringPiece toolstrip_theme_css( - ResourceBundle::GetSharedInstance().GetRawDataResource( - IDR_EXTENSIONS_TOOLSTRIP_THEME_CSS)); - - std::string css = toolstrip_theme_css.as_string(); - ThemeProvider* theme_provider = - render_view_host()->process()->profile()->GetThemeProvider(); - - SkColor text_color = theme_provider ? - theme_provider->GetColor(BrowserThemeProvider::COLOR_BOOKMARK_TEXT) : - SK_ColorBLACK; - - std::string hex_color_string = StringPrintf( - "#%02x%02x%02x", SkColorGetR(text_color), - SkColorGetG(text_color), - SkColorGetB(text_color)); - size_t pos = css.find(kToolstripTextColorSubstitution); - while (pos != std::string::npos) { - css.replace(pos, 12, hex_color_string); - pos = css.find(kToolstripTextColorSubstitution); - } - - // As a toolstrip, inject our toolstrip CSS to make it easier for toolstrips - // to blend in with the chrome UI. - render_view_host()->InsertCSSInWebFrame(L"", css, "ToolstripThemeCSS"); -} - void ExtensionHost::DisableScrollbarsForSmallWindows( const gfx::Size& size_limit) { render_view_host()->Send(new ViewMsg_DisableScrollbarsForSmallWindows( @@ -389,9 +350,7 @@ void ExtensionHost::DisableScrollbarsForSmallWindows( void ExtensionHost::DidStopLoading() { bool notify = !did_stop_loading_; did_stop_loading_ = true; - if (extension_host_type_ == ViewType::EXTENSION_TOOLSTRIP || - extension_host_type_ == ViewType::EXTENSION_MOLE || - extension_host_type_ == ViewType::EXTENSION_POPUP || + if (extension_host_type_ == ViewType::EXTENSION_POPUP || extension_host_type_ == ViewType::EXTENSION_INFOBAR) { #if defined(TOOLKIT_VIEWS) if (view_.get()) @@ -410,9 +369,6 @@ void ExtensionHost::DidStopLoading() { } else if (extension_host_type_ == ViewType::EXTENSION_POPUP) { UMA_HISTOGRAM_TIMES("Extensions.PopupLoadTime", since_created_.Elapsed()); - } else if (extension_host_type_ == ViewType::EXTENSION_TOOLSTRIP) { - UMA_HISTOGRAM_TIMES("Extensions.ToolstripLoadTime", - since_created_.Elapsed()); } else if (extension_host_type_ == ViewType::EXTENSION_INFOBAR) { UMA_HISTOGRAM_TIMES("Extensions.InfobarLoadTime", since_created_.Elapsed()); @@ -434,15 +390,6 @@ void ExtensionHost::DocumentAvailableInMainFrame(RenderViewHost* rvh) { case ViewType::EXTENSION_INFOBAR: InsertInfobarCSS(); break; - case ViewType::EXTENSION_TOOLSTRIP: - case ViewType::EXTENSION_MOLE: - // See also BROWSER_THEME_CHANGED in the Observe function. - InsertThemedToolstripCSS(); - - // Listen for browser changes so we can resend the CSS. - registrar_.Add(this, NotificationType::BROWSER_THEME_CHANGED, - NotificationService::AllSources()); - break; default: break; // No style sheet for other types, at the moment. } @@ -702,14 +649,6 @@ void ExtensionHost::HandleMouseLeave() { #endif } -void ExtensionHost::SetRenderViewType(ViewType::Type type) { - DCHECK(type == ViewType::EXTENSION_MOLE || - type == ViewType::EXTENSION_TOOLSTRIP || - type == ViewType::EXTENSION_POPUP); - extension_host_type_ = type; - render_view_host()->ViewTypeChanged(extension_host_type_); -} - ViewType::Type ExtensionHost::GetRenderViewType() const { return extension_host_type_; } @@ -727,9 +666,7 @@ void ExtensionHost::RenderViewCreated(RenderViewHost* render_view_host) { extension_function_dispatcher_.reset( ExtensionFunctionDispatcher::Create(render_view_host, this, url_)); - if (extension_host_type_ == ViewType::EXTENSION_TOOLSTRIP || - extension_host_type_ == ViewType::EXTENSION_MOLE || - extension_host_type_ == ViewType::EXTENSION_POPUP || + if (extension_host_type_ == ViewType::EXTENSION_POPUP || extension_host_type_ == ViewType::EXTENSION_INFOBAR) { render_view_host->EnablePreferredSizeChangedMode( kPreferredSizeWidth | kPreferredSizeHeightThisIsSlow); @@ -740,9 +677,7 @@ int ExtensionHost::GetBrowserWindowID() const { // Hosts not attached to any browser window have an id of -1. This includes // those mentioned below, and background pages. int window_id = extension_misc::kUnknownWindowId; - if (extension_host_type_ == ViewType::EXTENSION_TOOLSTRIP || - extension_host_type_ == ViewType::EXTENSION_MOLE || - extension_host_type_ == ViewType::EXTENSION_POPUP || + if (extension_host_type_ == ViewType::EXTENSION_POPUP || extension_host_type_ == ViewType::EXTENSION_INFOBAR) { // If the host is bound to a browser, then extract its window id. // Extensions hosted in ExternalTabContainer objects may not have diff --git a/chrome/browser/extensions/extension_host.h b/chrome/browser/extensions/extension_host.h index 253c4f4..7d293db 100644 --- a/chrome/browser/extensions/extension_host.h +++ b/chrome/browser/extensions/extension_host.h @@ -92,9 +92,6 @@ class ExtensionHost : public RenderViewHostDelegate, associated_tab_contents_ = associated_tab_contents; } - // Sets the the ViewType of this host (e.g. mole, toolstrip). - void SetRenderViewType(ViewType::Type type); - // Returns true if the render view is initialized and didn't crash. bool IsRenderViewLive() const; @@ -109,9 +106,6 @@ class ExtensionHost : public RenderViewHostDelegate, // Insert a default style sheet for Extension Infobars. void InsertInfobarCSS(); - // Insert the theme CSS for a toolstrip/mole. - void InsertThemedToolstripCSS(); - // Tell the renderer not to draw scrollbars on windows smaller than // |size_limit| in both width and height. void DisableScrollbarsForSmallWindows(const gfx::Size& size_limit); @@ -267,7 +261,7 @@ class ExtensionHost : public RenderViewHostDelegate, scoped_ptr<ExtensionFunctionDispatcher> extension_function_dispatcher_; - // Only EXTENSION_TOOLSTRIP, EXTENSION_POPUP, and EXTENSION_BACKGROUND_PAGE + // Only EXTENSION_INFOBAR, EXTENSION_POPUP, and EXTENSION_BACKGROUND_PAGE // are used here, others are not hosted by ExtensionHost. ViewType::Type extension_host_type_; diff --git a/chrome/browser/extensions/extension_popup_api.cc b/chrome/browser/extensions/extension_popup_api.cc index 1d3c3c7..855dfa1 100644 --- a/chrome/browser/extensions/extension_popup_api.cc +++ b/chrome/browser/extensions/extension_popup_api.cc @@ -45,7 +45,7 @@ const char kBadAnchorArgument[] = "Invalid anchor argument."; const char kInvalidURLError[] = "Invalid URL."; const char kNotAnExtension[] = "Not an extension view."; const char kPopupsDisallowed[] = - "Popups are only supported from toolstrip or tab-contents views."; + "Popups are only supported from tab-contents views."; // Keys. const wchar_t kUrlKey[] = L"url"; @@ -356,12 +356,10 @@ void PopupShowFunction::Run() { } bool PopupShowFunction::RunImpl() { - // Popups may only be displayed from TAB_CONTENTS and EXTENSION_TOOLSTRIP - // views. + // Popups may only be displayed from TAB_CONTENTS. ViewType::Type view_type = dispatcher()->render_view_host()->delegate()->GetRenderViewType(); - if (ViewType::EXTENSION_TOOLSTRIP != view_type && - ViewType::TAB_CONTENTS != view_type) { + if (ViewType::TAB_CONTENTS != view_type) { error_ = kPopupsDisallowed; return false; } @@ -444,11 +442,7 @@ bool PopupShowFunction::RunImpl() { window = GetCurrentBrowser()->window()->GetNativeHandle(); #if defined(TOOLKIT_VIEWS) - // Pop-up from extension views (ExtensionShelf, etc.), and drop-down when - // in a TabContents view. - BubbleBorder::ArrowLocation arrow_location = - view_type == ViewType::TAB_CONTENTS ? - BubbleBorder::TOP_LEFT : BubbleBorder::BOTTOM_LEFT; + BubbleBorder::ArrowLocation arrow_location = BubbleBorder::TOP_LEFT; // ExtensionPopupHost manages it's own lifetime. ExtensionPopupHost* popup_host = new ExtensionPopupHost(dispatcher()); @@ -468,6 +462,7 @@ bool PopupShowFunction::RunImpl() { popup_->set_close_on_lost_focus(false); popup_host->set_popup(popup_); #endif // defined(TOOLKIT_VIEWS) + return true; } diff --git a/chrome/browser/extensions/extension_popup_apitest.cc b/chrome/browser/extensions/extension_popup_apitest.cc index ba6a082..0d71219 100644 --- a/chrome/browser/extensions/extension_popup_apitest.cc +++ b/chrome/browser/extensions/extension_popup_apitest.cc @@ -13,11 +13,10 @@ #define MAYBE_Popup Popup #endif -IN_PROC_BROWSER_TEST_F(ExtensionApiTest, MAYBE_Popup) { +// Disabled for some rewriting. http://crbug.com/51821 +IN_PROC_BROWSER_TEST_F(ExtensionApiTest, DISABLED_Popup) { CommandLine::ForCurrentProcess()->AppendSwitch( switches::kEnableExperimentalExtensionApis); - CommandLine::ForCurrentProcess()->AppendSwitch( - switches::kEnableExtensionToolstrips); ASSERT_TRUE(RunExtensionTest("popup")) << message_; } diff --git a/chrome/browser/extensions/extension_prefs.cc b/chrome/browser/extensions/extension_prefs.cc index e987065..c33ea33 100644 --- a/chrome/browser/extensions/extension_prefs.cc +++ b/chrome/browser/extensions/extension_prefs.cc @@ -41,10 +41,6 @@ const char kPrefBlacklist[] = "blacklist"; // Indicates whether to show an install warning when the user enables. const char kExtensionDidEscalatePermissions[] = "install_warning_on_enable"; -// A preference that tracks extension shelf configuration. This is a list -// object read from the Preferences file, containing a list of toolstrip URLs. -const char kExtensionShelf[] = "extensions.shelf"; - // A preference that tracks admin policy regarding which extensions the user // can and can not install. This preference is a list object, containing // strings that list extension ids. Denylist can contain "*" meaning all @@ -438,29 +434,6 @@ void ExtensionPrefs::GetKilledExtensionIds(std::set<std::string>* killed_ids) { } } -ExtensionPrefs::URLList ExtensionPrefs::GetShelfToolstripOrder() { - URLList urls; - const ListValue* toolstrip_urls = prefs_->GetList(kExtensionShelf); - if (toolstrip_urls) { - for (size_t i = 0; i < toolstrip_urls->GetSize(); ++i) { - std::string url; - if (toolstrip_urls->GetString(i, &url)) - urls.push_back(GURL(url)); - } - } - return urls; -} - -void ExtensionPrefs::SetShelfToolstripOrder(const URLList& urls) { - ListValue* toolstrip_urls = prefs_->GetMutableList(kExtensionShelf); - toolstrip_urls->Clear(); - for (size_t i = 0; i < urls.size(); ++i) { - GURL url = urls[i]; - toolstrip_urls->Append(new StringValue(url.spec())); - } - prefs_->ScheduleSavePersistentPrefs(); -} - std::vector<std::string> ExtensionPrefs::GetToolbarOrder() { std::vector<std::string> extension_ids; const ListValue* toolbar_order = prefs_->GetList(kExtensionToolbar); @@ -821,7 +794,6 @@ std::set<std::string> ExtensionPrefs::GetIdleInstallInfoIds() { // static void ExtensionPrefs::RegisterUserPrefs(PrefService* prefs) { prefs->RegisterDictionaryPref(kExtensionsPref); - prefs->RegisterListPref(kExtensionShelf); prefs->RegisterListPref(kExtensionToolbar); prefs->RegisterIntegerPref(prefs::kExtensionToolbarSize, -1); prefs->RegisterDictionaryPref(kExtensionsBlacklistUpdate); diff --git a/chrome/browser/extensions/extension_process_manager.cc b/chrome/browser/extensions/extension_process_manager.cc index 3cde54e..49205cd 100644 --- a/chrome/browser/extensions/extension_process_manager.cc +++ b/chrome/browser/extensions/extension_process_manager.cc @@ -94,17 +94,6 @@ ExtensionHost* ExtensionProcessManager::CreateView(const GURL& url, return NULL; } -ExtensionHost* ExtensionProcessManager::CreateToolstrip(Extension* extension, - const GURL& url, - Browser* browser) { - return CreateView(extension, url, browser, ViewType::EXTENSION_TOOLSTRIP); -} - -ExtensionHost* ExtensionProcessManager::CreateToolstrip(const GURL& url, - Browser* browser) { - return CreateView(url, browser, ViewType::EXTENSION_TOOLSTRIP); -} - ExtensionHost* ExtensionProcessManager::CreatePopup(Extension* extension, const GURL& url, Browser* browser) { diff --git a/chrome/browser/extensions/extension_process_manager.h b/chrome/browser/extensions/extension_process_manager.h index 13b98142..f0c2927 100644 --- a/chrome/browser/extensions/extension_process_manager.h +++ b/chrome/browser/extensions/extension_process_manager.h @@ -40,10 +40,6 @@ class ExtensionProcessManager : public NotificationObserver { ExtensionHost* CreateView(const GURL& url, Browser* browser, ViewType::Type view_type); - ExtensionHost* CreateToolstrip(Extension* extension, - const GURL& url, - Browser* browser); - ExtensionHost* CreateToolstrip(const GURL& url, Browser* browser); ExtensionHost* CreatePopup(Extension* extension, const GURL& url, Browser* browser); diff --git a/chrome/browser/extensions/extension_shelf_model.cc b/chrome/browser/extensions/extension_shelf_model.cc deleted file mode 100644 index 51a8ce1..0000000 --- a/chrome/browser/extensions/extension_shelf_model.cc +++ /dev/null @@ -1,282 +0,0 @@ -// Copyright (c) 2009 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. - -#include "chrome/browser/extensions/extension_shelf_model.h" - -#include "base/stl_util-inl.h" -#include "chrome/browser/browser.h" -#include "chrome/browser/profile.h" -#include "chrome/browser/extensions/extension_host.h" -#include "chrome/browser/extensions/extension_process_manager.h" -#include "chrome/browser/extensions/extension_toolstrip_api.h" -#include "chrome/browser/extensions/extensions_service.h" -#include "chrome/browser/renderer_host/render_view_host.h" -#include "chrome/common/extensions/extension.h" -#include "chrome/common/notification_service.h" - -ExtensionShelfModel::ExtensionShelfModel(Browser* browser) - : browser_(browser), ready_(false) { - // Watch extensions loaded and unloaded notifications. - registrar_.Add(this, NotificationType::EXTENSION_UNLOADED, - NotificationService::AllSources()); - registrar_.Add(this, NotificationType::EXTENSION_LOADED, - NotificationService::AllSources()); - registrar_.Add(this, NotificationType::EXTENSIONS_READY, - NotificationService::AllSources()); - - // Add any already-loaded extensions now, since we missed the notification for - // those. - ExtensionsService* service = browser_->profile()->GetExtensionsService(); - if (service) { // This can be null in unit tests. - prefs_ = browser_->profile()->GetExtensionsService()->extension_prefs(); - registrar_.Add(this, NotificationType::EXTENSION_SHELF_MODEL_CHANGED, - Source<ExtensionPrefs>(prefs_)); - ready_ = service->is_ready(); - if (ready_) { - AddExtensions(service->extensions()); - SortToolstrips(); - } - } -} - -ExtensionShelfModel::~ExtensionShelfModel() { - FOR_EACH_OBSERVER(ExtensionShelfModelObserver, observers_, - ShelfModelDeleting()); - - observers_.Clear(); - - for (iterator t = toolstrips_.begin(); t != toolstrips_.end(); ++t) - delete t->host; - toolstrips_.clear(); -} - -void ExtensionShelfModel::AddObserver(ExtensionShelfModelObserver* observer) { - observers_.AddObserver(observer); -} - -void ExtensionShelfModel::RemoveObserver( - ExtensionShelfModelObserver* observer) { - observers_.RemoveObserver(observer); -} - -void ExtensionShelfModel::AppendToolstrip(const ToolstripItem& toolstrip) { - InsertToolstripAt(count(), toolstrip); -} - -void ExtensionShelfModel::InsertToolstripAt(int index, - const ToolstripItem& toolstrip) { - toolstrips_.insert(toolstrips_.begin() + index, toolstrip); - if (ready_) { - FOR_EACH_OBSERVER(ExtensionShelfModelObserver, observers_, - ToolstripInsertedAt(toolstrip.host, index)); - } -} - -void ExtensionShelfModel::RemoveToolstripAt(int index) { - ExtensionHost* host = ToolstripAt(index).host; - FOR_EACH_OBSERVER(ExtensionShelfModelObserver, observers_, - ToolstripRemovingAt(host, index)); - toolstrips_.erase(toolstrips_.begin() + index); - delete host; -} - -void ExtensionShelfModel::MoveToolstripAt(int index, int to_index) { - DCHECK(index >= 0); - DCHECK(to_index >= 0); - if (index == to_index) - return; - - ToolstripItem toolstrip = toolstrips_[index]; - toolstrips_.erase(toolstrips_.begin() + index); - toolstrips_.insert(toolstrips_.begin() + to_index, toolstrip); - - FOR_EACH_OBSERVER(ExtensionShelfModelObserver, observers_, - ToolstripMoved(toolstrip.host, index, to_index)); - - UpdatePrefs(); -} - -int ExtensionShelfModel::IndexOfHost(ExtensionHost* host) { - for (iterator i = toolstrips_.begin(); i != toolstrips_.end(); ++i) { - if (i->host == host) - return i - toolstrips_.begin(); - } - return -1; -} - -ExtensionShelfModel::iterator ExtensionShelfModel::ToolstripForHost( - ExtensionHost* host) { - for (iterator i = toolstrips_.begin(); i != toolstrips_.end(); ++i) { - if (i->host == host) - return i; - } - return toolstrips_.end(); -} - -const ExtensionShelfModel::ToolstripItem& ExtensionShelfModel::ToolstripAt( - int index) { - DCHECK(index >= 0); - return toolstrips_[index]; -} - -void ExtensionShelfModel::SetToolstripDataAt(int index, void* data) { - DCHECK(index >= 0); - toolstrips_[index].data = data; -} - -void ExtensionShelfModel::ExpandToolstrip(iterator toolstrip, - const GURL& url, int height) { - if (toolstrip == end()) - return; - toolstrip->height = height; - toolstrip->url = url; - FOR_EACH_OBSERVER(ExtensionShelfModelObserver, observers_, - ToolstripChanged(toolstrip)); - int routing_id = toolstrip->host->render_view_host()->routing_id(); - ToolstripEventRouter::OnToolstripExpanded(browser_->profile(), - routing_id, - url, height); - toolstrip->host->SetRenderViewType(ViewType::EXTENSION_MOLE); -} - -void ExtensionShelfModel::CollapseToolstrip(iterator toolstrip, - const GURL& url) { - if (toolstrip == end()) - return; - toolstrip->height = 0; - toolstrip->url = url; - FOR_EACH_OBSERVER(ExtensionShelfModelObserver, observers_, - ToolstripChanged(toolstrip)); - int routing_id = toolstrip->host->render_view_host()->routing_id(); - ToolstripEventRouter::OnToolstripCollapsed(browser_->profile(), - routing_id, - url); - toolstrip->host->SetRenderViewType(ViewType::EXTENSION_TOOLSTRIP); -} - -void ExtensionShelfModel::Observe(NotificationType type, - const NotificationSource& source, - const NotificationDetails& details) { - switch (type.value) { - case NotificationType::EXTENSION_LOADED: - if (ready_) - AddExtension(Details<Extension>(details).ptr()); - break; - case NotificationType::EXTENSION_UNLOADED: - RemoveExtension(Details<Extension>(details).ptr()); - break; - case NotificationType::EXTENSIONS_READY: - if (browser_->profile()->GetExtensionsService()) { - AddExtensions( - browser_->profile()->GetExtensionsService()->extensions()); - SortToolstrips(); - } - ready_ = true; - break; - case NotificationType::EXTENSION_SHELF_MODEL_CHANGED: - // Ignore changes that this model originated. - if (Details<ExtensionShelfModel>(details).ptr() != this) - SortToolstrips(); - break; - default: - DCHECK(false) << "Unhandled notification of type: " << type.value; - break; - } -} - -void ExtensionShelfModel::AddExtension(Extension* extension) { - ExtensionProcessManager* manager = - browser_->profile()->GetExtensionProcessManager(); - DCHECK(manager); - if (!manager) - return; - - for (std::vector<Extension::ToolstripInfo>::const_iterator toolstrip = - extension->toolstrips().begin(); - toolstrip != extension->toolstrips().end(); ++toolstrip) { - GURL url = toolstrip->toolstrip; - ToolstripItem item; - item.host = manager->CreateToolstrip(extension, url, browser_); - item.info = *toolstrip; - item.data = NULL; - item.height = 0; - AppendToolstrip(item); - } -} - -void ExtensionShelfModel::AddExtensions(const ExtensionList* extensions) { - if (extensions->size()) { - ExtensionList::const_iterator extension = extensions->begin(); - for (; extension != extensions->end(); ++extension) - AddExtension(*extension); - } -} - -void ExtensionShelfModel::RemoveExtension(Extension* extension) { - bool changed = false; - for (int i = count() - 1; i >= 0; --i) { - ExtensionHost* t = ToolstripAt(i).host; - if (t->extension()->id() == extension->id()) { - changed = true; - RemoveToolstripAt(i); - - // There can be more than one toolstrip per extension, so we have to keep - // looping even after finding a match. - } - } - if (changed) - UpdatePrefs(); -} - -void ExtensionShelfModel::UpdatePrefs() { - if (!prefs_) - return; - - // It's easiest to just rebuild the list each time. - ExtensionPrefs::URLList urls; - for (int i = 0; i < count(); ++i) - urls.push_back(ToolstripAt(i).host->GetURL()); - prefs_->SetShelfToolstripOrder(urls); - - NotificationService::current()->Notify( - NotificationType::EXTENSION_SHELF_MODEL_CHANGED, - Source<ExtensionPrefs>(prefs_), - Details<ExtensionShelfModel>(this)); -} - -void ExtensionShelfModel::SortToolstrips() { - ExtensionPrefs::URLList urls = prefs_->GetShelfToolstripOrder(); - ToolstripList copy = - ToolstripList(toolstrips_.begin(), toolstrips_.end()); - toolstrips_.clear(); - - // Go through the urls and find the matching toolstrip, re-adding it to the - // new list in the proper order. - for (size_t i = 0; i < urls.size(); ++i) { - GURL& url = urls[i]; - for (iterator toolstrip = copy.begin(); - toolstrip != copy.end(); ++toolstrip) { - if (url == toolstrip->host->GetURL()) { - // Note that it's technically possible for the same URL to appear in - // multiple toolstrips, so we don't do any testing for uniqueness. - toolstrips_.push_back(*toolstrip); - - // Remove the toolstrip from the list so we don't have to iterate over - // it next time. - copy.erase(toolstrip); - break; - } - } - } - - // Any toolstrips remaining in |copy| were somehow missing from the prefs, - // so just append them to the end. - for (iterator toolstrip = copy.begin(); - toolstrip != copy.end(); ++toolstrip) { - toolstrips_.push_back(*toolstrip); - } - - FOR_EACH_OBSERVER(ExtensionShelfModelObserver, observers_, - ShelfModelReloaded()); -} diff --git a/chrome/browser/extensions/extension_shelf_model.h b/chrome/browser/extensions/extension_shelf_model.h deleted file mode 100644 index c2261c5..0000000 --- a/chrome/browser/extensions/extension_shelf_model.h +++ /dev/null @@ -1,168 +0,0 @@ -// Copyright (c) 2009 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. - -#ifndef CHROME_BROWSER_EXTENSIONS_EXTENSION_SHELF_MODEL_H_ -#define CHROME_BROWSER_EXTENSIONS_EXTENSION_SHELF_MODEL_H_ -#pragma once - -#include <vector> - -#include "base/basictypes.h" -#include "base/observer_list.h" -#include "chrome/browser/extensions/extension_host.h" -#include "chrome/common/extensions/extension.h" -#include "chrome/common/notification_observer.h" -#include "chrome/common/notification_registrar.h" - -class Browser; -class ExtensionPrefs; -class ExtensionShelfModelObserver; - -// The model representing the toolstrips on an ExtensionShelf. The order of -// the toolstrips is common across all of the models for a given Profile, -// but there are multiple models. Each model contains the hosts/views which -// are specific to a Browser. -class ExtensionShelfModel : public NotificationObserver { - public: - explicit ExtensionShelfModel(Browser* browser); - virtual ~ExtensionShelfModel(); - - struct ToolstripItem { - ExtensionHost* host; - Extension::ToolstripInfo info; - void* data; - int height; - GURL url; - }; - - typedef std::vector<ToolstripItem> ToolstripList; - typedef ToolstripList::iterator iterator; - - // Add and remove observers to changes within this ExtensionShelfModel. - void AddObserver(ExtensionShelfModelObserver* observer); - void RemoveObserver(ExtensionShelfModelObserver* observer); - - // The number of toolstrips in the model. - int count() const { return static_cast<int>(toolstrips_.size()); } - bool empty() const { return toolstrips_.empty(); } - - // Iterators for the toolstrips in the model. - iterator begin() { return toolstrips_.begin(); } - ExtensionShelfModel::iterator end() { return toolstrips_.end(); } - - // Add |toolstrip| to the end of the shelf. - void AppendToolstrip(const ToolstripItem& toolstrip); - - // Insert |toolstrip| and |data| at |index|. - void InsertToolstripAt(int index, const ToolstripItem& toolstrip); - - // Remove the toolstrip at |index|. - void RemoveToolstripAt(int index); - - // Move the toolstrip at |index| to |to_index|. - void MoveToolstripAt(int index, int to_index); - - // Lookup the index of |host|. Returns -1 if not present. - int IndexOfHost(ExtensionHost* host); - - // Return the toolstrip at |index|. - const ToolstripItem& ToolstripAt(int index); - - // Return the ToolstripItem associated with |host| or NULL if it's not - // present. - ToolstripList::iterator ToolstripForHost(ExtensionHost* host); - - // Set some arbitrary data associated with a particular toolstrip. - void SetToolstripDataAt(int index, void* data); - - // Update the ToolstripItem for |toolstrip| to set its |url| and |height| - // and then call ToolstripChanged for all observers. - // If |url| is empty, no navigation is requested. - void ExpandToolstrip(iterator toolstrip, const GURL& url, int height); - - // Update the ToolstripItem for |toolstrip| to set its |url| and its height - // to 0, and then call ToolstripChanged for all observers. - // If |url| is empty, no navigation is requested. - void CollapseToolstrip(iterator toolstrip, const GURL& url); - - // NotificationObserver - virtual void Observe(NotificationType type, - const NotificationSource& source, - const NotificationDetails& details); - - private: - // Add all of the toolstrips from |extension|. - void AddExtension(Extension* extension); - - // Add all of the toolstrips from each extension in |extensions|. - void AddExtensions(const ExtensionList* extensions); - - // Remove all of the toolstrips in |extension| from the shelf. - void RemoveExtension(Extension* extension); - - // Update prefs with the most recent changes. - void UpdatePrefs(); - - // Reloads order from prefs. - void SortToolstrips(); - - // The browser that this model is attached to. - Browser* browser_; - - // The preferences that this model uses. - ExtensionPrefs* prefs_; - - // Manages our notification registrations. - NotificationRegistrar registrar_; - - // The Toolstrips loaded in this model. The model owns these objects. - ToolstripList toolstrips_; - - // Our observers. - typedef ObserverList<ExtensionShelfModelObserver> - ExtensionShelfModelObservers; - ExtensionShelfModelObservers observers_; - - // Whether the model has received an EXTENSIONS_READY notification. - bool ready_; - - DISALLOW_COPY_AND_ASSIGN(ExtensionShelfModel); -}; - -// Objects implement this interface when they wish to be notified of changes to -// the ExtensionShelfModel. -// -// Register your ExtensionShelfModelObserver with the ExtensionShelfModel using -// Add/RemoveObserver methods. -class ExtensionShelfModelObserver { - public: - // A new toolstrip was inserted into ExtensionShelfModel at |index|. - virtual void ToolstripInsertedAt(ExtensionHost* toolstrip, int index) {} - - // The specified toolstrip is being removed and destroyed. - virtual void ToolstripRemovingAt(ExtensionHost* toolstrip, int index) {} - - // |toolstrip| moved from |from_index| to |to_index|. - virtual void ToolstripMoved(ExtensionHost* toolstrip, - int from_index, - int to_index) {} - - // The specified toolstrip changed in some way (currently only size changes) - virtual void ToolstripChanged(ExtensionShelfModel::iterator toolstrip) {} - - // There are no more toolstrips in the model. - virtual void ExtensionShelfEmpty() {} - - // The entire model may have changed. - virtual void ShelfModelReloaded() {} - - // The model is being destroyed. - virtual void ShelfModelDeleting() {} - - protected: - virtual ~ExtensionShelfModelObserver() {} -}; - - -#endif // CHROME_BROWSER_EXTENSIONS_EXTENSION_SHELF_MODEL_H_ diff --git a/chrome/browser/extensions/extension_shelf_model_browsertest.cc b/chrome/browser/extensions/extension_shelf_model_browsertest.cc deleted file mode 100644 index abb2a93..0000000 --- a/chrome/browser/extensions/extension_shelf_model_browsertest.cc +++ /dev/null @@ -1,97 +0,0 @@ -// Copyright (c) 2009 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. - -#include "chrome/browser/browser.h" -#include "chrome/browser/extensions/extension_browsertest.h" -#include "chrome/browser/extensions/extension_error_reporter.h" -#include "chrome/browser/extensions/extension_host.h" -#include "chrome/browser/extensions/extension_shelf_model.h" -#include "chrome/browser/extensions/extensions_service.h" -#include "chrome/browser/profile.h" -#include "chrome/browser/views/extensions/extension_shelf.h" -#include "chrome/browser/views/frame/browser_view.h" -#include "chrome/common/chrome_paths.h" -#include "chrome/common/chrome_switches.h" -#include "chrome/test/in_process_browser_test.h" - -namespace { - -// The extension we're using as our test case. -const char* kExtensionId = "behllobkkfkfnphdnhnkndlbkcpglgmj"; - -}; // namespace - - -// An InProcessBrowserTest for testing the ExtensionShelfModel. -// TODO(erikkay) It's unfortunate that this needs to be an in-proc browser test. -// It would be nice to refactor things so that ExtensionShelfModel, -// ExtensionHost and ExtensionsService could run without so much of the browser -// in place. -class ExtensionShelfModelTest : public ExtensionBrowserTest, - public ExtensionShelfModelObserver { - public: - virtual void SetUp() { - inserted_count_ = 0; - removed_count_ = 0; - moved_count_ = 0; - InProcessBrowserTest::SetUp(); - } - - virtual Browser* CreateBrowser(Profile* profile) { - Browser* b = InProcessBrowserTest::CreateBrowser(profile); - BrowserView* browser_view = static_cast<BrowserView*>(b->window()); - model_ = browser_view->extension_shelf()->model(); - model_->AddObserver(this); - return b; - } - - virtual void CleanUpOnMainThread() { - model_->RemoveObserver(this); - } - - virtual void ToolstripInsertedAt(ExtensionHost* toolstrip, int index) { - inserted_count_++; - } - - virtual void ToolstripRemovingAt(ExtensionHost* toolstrip, int index) { - removed_count_++; - } - - virtual void ToolstripMoved(ExtensionHost* toolstrip, - int from_index, - int to_index) { - moved_count_++; - } - - protected: - ExtensionShelfModel* model_; - - int inserted_count_; - int removed_count_; - int moved_count_; -}; - -IN_PROC_BROWSER_TEST_F(ExtensionShelfModelTest, Basic) { - ASSERT_TRUE(LoadExtension(test_data_dir_.AppendASCII("good") - .AppendASCII("Extensions") - .AppendASCII(kExtensionId) - .AppendASCII("1.0.0.0"))); - - // extension1 has two toolstrips - EXPECT_EQ(inserted_count_, 2); - ExtensionHost* one = model_->ToolstripAt(0).host; - ExtensionHost* two = model_->ToolstripAt(1).host; - EXPECT_EQ(one->GetURL().path(), "/toolstrip1.html"); - EXPECT_EQ(two->GetURL().path(), "/toolstrip2.html"); - - model_->MoveToolstripAt(0, 1); - EXPECT_EQ(two, model_->ToolstripAt(0).host); - EXPECT_EQ(one, model_->ToolstripAt(1).host); - EXPECT_EQ(moved_count_, 1); - - model_->RemoveToolstripAt(0); - EXPECT_EQ(one, model_->ToolstripAt(0).host); - EXPECT_EQ(1, model_->count()); - EXPECT_EQ(removed_count_, 1); -} diff --git a/chrome/browser/extensions/extension_toolstrip_api.cc b/chrome/browser/extensions/extension_toolstrip_api.cc deleted file mode 100644 index 26618e0..0000000 --- a/chrome/browser/extensions/extension_toolstrip_api.cc +++ /dev/null @@ -1,176 +0,0 @@ -// 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. - -#include "chrome/browser/extensions/extension_toolstrip_api.h" - -#include "base/json/json_writer.h" -#include "base/string_util.h" -#include "chrome/browser/browser.h" -#include "chrome/browser/extensions/extension_host.h" -#include "chrome/browser/extensions/extension_message_service.h" -#include "chrome/browser/extensions/extension_shelf_model.h" -#include "chrome/browser/extensions/extension_tabs_module_constants.h" -#include "chrome/browser/profile.h" -#include "chrome/browser/renderer_host/render_view_host.h" - -namespace extension_toolstrip_api_events { -const char kOnToolstripExpanded[] = "toolstrip.onExpanded.%d"; -const char kOnToolstripCollapsed[] = "toolstrip.onCollapsed.%d"; -}; // namespace extension_toolstrip_api_events - -namespace { -// Errors. -const char kNotAToolstripError[] = "This page is not a toolstrip."; -const char kAlreadyExpandedError[] = "This toolstrip is already expanded."; -const char kAlreadyCollapsedError[] = "This toolstrip is already collapsed."; -const char kInvalidURLError[] = "Invalid URL"; -const char kBadHeightError[] = "Bad height."; - -// TODO(erikkay) what are good values here? -const int kMinHeight = 50; -const int kMaxHeight = 1000; -}; // namespace - -namespace keys = extension_tabs_module_constants; -namespace events = extension_toolstrip_api_events; - -bool ToolstripFunction::RunImpl() { - ViewType::Type view_type = - dispatcher()->render_view_host()->delegate()->GetRenderViewType(); - if (view_type != ViewType::EXTENSION_TOOLSTRIP && - view_type != ViewType::EXTENSION_MOLE) { - error_ = kNotAToolstripError; - return false; - } - - Browser* browser = GetCurrentBrowser(); - if (!browser) { - error_ = kNotAToolstripError; - return false; - } - - model_ = browser->extension_shelf_model(); - if (!model_) { - error_ = kNotAToolstripError; - return false; - } - - // Since this is an EXTENSION_TOOLSTRIP or EXTESION_MOLE view type, we know - // the delegate must be an ExtensionHost. - ExtensionHost* host = - static_cast<ExtensionHost*>(dispatcher()->delegate()); - toolstrip_ = model_->ToolstripForHost(host); - if (toolstrip_ == model_->end()) { - error_ = kNotAToolstripError; - return false; - } - - return true; -} - -bool ToolstripExpandFunction::RunImpl() { - if (!ToolstripFunction::RunImpl()) - return false; - if (toolstrip_->height != 0) { - error_ = kAlreadyExpandedError; - return false; - } - - DictionaryValue* args; - EXTENSION_FUNCTION_VALIDATE(args_->GetDictionary(0, &args)); - - int height; - EXTENSION_FUNCTION_VALIDATE(args->GetInteger(keys::kHeightKey, - &height)); - EXTENSION_FUNCTION_VALIDATE(height >= 0); - if (height < kMinHeight || height > kMaxHeight) { - error_ = kBadHeightError; - return false; - } - - GURL url; - if (args->HasKey(keys::kUrlKey)) { - std::string url_string; - EXTENSION_FUNCTION_VALIDATE(args->GetString(keys::kUrlKey, - &url_string)); - url = dispatcher()->url().Resolve(url_string); - if (!url.is_valid()) { - error_ = kInvalidURLError; - return false; - } - } - - model_->ExpandToolstrip(toolstrip_, url, height); - return true; -} - -bool ToolstripCollapseFunction::RunImpl() { - if (!ToolstripFunction::RunImpl()) - return false; - - if (toolstrip_->height == 0) { - error_ = kAlreadyCollapsedError; - return false; - } - - GURL url; - if (HasOptionalArgument(0)) { - DictionaryValue* args; - EXTENSION_FUNCTION_VALIDATE(args_->GetDictionary(0, &args)); - - if (args->HasKey(keys::kUrlKey)) { - std::string url_string; - EXTENSION_FUNCTION_VALIDATE(args->GetString(keys::kUrlKey, - &url_string)); - url = dispatcher()->url().Resolve(url_string); - if (!url.is_valid()) { - error_ = kInvalidURLError; - return false; - } - } - } - - model_->CollapseToolstrip(toolstrip_, url); - return true; -} - -// static -void ToolstripEventRouter::DispatchEvent(Profile *profile, - int routing_id, - const char *event_name, - const Value& json) { - if (profile->GetExtensionMessageService()) { - std::string json_args; - base::JSONWriter::Write(&json, false, &json_args); - std::string full_event_name = StringPrintf(event_name, routing_id); - profile->GetExtensionMessageService()->DispatchEventToRenderers( - full_event_name, json_args, profile->IsOffTheRecord(), GURL()); - } -} - -// static -void ToolstripEventRouter::OnToolstripExpanded(Profile* profile, - int routing_id, - const GURL &url, - int height) { - ListValue args; - DictionaryValue* obj = new DictionaryValue(); - if (!url.is_empty()) - obj->SetString(keys::kUrlKey, url.spec()); - obj->SetInteger(keys::kHeightKey, height); - args.Append(obj); - DispatchEvent(profile, routing_id, events::kOnToolstripExpanded, args); -} - -// static -void ToolstripEventRouter::OnToolstripCollapsed(Profile* profile, - int routing_id, - const GURL &url) { - ListValue args; - DictionaryValue* obj = new DictionaryValue(); - if (!url.is_empty()) - obj->SetString(keys::kUrlKey, url.spec()); - args.Append(obj); - DispatchEvent(profile, routing_id, events::kOnToolstripCollapsed, args); -} diff --git a/chrome/browser/extensions/extension_toolstrip_api.h b/chrome/browser/extensions/extension_toolstrip_api.h deleted file mode 100644 index 07ba8f1..0000000 --- a/chrome/browser/extensions/extension_toolstrip_api.h +++ /dev/null @@ -1,61 +0,0 @@ -// Copyright (c) 2009 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. - -#ifndef CHROME_BROWSER_EXTENSIONS_EXTENSION_TOOLSTRIP_API_H_ -#define CHROME_BROWSER_EXTENSIONS_EXTENSION_TOOLSTRIP_API_H_ -#pragma once - -#include "chrome/browser/extensions/extension_function.h" -#include "chrome/browser/extensions/extension_shelf_model.h" - -class Profile; - -namespace extension_toolstrip_api_events { - extern const char kOnToolstripExpanded[]; - extern const char kOnToolstripCollapsed[]; -}; // namespace extension_toolstrip_api_events - -class ToolstripFunction : public SyncExtensionFunction { - protected: - virtual ~ToolstripFunction() {} - virtual bool RunImpl(); - - ExtensionShelfModel* model_; - ExtensionShelfModel::iterator toolstrip_; -}; - -class ToolstripExpandFunction : public ToolstripFunction { - ~ToolstripExpandFunction() {} - virtual bool RunImpl(); - DECLARE_EXTENSION_FUNCTION_NAME("toolstrip.expand") -}; - -class ToolstripCollapseFunction : public ToolstripFunction { - ~ToolstripCollapseFunction() {} - virtual bool RunImpl(); - DECLARE_EXTENSION_FUNCTION_NAME("toolstrip.collapse") -}; - -class ToolstripEventRouter { - public: - // Toolstrip events. - static void OnToolstripExpanded(Profile* profile, - int routing_id, - const GURL& url, - int height); - static void OnToolstripCollapsed(Profile* profile, - int routing_id, - const GURL& url); - - private: - // Helper to actually dispatch an event to extension listeners. - static void DispatchEvent(Profile* profile, - int routing_id, - const char* event_name, - const Value& json); - - DISALLOW_COPY_AND_ASSIGN(ToolstripEventRouter); -}; - -#endif // CHROME_BROWSER_EXTENSIONS_EXTENSION_TOOLSTRIP_API_H_ diff --git a/chrome/browser/extensions/extension_toolstrip_apitest.cc b/chrome/browser/extensions/extension_toolstrip_apitest.cc deleted file mode 100644 index 05955a0..0000000 --- a/chrome/browser/extensions/extension_toolstrip_apitest.cc +++ /dev/null @@ -1,11 +0,0 @@ -// Copyright (c) 2009 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. - -#include "chrome/browser/extensions/extension_apitest.h" - -// Disabled, http://crbug.com/30151 (Linux and ChromeOS), -// http://crbug.com/35034 (others). -IN_PROC_BROWSER_TEST_F(ExtensionApiTest, DISABLED_Toolstrip) { - ASSERT_TRUE(RunExtensionTest("toolstrip")) << message_; -} diff --git a/chrome/browser/extensions/extensions_service_unittest.cc b/chrome/browser/extensions/extensions_service_unittest.cc index c23f451..b3e2b0f 100644 --- a/chrome/browser/extensions/extensions_service_unittest.cc +++ b/chrome/browser/extensions/extensions_service_unittest.cc @@ -246,11 +246,6 @@ ExtensionsServiceTestBase::~ExtensionsServiceTestBase() { void ExtensionsServiceTestBase::InitializeExtensionsService( const FilePath& pref_file, const FilePath& extensions_install_dir) { - // Must setup the commandline here, since Extension caches the switch value - // when the prefs are registered. - CommandLine::ForCurrentProcess()->AppendSwitch( - switches::kEnableExtensionToolstrips); - ExtensionTestingProfile* profile = new ExtensionTestingProfile(); // Create a preference service that only contains user defined // preference values. @@ -685,8 +680,6 @@ TEST_F(ExtensionsServiceTest, LoadAllExtensionsFromDirectorySuccess) { Extension* extension = loaded_[0]; const UserScriptList& scripts = extension->content_scripts(); - const std::vector<Extension::ToolstripInfo>& toolstrips = - extension->toolstrips(); ASSERT_EQ(2u, scripts.size()); EXPECT_EQ(3u, scripts[0].url_patterns().size()); EXPECT_EQ("file://*", @@ -722,14 +715,6 @@ TEST_F(ExtensionsServiceTest, LoadAllExtensionsFromDirectorySuccess) { ASSERT_EQ(2u, permissions.size()); EXPECT_EQ("http://*.google.com/*", permissions[0].GetAsString()); EXPECT_EQ("https://*.google.com/*", permissions[1].GetAsString()); - ASSERT_EQ(2u, toolstrips.size()); - EXPECT_EQ(extension->GetResourceURL("toolstrip1.html"), - toolstrips[0].toolstrip); - EXPECT_EQ(extension->GetResourceURL("lorem_ipsum.html"), - toolstrips[0].mole); - EXPECT_EQ(200, toolstrips[0].mole_height); - EXPECT_EQ(extension->GetResourceURL("toolstrip2.html"), - toolstrips[1].toolstrip); EXPECT_EQ(std::string(good1), loaded_[1]->id()); EXPECT_EQ(std::string("My extension 2"), loaded_[1]->name()); diff --git a/chrome/browser/gtk/browser_window_gtk.cc b/chrome/browser/gtk/browser_window_gtk.cc index b268484..3d8e865 100644 --- a/chrome/browser/gtk/browser_window_gtk.cc +++ b/chrome/browser/gtk/browser_window_gtk.cc @@ -742,10 +742,6 @@ void BrowserWindowGtk::SelectedTabToolbarSizeChanged(bool is_animating) { // http://code.google.com/p/chromium/issues/detail?id=12291 } -void BrowserWindowGtk::SelectedTabExtensionShelfSizeChanged() { - NOTIMPLEMENTED(); -} - void BrowserWindowGtk::UpdateTitleBar() { string16 title = browser_->GetWindowTitleForCurrentTab(); gtk_window_set_title(window_, UTF16ToUTF8(title).c_str()); @@ -913,10 +909,6 @@ void BrowserWindowGtk::ToggleBookmarkBar() { bookmark_utils::ToggleWhenVisible(browser_->profile()); } -void BrowserWindowGtk::ToggleExtensionShelf() { - NOTIMPLEMENTED(); -} - views::Window* BrowserWindowGtk::ShowAboutChromeDialog() { ShowAboutDialogForProfile(window_, browser_->profile()); return NULL; diff --git a/chrome/browser/gtk/browser_window_gtk.h b/chrome/browser/gtk/browser_window_gtk.h index f2bc145..e02f4ab 100644 --- a/chrome/browser/gtk/browser_window_gtk.h +++ b/chrome/browser/gtk/browser_window_gtk.h @@ -60,7 +60,6 @@ class BrowserWindowGtk : public BrowserWindow, virtual BrowserWindowTesting* GetBrowserWindowTesting(); virtual StatusBubble* GetStatusBubble(); virtual void SelectedTabToolbarSizeChanged(bool is_animating); - virtual void SelectedTabExtensionShelfSizeChanged(); virtual void UpdateTitleBar(); virtual void ShelfVisibilityChanged(); virtual void UpdateDevTools(); @@ -88,7 +87,6 @@ class BrowserWindowGtk : public BrowserWindow, virtual void ConfirmAddSearchProvider(const TemplateURL* template_url, Profile* profile); virtual void ToggleBookmarkBar(); - virtual void ToggleExtensionShelf(); virtual views::Window* ShowAboutChromeDialog(); virtual void ShowUpdateChromeDialog(); virtual void ShowTaskManager(); diff --git a/chrome/browser/gtk/view_id_util.cc b/chrome/browser/gtk/view_id_util.cc index 684c669..2b8e396 100644 --- a/chrome/browser/gtk/view_id_util.cc +++ b/chrome/browser/gtk/view_id_util.cc @@ -107,9 +107,6 @@ const char* GetNameFromID(ViewID id) { case VIEW_ID_DEV_TOOLS_DOCKED: return "chrome-dev-tools-docked"; - case VIEW_ID_DEV_EXTENSION_SHELF: - return "chrome-extension-shelf"; - // These are never hit because the tab container uses the delegate to // set its ID. case VIEW_ID_TAB_CONTAINER: diff --git a/chrome/browser/gtk/view_id_util_browsertest.cc b/chrome/browser/gtk/view_id_util_browsertest.cc index b647900..b80fb02 100644 --- a/chrome/browser/gtk/view_id_util_browsertest.cc +++ b/chrome/browser/gtk/view_id_util_browsertest.cc @@ -33,10 +33,6 @@ IN_PROC_BROWSER_TEST_F(ViewIDTest, Basic) { browser()->ShowFindBar(); for (int i = VIEW_ID_TOOLBAR; i < VIEW_ID_PREDEFINED_COUNT; ++i) { - // Extension shelf is being removed, http://crbug.com/25106. - if (i == VIEW_ID_DEV_EXTENSION_SHELF) - continue; - // The following ids are used only in views implementation. if (i == VIEW_ID_CONTENTS_SPLIT || i == VIEW_ID_INFO_BAR_CONTAINER || diff --git a/chrome/browser/renderer_host/render_view_host.cc b/chrome/browser/renderer_host/render_view_host.cc index 644d116..fcdc75f 100644 --- a/chrome/browser/renderer_host/render_view_host.cc +++ b/chrome/browser/renderer_host/render_view_host.cc @@ -1911,10 +1911,6 @@ void RenderViewHost::BlockExtensionRequest(int request_id) { "Access to extension API denied."); } -void RenderViewHost::ViewTypeChanged(ViewType::Type type) { - Send(new ViewMsg_NotifyRenderViewType(routing_id(), type)); -} - void RenderViewHost::UpdateBrowserWindowId(int window_id) { Send(new ViewMsg_UpdateBrowserWindowId(routing_id(), window_id)); } diff --git a/chrome/browser/renderer_host/render_view_host.h b/chrome/browser/renderer_host/render_view_host.h index 6d770cd..736c08f 100644 --- a/chrome/browser/renderer_host/render_view_host.h +++ b/chrome/browser/renderer_host/render_view_host.h @@ -442,9 +442,6 @@ class RenderViewHost : public RenderWidgetHost { // permission. void BlockExtensionRequest(int request_id); - // Notifies the renderer that its view type has changed. - void ViewTypeChanged(ViewType::Type type); - // Tells the renderer which browser window it is being attached to. void UpdateBrowserWindowId(int window_id); diff --git a/chrome/browser/resources/extensions_toolstrip.css b/chrome/browser/resources/extensions_toolstrip.css deleted file mode 100644 index d4691fc..0000000 --- a/chrome/browser/resources/extensions_toolstrip.css +++ /dev/null @@ -1,8 +0,0 @@ -/** - * The following style rules affect toolstrips and moles and are affected by - * theme changes. - */ - -body { - color: $TEXT_COLOR$; -} diff --git a/chrome/browser/tab_contents/navigation_controller.cc b/chrome/browser/tab_contents/navigation_controller.cc index fcc1e7a..1b2f117 100644 --- a/chrome/browser/tab_contents/navigation_controller.cc +++ b/chrome/browser/tab_contents/navigation_controller.cc @@ -36,8 +36,7 @@ namespace { const int kInvalidateAllButShelves = - 0xFFFFFFFF & ~(TabContents::INVALIDATE_BOOKMARK_BAR | - TabContents::INVALIDATE_EXTENSION_SHELF); + 0xFFFFFFFF & ~TabContents::INVALIDATE_BOOKMARK_BAR; // Invoked when entries have been pruned, or removed. For example, if the // current entries are [google, digg, yahoo], with the current entry google, diff --git a/chrome/browser/tab_contents/tab_contents.cc b/chrome/browser/tab_contents/tab_contents.cc index 42f63db..1d2e028 100644 --- a/chrome/browser/tab_contents/tab_contents.cc +++ b/chrome/browser/tab_contents/tab_contents.cc @@ -1176,27 +1176,6 @@ bool TabContents::ShouldShowBookmarkBar() { return false; // Default. } -bool TabContents::IsExtensionShelfAlwaysVisible() { - // See GetDOMUIForCurrentState() comment for more info. This case is very - // similar, but for non-first loads, we want to use the committed entry. This - // is so the bookmarks bar disappears at the same time the page does. - if (controller_.GetLastCommittedEntry()) { - // Not the first load, always use the committed DOM UI. - if (render_manager_.dom_ui()) - return render_manager_.dom_ui()->force_extension_shelf_visible(); - return false; // Default. - } - - // When it's the first load, we know either the pending one or the committed - // one will have the DOM UI in it (see GetDOMUIForCurrentState), and only one - // of them will be valid, so we can just check both. - if (render_manager_.pending_dom_ui()) - return render_manager_.pending_dom_ui()->force_extension_shelf_visible(); - if (render_manager_.dom_ui()) - return render_manager_.dom_ui()->force_extension_shelf_visible(); - return false; // Default. -} - void TabContents::ToolbarSizeChanged(bool is_animating) { TabContentsDelegate* d = delegate(); if (d) @@ -2381,14 +2360,11 @@ void TabContents::DidNavigate(RenderViewHost* rvh, if (PageTransition::IsMainFrame(params.transition)) { bool was_bookmark_bar_visible = ShouldShowBookmarkBar(); - bool was_extension_shelf_visible = IsExtensionShelfAlwaysVisible(); render_manager_.DidNavigateMainFrame(rvh); if (was_bookmark_bar_visible != ShouldShowBookmarkBar()) extra_invalidate_flags |= INVALIDATE_BOOKMARK_BAR; - if (was_extension_shelf_visible != IsExtensionShelfAlwaysVisible()) - extra_invalidate_flags |= INVALIDATE_EXTENSION_SHELF; } // Update the site of the SiteInstance if it doesn't have one yet. diff --git a/chrome/browser/tab_contents/tab_contents.h b/chrome/browser/tab_contents/tab_contents.h index cba7367..49f89e2 100644 --- a/chrome/browser/tab_contents/tab_contents.h +++ b/chrome/browser/tab_contents/tab_contents.h @@ -111,10 +111,7 @@ class TabContents : public PageNavigator, INVALIDATE_PAGE_ACTIONS = 1 << 3, // Page action icons have changed. INVALIDATE_BOOKMARK_BAR = 1 << 4, // State of ShouldShowBookmarkBar // changed. - INVALIDATE_EXTENSION_SHELF = 1 << 5, // State of - // IsExtensionShelfAlwaysVisible - // changed. - INVALIDATE_TITLE = 1 << 6, // The title changed. + INVALIDATE_TITLE = 1 << 5, // The title changed. }; // |base_tab_contents| is used if we want to size the new tab contents view @@ -466,9 +463,6 @@ class TabContents : public PageNavigator, // Returns true if a Bookmark Bar should be shown for this tab. virtual bool ShouldShowBookmarkBar(); - // Returns whether the extension shelf should be visible. - virtual bool IsExtensionShelfAlwaysVisible(); - // Notifies the delegate that a download is about to be started. // This notification is fired before a local temporary file has been created. bool CanDownload(int request_id); diff --git a/chrome/browser/task_manager_browsertest.cc b/chrome/browser/task_manager_browsertest.cc index d546fe5..a8eaa2e 100644 --- a/chrome/browser/task_manager_browsertest.cc +++ b/chrome/browser/task_manager_browsertest.cc @@ -128,16 +128,11 @@ IN_PROC_BROWSER_TEST_F(TaskManagerBrowserTest, FLAKY_NoticeExtensionChanges) { // Browser and the New Tab Page. EXPECT_EQ(2, model()->ResourceCount()); - // Loading an extension should result in a new resource being - // created for it. - ASSERT_TRUE(LoadExtension( - test_data_dir_.AppendASCII("common").AppendASCII("one_in_shelf"))); - WaitForResourceChange(3); - - // Make sure we also recognize extensions with just background pages. + // Loading an extension with a background page should result in a new + // resource being created for it. ASSERT_TRUE(LoadExtension( test_data_dir_.AppendASCII("common").AppendASCII("background_page"))); - WaitForResourceChange(4); + WaitForResourceChange(3); } // Times out on Vista; disabled to keep tests fast. http://crbug.com/44991 diff --git a/chrome/browser/view_ids.h b/chrome/browser/view_ids.h index 5adf18a..f345b3f 100644 --- a/chrome/browser/view_ids.h +++ b/chrome/browser/view_ids.h @@ -62,9 +62,6 @@ enum ViewID { // Docked dev tools. VIEW_ID_DEV_TOOLS_DOCKED, - // Bottom extension shelf. - VIEW_ID_DEV_EXTENSION_SHELF, - // The contents split. VIEW_ID_CONTENTS_SPLIT, diff --git a/chrome/browser/views/extensions/extension_shelf.cc b/chrome/browser/views/extensions/extension_shelf.cc deleted file mode 100644 index 000c988..0000000 --- a/chrome/browser/views/extensions/extension_shelf.cc +++ /dev/null @@ -1,1108 +0,0 @@ -// 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. - -#include "chrome/browser/views/extensions/extension_shelf.h" - -#include <algorithm> - -#include "app/resource_bundle.h" -#include "base/logging.h" -#include "base/message_loop.h" -#include "base/stl_util-inl.h" -#include "base/string_util.h" -#include "base/utf_string_conversions.h" -#include "chrome/browser/browser.h" -#include "chrome/browser/browser_theme_provider.h" -#include "chrome/browser/extensions/extension_host.h" -#include "chrome/browser/extensions/extension_process_manager.h" -#include "chrome/browser/extensions/extensions_service.h" -#include "chrome/browser/profile.h" -#include "chrome/browser/tab_contents/tab_contents.h" -#include "chrome/browser/views/extensions/extension_view.h" -#include "chrome/browser/view_ids.h" -#include "chrome/common/chrome_switches.h" -#include "chrome/common/extensions/extension.h" -#include "chrome/common/notification_service.h" -#include "chrome/common/pref_names.h" -#include "gfx/canvas_skia.h" -#include "views/controls/label.h" -#include "views/screen.h" -#include "views/widget/root_view.h" - -namespace { - -// This is the slight padding that is there around the edge of the browser. This -// has been determined empirically. -// TODO(sidchat): Compute this value from the root view of the extension shelf. -static const int kExtensionShelfPaddingOnLeft = 4; - -// Margins around the content. -static const int kTopMarginWhenExtensionsOnTop = 1; -static const int kTopMarginWhenExtensionsOnBottom = 2; -static const int kBottomMargin = 2; -static const int kLeftMargin = 0; -static const int kRightMargin = 0; - -// Padding on left and right side of an extension toolstrip. -static const int kToolstripPadding = 2; - -// Width of the toolstrip divider. -static const int kToolstripDividerWidth = 2; - -// Preferred height of the ExtensionShelf. -static const int kShelfHeight = 29; - -// Preferred height of the Extension shelf when only shown on the new tab page. -const int kNewtabShelfHeight = 58; - -// How inset the extension shelf is when displayed on the new tab page. This is -// in addition to the margins above. -static const int kNewtabHorizontalPadding = 8; -static const int kNewtabVerticalPadding = 12; - -// We need an extra margin to the left of all the toolstrips in detached mode, -// so that the first toolstrip doesn't look so squished against the rounded -// corners of the extension shelf. -static const int kNewtabExtraHorMargin = 2; -static const int kNewtabExtraVerMargin = 2; - -// Padding for the title inside the handle. -static const int kHandlePadding = 4; - -// Inset for the extension view when displayed either dragging or expanded. -static const int kWindowInset = 1; - -// Delays for showing and hiding the shelf handle. -static const int kShowDelayMs = 500; -static const int kHideDelayMs = 300; - -} // namespace - - -// A view that holds the place for a toolstrip in the shelf while the toolstrip -// is being dragged or moved. -// TODO(erikkay) this should draw a dimmed out version of the toolstrip. -class ExtensionShelf::PlaceholderView : public views::View { - public: - PlaceholderView() {} - - void SetWidth(int width) { - SetBounds(x(), y(), width, height()); - PreferredSizeChanged(); - } - - // ExtensionShelf resizes its views to their preferred size at layout, - // so just always prefer the current size. - gfx::Size GetPreferredSize() { return size(); } - - private: - DISALLOW_COPY_AND_ASSIGN(PlaceholderView); -}; - -// A wrapper class for the ExtensionHost displayed as a toolstrip. -// The class itself also acts as the View for the handle of the toolstrip -// it represents. -class ExtensionShelf::Toolstrip : public views::View, - public BrowserBubble::Delegate, - public AnimationDelegate { - public: - Toolstrip(ExtensionShelf* shelf, ExtensionHost* host, - const Extension::ToolstripInfo& info); - virtual ~Toolstrip(); - - // Convenience to calculate just the size of the handle. - gfx::Size GetHandlePreferredSize(); - - // View methods: - virtual void Paint(gfx::Canvas* canvas); - virtual gfx::Size GetPreferredSize(); - virtual void Layout(); - virtual void OnMouseEntered(const views::MouseEvent& event); - virtual void OnMouseExited(const views::MouseEvent& event); - virtual bool OnMousePressed(const views::MouseEvent& event); - virtual bool OnMouseDragged(const views::MouseEvent& event); - virtual void OnMouseReleased(const views::MouseEvent& event, bool canceled); - virtual bool IsFocusable() const { return true; } - virtual void ChildPreferredSizeChanged(View* child); - - // Adjust the size and position of the window/handle. - void LayoutWindow(); - - // Is the toolstrip window visible (not necessarily the handle). - bool window_visible() { return (window_.get() && window_->visible()); } - - // Is the handle for this toolstrip currently visible. - bool handle_visible() { return (window_visible() && handle_visible_); } - - // Is the toolstrip opened in expanded mode. - bool expanded() { return expanded_; } - - // Is the toolstrip being dragged. - bool dragging() { return dragging_; } - - // Accessors for the host and its view. - ExtensionHost* host() const { return host_; } - ExtensionView* view() const { return host_->view(); } - - // The view that's currently displayed in the shelf. This could be - // either the ExtensionView or |placeholder_view_| depending on the - // current state. - View* GetShelfView() const { - if (placeholder_view_) - return placeholder_view_; - return view(); - } - - // Detaching the toolstrip from the shelf means that the ExtensionView is - // displayed inside of the BrowserBubble rather than the shelf. This may - // still visually appear to be part of the shelf (expanded) or completely - // separate (dragging). - // If |browser| is true, it also will detach/attach to the browser window. - void DetachFromShelf(bool browser); - void AttachToShelf(bool browser); - - // Show / Hide the shelf handle. - void ShowShelfHandle(); - void DoShowShelfHandle(); - void HideShelfHandle(int delay_ms); - void DoHideShelfHandle(); - void StopHandleTimer(); - void HideWindow(); - void ShowWindow(); - - // Expand / Collapse - void Expand(int height, const GURL& url); - void Collapse(const GURL& url); - - // BrowserBubble::Delegate - virtual void BubbleBrowserWindowMoved(BrowserBubble* bubble); - virtual void BubbleBrowserWindowClosing(BrowserBubble* bubble); - - // AnimationDelegate - virtual void AnimationProgressed(const Animation* animation); - virtual void AnimationEnded(const Animation* animation); - - private: - // The actual renderer that this toolstrip contains. - ExtensionHost* host_; - - // Manifest definition of this toolstrip. - Extension::ToolstripInfo info_; - - // A window that can be logically attached to the browser window. This is - // used for two purposes: a handle that sits above the toolstrip when it's - // collapsed and not dragging, and as a container for the toolstrip when it's - // dragging or expanded. - scoped_ptr<BrowserBubble> window_; - - // Used for drawing the name of the extension in the handle. - scoped_ptr<views::Label> title_; - - // Pointer back to the containing shelf. - ExtensionShelf* shelf_; - - // When dragging, a placeholder view is put into the shelf to hold space - // for the ExtensionView. This view is parent owned when it's in the view - // hierarchy, so there's no ownership issues here. - PlaceholderView* placeholder_view_; - - // Current state of the toolstrip, currently can't both be expanded and - // dragging. - // TODO(erikkay) Support dragging while expanded. - bool dragging_; - bool expanded_; - bool handle_visible_; - - // The target expanded height of the toolstrip (used for animation). - int expanded_height_; - - // If dragging, where did the drag start from. - gfx::Point initial_drag_location_; - - // We have to remember the initial drag point in screen coordinates, because - // later, when the toolstrip is being dragged around, there is no good way of - // computing the screen coordinates given the initial drag view coordinates. - gfx::Point initial_drag_screen_point_; - - // Timers for tracking mouse hovering. - ScopedRunnableMethodFactory<ExtensionShelf::Toolstrip> timer_factory_; - - // Animate opening and closing the mole. - scoped_ptr<SlideAnimation> mole_animation_; - - DISALLOW_COPY_AND_ASSIGN(Toolstrip); -}; - -ExtensionShelf::Toolstrip::Toolstrip(ExtensionShelf* shelf, - ExtensionHost* host, - const Extension::ToolstripInfo& info) - : host_(host), - info_(info), - shelf_(shelf), - placeholder_view_(NULL), - dragging_(false), - expanded_(false), - handle_visible_(false), - expanded_height_(0), - ALLOW_THIS_IN_INITIALIZER_LIST(timer_factory_(this)) { - DCHECK(host->view()); - // We're owned by shelf_, not the bubble that we get inserted in and out of. - set_parent_owned(false); - - mole_animation_.reset(new SlideAnimation(this)); - - std::wstring name = UTF8ToWide(host_->extension()->name()); - // |title_| isn't actually put in the view hierarchy. We just use it - // to draw in place. The reason for this is so that we can properly handle - // the various mouse events necessary for hovering and dragging. - ResourceBundle& rb = ResourceBundle::GetSharedInstance(); - title_.reset(new views::Label(name, rb.GetFont(ResourceBundle::BaseFont))); - title_->SetBounds(kHandlePadding, kHandlePadding, 100, 100); - title_->SizeToPreferredSize(); - - SizeToPreferredSize(); -} - -ExtensionShelf::Toolstrip::~Toolstrip() { - if (window_.get() && window_->attached()) - window_->DetachFromBrowser(); -} - -void ExtensionShelf::Toolstrip::Paint(gfx::Canvas* canvas) { - // Paint the background. - SkColor theme_toolbar_color = - shelf_->GetThemeProvider()->GetColor(BrowserThemeProvider::COLOR_TOOLBAR); - canvas->FillRectInt(theme_toolbar_color, 0, 0, width(), height()); - - // Paints the handle for the toolstrip (only called on mouse-hover). - SkColor border_color = ResourceBundle::toolbar_separator_color; - canvas->FillRectInt(border_color, 0, 0, width(), 1); - canvas->FillRectInt(border_color, 0, 0, 1, height() - 1); - canvas->FillRectInt(border_color, width() - 1, 0, 1, height() - 1); - int ext_width = view()->width() + kToolstripPadding + - kToolstripDividerWidth; - if (ext_width < width()) { - canvas->FillRectInt(border_color, ext_width, height() - 1, - width() - ext_width, 1); - } - - if (handle_visible_) { - // Draw the title using a Label as a stamp. - // See constructor for comment about this. - title_->ProcessPaint(canvas); - - if (dragging_) { - // When we're dragging, draw the bottom border. - canvas->FillRectInt(border_color, 0, height() - 1, width(), 1); - } - } -} - -gfx::Size ExtensionShelf::Toolstrip::GetHandlePreferredSize() { - gfx::Size sz; - if (handle_visible_) { - sz = title_->GetPreferredSize(); - sz.set_width(std::max(view()->width(), sz.width())); - sz.Enlarge(2 + kHandlePadding * 2, kHandlePadding * 2); - } - return sz; -} - -gfx::Size ExtensionShelf::Toolstrip::GetPreferredSize() { - gfx::Size sz; - if (handle_visible_) - sz = GetHandlePreferredSize(); - if (view()->GetParent() == this) { - gfx::Size extension_size = view()->GetPreferredSize(); - sz.Enlarge(0, extension_size.height()); - sz.set_width(extension_size.width()); - } - - // The view is inset slightly when displayed in the window. - sz.Enlarge(kWindowInset * 2, kWindowInset * 2); - return sz; -} - -void ExtensionShelf::Toolstrip::Layout() { - if (view()->GetParent() == this) { - int view_y = kWindowInset; - if (handle_visible_) - view_y += GetHandlePreferredSize().height(); - view()->SetBounds(kWindowInset, view_y, view()->width(), view()->height()); - } -} - -void ExtensionShelf::Toolstrip::OnMouseEntered(const views::MouseEvent& event) { - if (dragging_) - return; - ShowShelfHandle(); -} - -void ExtensionShelf::Toolstrip::OnMouseExited(const views::MouseEvent& event) { - if (dragging_) - return; - HideShelfHandle(kHideDelayMs); -} - -bool ExtensionShelf::Toolstrip::OnMousePressed(const views::MouseEvent& event) { - initial_drag_location_ = event.location(); - initial_drag_screen_point_ = views::Screen::GetCursorScreenPoint(); - return true; -} - -bool ExtensionShelf::Toolstrip::OnMouseDragged(const views::MouseEvent& event) { - if (expanded_) { - // Do nothing for now. - } else if (!dragging_) { - int y_delta = abs(initial_drag_location_.y() - event.location().y()); - int x_delta = abs(initial_drag_location_.x() - event.location().x()); - if (y_delta > GetVerticalDragThreshold() || - x_delta > GetHorizontalDragThreshold()) { - dragging_ = true; - StopHandleTimer(); - DetachFromShelf(true); - } - } else { - // When freely dragging a window, you can really only trust the - // actual screen point. Local coordinate conversions don't work. - gfx::Point screen = views::Screen::GetCursorScreenPoint(); - - // However, the handle is actually a child of the browser window - // so we need to convert it back to local coordinates. - gfx::Point origin(0, 0); - views::View::ConvertPointToScreen(shelf_->GetRootView(), &origin); - int screen_x = screen.x() - initial_drag_location_.x() - origin.x(); - - // Restrict the horizontal and vertical motions of the toolstrip so that it - // cannot be dragged out of the extension shelf. If the extension shelf is - // on the top along with the bookmark bar, the toolstrip cannot be dragged - // into the space allocated for bookmarks. The toolstrip cannot be dragged - // out of the browser window. - if (screen_x < kExtensionShelfPaddingOnLeft) { - screen_x = kExtensionShelfPaddingOnLeft; - } else if (screen_x > shelf_->width() - width() + - kExtensionShelfPaddingOnLeft) { - screen_x = shelf_->width() - width() + kExtensionShelfPaddingOnLeft; - } - screen.set_x(screen_x); - screen.set_y(initial_drag_screen_point_.y() - origin.y() - - initial_drag_location_.y()); - - // TODO(erikkay) as this gets dragged around, update the placeholder view - // on the shelf to show where it will get dropped to. - window_->MoveTo(screen.x(), screen.y()); - } - return true; -} - -void ExtensionShelf::Toolstrip::OnMouseReleased(const views::MouseEvent& event, - bool canceled) { - StopHandleTimer(); - if (dragging_) { - // Drop the toolstrip roughly where it is now. - views::View::OnMouseReleased(event, canceled); - dragging_ = false; - // |this| and |shelf_| are in different view hierarchies, so we need to - // convert to screen coordinates and back again to map locations. - gfx::Point loc = event.location(); - View::ConvertPointToScreen(this, &loc); - View::ConvertPointToView(NULL, shelf_, &loc); - shelf_->DropExtension(this, loc, canceled); - AttachToShelf(true); - } else if (!canceled) { - // Toggle mole to either expanded or collapsed. - // TODO(erikkay) If there's no valid URL in the manifest, should we - // post an event to the toolstrip in this case? - if (expanded_) { - if (info_.toolstrip.is_valid()) - shelf_->CollapseToolstrip(host_, info_.toolstrip); - } else { - if (info_.mole.is_valid()) - shelf_->ExpandToolstrip(host_, info_.mole, info_.mole_height); - } - } -} - -void ExtensionShelf::Toolstrip::LayoutWindow() { - if (!window_visible() && !handle_visible_ && !expanded_) - return; - - if (!window_.get()) { - window_.reset(new BrowserBubble(this, shelf_->GetWidget(), - gfx::Point(0, 0), - false)); // Do not add a drop-shadow. - window_->set_delegate(this); - } - - gfx::Size window_size = GetPreferredSize(); - if (mole_animation_->is_animating()) { - // We only want to animate the body of the mole window. When we're - // expanding, this is everything except for the handle. When we're - // collapsing, this is everything except for the handle and the toolstrip. - // We subtract this amount from the target height, figure out the step in - // the animation from the rest, and then add it back in. - int window_offset = shelf_->height(); - if (!mole_animation_->IsShowing()) - window_offset += GetPreferredSize().height(); - else - window_offset += GetHandlePreferredSize().height(); - int h = expanded_height_ - window_offset; - window_size.set_height(window_offset + - static_cast<int>(h * mole_animation_->GetCurrentValue())); - } else if (!expanded_ && !dragging_) { - window_size.set_height(GetHandlePreferredSize().height()); - } - - // Now figure out where to place the window on the screen. Since it's a top- - // level widget, we need to do some coordinate conversion to get this right. - gfx::Point origin(-kToolstripPadding, 0); - if (expanded_ || mole_animation_->is_animating()) { - origin.set_y(GetShelfView()->height() - window_size.height()); - views::View::ConvertPointToView(GetShelfView(), shelf_->GetRootView(), - &origin); - } else { - origin.set_y(-(window_size.height() + kToolstripPadding - 1)); - views::View::ConvertPointToWidget(view(), &origin); - } - SetBounds(0, 0, window_size.width(), window_size.height()); - window_->SetBounds(origin.x(), origin.y(), - window_size.width(), window_size.height()); -} - -void ExtensionShelf::Toolstrip::ChildPreferredSizeChanged(View* child) { - if (child == view()) { - child->SizeToPreferredSize(); - Layout(); - if (window_visible()) - LayoutWindow(); - if (expanded_) { - placeholder_view_->SetWidth(child->width()); - shelf_->Layout(); - } - } -} - -void ExtensionShelf::Toolstrip::BubbleBrowserWindowMoved( - BrowserBubble* bubble) { - if (!expanded_) - HideWindow(); -} - -void ExtensionShelf::Toolstrip::BubbleBrowserWindowClosing( - BrowserBubble* bubble) { - HideWindow(); -} - -void ExtensionShelf::Toolstrip::AnimationProgressed( - const Animation* animation) { - LayoutWindow(); -} - -void ExtensionShelf::Toolstrip::AnimationEnded(const Animation* animation) { - if (window_visible()) - LayoutWindow(); - if (!expanded_) { - AttachToShelf(false); - HideShelfHandle(kHideDelayMs); - } -} - -void ExtensionShelf::Toolstrip::DetachFromShelf(bool browserDetach) { - DCHECK(window_.get()); - DCHECK(!placeholder_view_); - if (browserDetach && window_->attached()) - window_->DetachFromBrowser(); - - // Construct a placeholder view to replace the view. - placeholder_view_ = new PlaceholderView(); - placeholder_view_->SetBounds(view()->bounds()); - shelf_->AddChildView(placeholder_view_); - - AddChildView(view()); - SizeToPreferredSize(); - window_->ResizeToView(); - Layout(); -} - -void ExtensionShelf::Toolstrip::AttachToShelf(bool browserAttach) { - DCHECK(window_.get()); - DCHECK(placeholder_view_); - if (browserAttach && !window_->attached()) - window_->AttachToBrowser(); - - // Move the view back into the shelf and remove the old placeholder. - shelf_->AddChildView(view()); - - // The size of the view may have changed, so just set the position. - view()->SetX(placeholder_view_->x()); - view()->SetY(placeholder_view_->y()); - - // Remove the old placeholder. - shelf_->RemoveChildView(placeholder_view_); - delete placeholder_view_; - placeholder_view_ = NULL; - - SizeToPreferredSize(); - Layout(); - shelf_->Layout(); -} - -void ExtensionShelf::Toolstrip::DoShowShelfHandle() { - if (!handle_visible()) { - handle_visible_ = true; - - // Make sure the text color for the title matches the theme colors. - title_->SetColor( - shelf_->GetThemeProvider()->GetColor( - BrowserThemeProvider::COLOR_BOOKMARK_TEXT)); - - ShowWindow(); - } -} - -void ExtensionShelf::Toolstrip::HideWindow() { - if (!window_visible()) - return; - handle_visible_ = false; - window_->Hide(); - if (expanded_) { - if (info_.toolstrip.is_valid()) - shelf_->CollapseToolstrip(host_, info_.toolstrip); - else - shelf_->CollapseToolstrip(host_, GURL()); - } - if (window_->attached()) - window_->DetachFromBrowser(); - window_.reset(NULL); - shelf_->Layout(); -} - -void ExtensionShelf::Toolstrip::ShowWindow() { - DCHECK(handle_visible_ || expanded_); - - LayoutWindow(); - if (!window_visible()) - window_->Show(false); // |false| means show, but don't activate. -} - -void ExtensionShelf::Toolstrip::DoHideShelfHandle() { - if (!handle_visible()) - return; - handle_visible_ = false; - if (expanded_) { - LayoutWindow(); - Layout(); - } else { - HideWindow(); - } -} - -void ExtensionShelf::Toolstrip::StopHandleTimer() { - if (!timer_factory_.empty()) - timer_factory_.RevokeAll(); -} - -void ExtensionShelf::Toolstrip::Expand(int height, const GURL& url) { - DCHECK(!expanded_); - - expanded_ = true; - ShowWindow(); - - bool navigate = (!url.is_empty() && url != host_->GetURL()); - if (navigate) - host_->NavigateToURL(url); - - StopHandleTimer(); - DetachFromShelf(false); - - mole_animation_->Show(); - - gfx::Size extension_size = view()->GetPreferredSize(); - extension_size.set_height(height); - view()->SetPreferredSize(extension_size); - expanded_height_ = GetPreferredSize().height(); - - // This is to prevent flickering as the page loads and lays out. - // Once the navigation is finished, ExtensionView will wind up setting - // visibility to true. - if (navigate) - view()->SetVisible(false); -} - -void ExtensionShelf::Toolstrip::Collapse(const GURL& url) { - DCHECK(expanded_); - expanded_ = false; - - if (window_visible()) - mole_animation_->Hide(); - - gfx::Size extension_size = view()->GetPreferredSize(); - extension_size.set_height( - kShelfHeight - (shelf_->top_margin() + kBottomMargin)); - view()->SetPreferredSize(extension_size); - - if (!url.is_empty() && url != host_->GetURL()) { - host_->NavigateToURL(url); - - // This is to prevent flickering as the page loads and lays out. - // Once the navigation is finished, ExtensionView will wind up setting - // visibility to true. - view()->SetVisible(false); - } - - if (!window_visible()) - AnimationEnded(NULL); -} - -void ExtensionShelf::Toolstrip::ShowShelfHandle() { - StopHandleTimer(); - if (handle_visible()) - return; - MessageLoop::current()->PostDelayedTask(FROM_HERE, - timer_factory_.NewRunnableMethod( - &ExtensionShelf::Toolstrip::DoShowShelfHandle), - kShowDelayMs); -} - -void ExtensionShelf::Toolstrip::HideShelfHandle(int delay_ms) { - StopHandleTimer(); - if (!handle_visible() || dragging_ || mole_animation_->is_animating()) - return; - if (delay_ms) { - MessageLoop::current()->PostDelayedTask(FROM_HERE, - timer_factory_.NewRunnableMethod( - &ExtensionShelf::Toolstrip::DoHideShelfHandle), - delay_ms); - } else { - DoHideShelfHandle(); - } -} - -//////////////////////////////////////////////////////////////////////////////// - -ExtensionShelf::ExtensionShelf(Browser* browser) - : background_needs_repaint_(true), - browser_(browser), - model_(browser->extension_shelf_model()), - fullscreen_(false) { - SetID(VIEW_ID_DEV_EXTENSION_SHELF); - - top_margin_ = kTopMarginWhenExtensionsOnBottom; - - model_->AddObserver(this); - LoadFromModel(); - EnableCanvasFlippingForRTLUI(true); - registrar_.Add(this, - NotificationType::EXTENSION_SHELF_VISIBILITY_PREF_CHANGED, - NotificationService::AllSources()); - - size_animation_.reset(new SlideAnimation(this)); - if (IsAlwaysShown()) - size_animation_->Reset(1); - else - size_animation_->Reset(0); -} - -ExtensionShelf::~ExtensionShelf() { - if (model_) { - int count = model_->count(); - for (int i = 0; i < count; ++i) { - delete ToolstripAtIndex(i); - model_->SetToolstripDataAt(i, NULL); - } - model_->RemoveObserver(this); - } -} - -void ExtensionShelf::PaintChildren(gfx::Canvas* canvas) { - InitBackground(canvas); - - int max_x = width(); - if (IsDetached()) - max_x -= 2 * kNewtabHorizontalPadding; - - // Draw vertical dividers between Toolstrip items in the Extension shelf. - int count = GetChildViewCount(); - for (int i = 0; i < count; ++i) { - int right = GetChildViewAt(i)->bounds().right() + kToolstripPadding; - if (right >= max_x) - break; - int vertical_padding = IsDetached() ? (height() - kShelfHeight) / 2 : 1; - - DetachableToolbarView::PaintVerticalDivider( - canvas, right, height(), vertical_padding, - DetachableToolbarView::kEdgeDividerColor, - DetachableToolbarView::kMiddleDividerColor, - GetThemeProvider()->GetColor(BrowserThemeProvider::COLOR_TOOLBAR)); - } -} - -// static -void ExtensionShelf::ToggleWhenExtensionShelfVisible(Profile* profile) { - PrefService* prefs = profile->GetPrefs(); - const bool always_show = !prefs->GetBoolean(prefs::kShowExtensionShelf); - - // The user changed when the Extension Shelf is shown, update the - // preferences. - prefs->SetBoolean(prefs::kShowExtensionShelf, always_show); - prefs->ScheduleSavePersistentPrefs(); - - // And notify the notification service. - Source<Profile> source(profile); - NotificationService::current()->Notify( - NotificationType::EXTENSION_SHELF_VISIBILITY_PREF_CHANGED, - source, - NotificationService::NoDetails()); -} - -gfx::Size ExtensionShelf::GetPreferredSize() { - return LayoutItems(true); -} - -void ExtensionShelf::ChildPreferredSizeChanged(View* child) { - PreferredSizeChanged(); -} - -void ExtensionShelf::Layout() { - LayoutItems(false); -} - -void ExtensionShelf::OnMouseEntered(const views::MouseEvent& event) { -} - -void ExtensionShelf::OnMouseExited(const views::MouseEvent& event) { -} - -bool ExtensionShelf::GetAccessibleRole(AccessibilityTypes::Role* role) { - DCHECK(role); - - *role = AccessibilityTypes::ROLE_TOOLBAR; - return true; -} - -void ExtensionShelf::OnThemeChanged() { - // Refresh the CSS to update toolstrip text colors from theme. - int count = model_->count(); - for (int i = 0; i < count; ++i) - ToolstripAtIndex(i)->view()->host()->InsertThemedToolstripCSS(); - - Layout(); -} - -void ExtensionShelf::ToolstripInsertedAt(ExtensionHost* host, - int index) { - model_->SetToolstripDataAt(index, - new Toolstrip(this, host, model_->ToolstripAt(index).info)); - - bool had_views = GetChildViewCount() > 0; - ExtensionView* view = host->view(); - AddChildView(view); - view->SetContainer(this); - if (!had_views) - PreferredSizeChanged(); - Layout(); -} - -void ExtensionShelf::ToolstripRemovingAt(ExtensionHost* host, int index) { - // Delete the Toolstrip view and remove it from the model. - Toolstrip* toolstrip = ToolstripAtIndex(index); - View* view = toolstrip->GetShelfView(); - RemoveChildView(view); - delete toolstrip; - model_->SetToolstripDataAt(index, NULL); - - // Technically, the toolstrip is still in the model at this point, but - // the Layout code handles this case. - Layout(); -} - -void ExtensionShelf::ToolstripDraggingFrom(ExtensionHost* host, int index) { -} - -void ExtensionShelf::ToolstripMoved(ExtensionHost* host, int from_index, - int to_index) { - Layout(); -} - -void ExtensionShelf::ToolstripChanged(ExtensionShelfModel::iterator toolstrip) { - Toolstrip* t = static_cast<Toolstrip*>(toolstrip->data); - if (toolstrip->height > 0) { - if (!t->expanded()) { - t->Expand(toolstrip->height, toolstrip->url); - } - } else if (t->expanded()) { - t->Collapse(toolstrip->url); - } -} - -void ExtensionShelf::ExtensionShelfEmpty() { - PreferredSizeChanged(); -} - -void ExtensionShelf::ShelfModelReloaded() { - // None of the child views are parent owned, so nothing is being leaked here. - RemoveAllChildViews(false); - LoadFromModel(); -} - -void ExtensionShelf::ShelfModelDeleting() { - int count = model_->count(); - for (int i = 0; i < count; ++i) { - delete ToolstripAtIndex(i); - model_->SetToolstripDataAt(i, NULL); - } - model_->RemoveObserver(this); - model_ = NULL; -} - -void ExtensionShelf::AnimationProgressed(const Animation* animation) { - if (browser_) - browser_->ExtensionShelfSizeChanged(); -} - -void ExtensionShelf::AnimationEnded(const Animation* animation) { - if (browser_) - browser_->ExtensionShelfSizeChanged(); - - Layout(); -} - -void ExtensionShelf::Observe(NotificationType type, - const NotificationSource& source, - const NotificationDetails& details) { - switch (type.value) { - case NotificationType::EXTENSION_SHELF_VISIBILITY_PREF_CHANGED: { - if (fullscreen_) - break; - if (IsAlwaysShown()) - size_animation_->Show(); - else - size_animation_->Hide(); - break; - } - default: - NOTREACHED(); - break; - } -} - -void ExtensionShelf::OnExtensionMouseMove(ExtensionView* view) { - Toolstrip *toolstrip = ToolstripForView(view); - if (toolstrip) - toolstrip->ShowShelfHandle(); -} - -void ExtensionShelf::OnExtensionMouseLeave(ExtensionView* view) { - Toolstrip *toolstrip = ToolstripForView(view); - if (toolstrip) - toolstrip->HideShelfHandle(kHideDelayMs); -} - -void ExtensionShelf::DropExtension(Toolstrip* toolstrip, const gfx::Point& pt, - bool cancel) { - Toolstrip* dest_toolstrip = ToolstripAtX(pt.x()); - if (!dest_toolstrip) { - if (pt.x() > 0) - dest_toolstrip = ToolstripAtIndex(model_->count() - 1); - else - dest_toolstrip = ToolstripAtIndex(0); - } - if (toolstrip == dest_toolstrip) - return; - int from = model_->IndexOfHost(toolstrip->host()); - int to = model_->IndexOfHost(dest_toolstrip->host()); - DCHECK(from != to); - model_->MoveToolstripAt(from, to); -} - -void ExtensionShelf::ExpandToolstrip(ExtensionHost* host, const GURL& url, - int height) { - ExtensionShelfModel::iterator toolstrip = model_->ToolstripForHost(host); - model_->ExpandToolstrip(toolstrip, url, height); -} - -void ExtensionShelf::CollapseToolstrip(ExtensionHost* host, const GURL& url) { - ExtensionShelfModel::iterator toolstrip = model_->ToolstripForHost(host); - model_->CollapseToolstrip(toolstrip, url); -} - -void ExtensionShelf::InitBackground(gfx::Canvas* canvas) { - if (!background_needs_repaint_) - return; - - // Capture a background bitmap to give to the toolstrips. - SkRect background_rect = { - SkIntToScalar(0), - SkIntToScalar(0), - SkIntToScalar(width()), - SkIntToScalar(height()) - }; - - // Tell all extension views about the new background. - int count = model_->count(); - for (int i = 0; i < count; ++i) { - ExtensionView* view = ToolstripAtIndex(i)->view(); - - const SkBitmap& background = - canvas->AsCanvasSkia()->getDevice()->accessBitmap(false); - - SkRect mapped_subset = background_rect; - gfx::Rect view_bounds = view->bounds(); - mapped_subset.offset(SkIntToScalar(view_bounds.x()), - SkIntToScalar(view_bounds.y())); - bool result = - canvas->AsCanvasSkia()->getTotalMatrix().mapRect(&mapped_subset); - DCHECK(result); - - SkIRect isubset; - mapped_subset.round(&isubset); - SkBitmap subset_bitmap; - // This will create another bitmap that just references pixels in the - // actual bitmap. - result = background.extractSubset(&subset_bitmap, isubset); - if (!result) - return; - - // We do a deep copy because extractSubset() returns a bitmap that - // references pixels in the original one and we want to actually make a - // smaller copy that will have a long lifetime. - SkBitmap smaller_copy; - if (!subset_bitmap.copyTo(&smaller_copy, SkBitmap::kARGB_8888_Config)) - return; - DCHECK(smaller_copy.readyToDraw()); - - view->SetBackground(smaller_copy); - } - - background_needs_repaint_ = false; -} - -ExtensionShelf::Toolstrip* ExtensionShelf::ToolstripAtX(int x) { - int count = model_->count(); - if (count == 0) - return NULL; - - if (x < 0) - return NULL; - - for (int i = 0; i < count; ++i) { - Toolstrip* toolstrip = ToolstripAtIndex(i); - View* view = toolstrip->GetShelfView(); - int x_mirrored = view->GetRootView()->MirroredXCoordinateInsideView(x); - if (x_mirrored > view->x() + view->width() + kToolstripPadding) - continue; - return toolstrip; - } - - return NULL; -} - -ExtensionShelf::Toolstrip* ExtensionShelf::ToolstripAtIndex(int index) { - return static_cast<Toolstrip*>(model_->ToolstripAt(index).data); -} - -ExtensionShelf::Toolstrip* ExtensionShelf::ToolstripForView( - ExtensionView* view) { - int count = model_->count(); - for (int i = 0; i < count; ++i) { - Toolstrip* toolstrip = ToolstripAtIndex(i); - if (view == toolstrip->view()) - return toolstrip; - } - return NULL; -} - -void ExtensionShelf::LoadFromModel() { - int count = model_->count(); - for (int i = 0; i < count; ++i) - ToolstripInsertedAt(model_->ToolstripAt(i).host, i); -} - -gfx::Size ExtensionShelf::LayoutItems(bool compute_bounds_only) { - if (!GetParent() || !model_ || !model_->count()) - return gfx::Size(0, 0); - - gfx::Size prefsize; - int x = kLeftMargin; - int y = top_margin_; - int content_height = kShelfHeight - top_margin_ - kBottomMargin; - int max_x = width() - kRightMargin; - - if (OnNewTabPage()) { - double current_state = 1 - size_animation_->GetCurrentValue(); - x += static_cast<int>(static_cast<double> - (kNewtabHorizontalPadding + kNewtabExtraHorMargin) * current_state); - y += static_cast<int>(static_cast<double> - (kNewtabVerticalPadding + kNewtabExtraVerMargin) * current_state); - max_x -= static_cast<int>(static_cast<double> - (2 * kNewtabHorizontalPadding) * current_state); - } - - int count = model_->count(); - for (int i = 0; i < count; ++i) { - x += kToolstripPadding; // Left padding. - Toolstrip* toolstrip = ToolstripAtIndex(i); - if (!toolstrip) // Can be NULL while in the process of removing. - continue; - View* view = toolstrip->GetShelfView(); - gfx::Size pref = view->GetPreferredSize(); - - // |next_x| is the x value for where the next toolstrip in the list will be. - int next_x = x + pref.width() + kToolstripPadding; // Right padding. - if (!compute_bounds_only) { - bool clipped = next_x >= max_x; - if (clipped) - pref.set_width(std::max(0, max_x - x)); - if (view == toolstrip->view()) - toolstrip->view()->SetIsClipped(clipped); - view->SetBounds(x, y, pref.width(), content_height); - view->Layout(); - if (toolstrip->window_visible()) - toolstrip->LayoutWindow(); - } - x = next_x + kToolstripDividerWidth; - } - - if (!compute_bounds_only) { - background_needs_repaint_ = true; - SchedulePaint(); - } else { - if (OnNewTabPage()) { - prefsize.set_height(kShelfHeight + static_cast<int>(static_cast<double> - (kNewtabShelfHeight - kShelfHeight) * - (1 - size_animation_->GetCurrentValue()))); - } else { - prefsize.set_height(static_cast<int>(static_cast<double>(kShelfHeight) * - size_animation_->GetCurrentValue())); - } - - x += kRightMargin; - prefsize.set_width(x); - } - - return prefsize; -} - -bool ExtensionShelf::IsDetached() const { - return OnNewTabPage() && (size_animation_->GetCurrentValue() != 1); -} - -bool ExtensionShelf::IsAlwaysShown() const { - Profile* profile = browser_->profile(); - return profile->GetPrefs()->GetBoolean(prefs::kShowExtensionShelf); -} - -bool ExtensionShelf::OnNewTabPage() const { - return (browser_ && browser_->GetSelectedTabContents() && - browser_->GetSelectedTabContents()->IsExtensionShelfAlwaysVisible()); -} - -void ExtensionShelf::OnFullscreenToggled(bool fullscreen) { - if (fullscreen == fullscreen_) - return; - fullscreen_ = fullscreen; - if (!IsAlwaysShown()) - return; - size_animation_->Reset(fullscreen ? 0 : 1); -} diff --git a/chrome/browser/views/extensions/extension_shelf.h b/chrome/browser/views/extensions/extension_shelf.h deleted file mode 100644 index 256b5cc..0000000 --- a/chrome/browser/views/extensions/extension_shelf.h +++ /dev/null @@ -1,155 +0,0 @@ -// 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. - -#ifndef CHROME_BROWSER_VIEWS_EXTENSIONS_EXTENSION_SHELF_H_ -#define CHROME_BROWSER_VIEWS_EXTENSIONS_EXTENSION_SHELF_H_ -#pragma once - -#include "app/slide_animation.h" -#include "base/task.h" -#include "chrome/browser/extensions/extension_shelf_model.h" -#include "chrome/browser/extensions/extensions_service.h" -#include "chrome/browser/views/browser_bubble.h" -#include "chrome/browser/views/detachable_toolbar_view.h" -#include "gfx/canvas.h" -#include "views/view.h" - -class Browser; -namespace views { - class Label; - class MouseEvent; -} - -// A shelf that contains Extension toolstrips. -class ExtensionShelf : public DetachableToolbarView, - public ExtensionView::Container, - public ExtensionShelfModelObserver, - public AnimationDelegate, - public NotificationObserver { - public: - explicit ExtensionShelf(Browser* browser); - virtual ~ExtensionShelf(); - - // Get the current model. - ExtensionShelfModel* model() { return model_; } - - // Toggles a preference for whether to always show the extension shelf. - static void ToggleWhenExtensionShelfVisible(Profile* profile); - - int top_margin() { return top_margin_; } - - // DetachableToolbarView methods: - virtual bool IsDetached() const; - virtual double GetAnimationValue() const { - return size_animation_->GetCurrentValue(); - } - - // View methods: - virtual void PaintChildren(gfx::Canvas* canvas); - virtual gfx::Size GetPreferredSize(); - virtual void Layout(); - virtual void OnMouseExited(const views::MouseEvent& event); - virtual void OnMouseEntered(const views::MouseEvent& event); - virtual bool GetAccessibleRole(AccessibilityTypes::Role* role); - virtual void OnThemeChanged(); - - // ExtensionContainer methods: - virtual void OnExtensionMouseMove(ExtensionView* view); - virtual void OnExtensionMouseLeave(ExtensionView* view); - - // ExtensionShelfModelObserver methods: - virtual void ToolstripInsertedAt(ExtensionHost* toolstrip, int index); - virtual void ToolstripRemovingAt(ExtensionHost* toolstrip, int index); - virtual void ToolstripDraggingFrom(ExtensionHost* toolstrip, int index); - virtual void ToolstripMoved(ExtensionHost* toolstrip, - int from_index, - int to_index); - virtual void ToolstripChanged(ExtensionShelfModel::iterator toolstrip); - virtual void ExtensionShelfEmpty(); - virtual void ShelfModelReloaded(); - virtual void ShelfModelDeleting(); - - // AnimationDelegate methods: - virtual void AnimationProgressed(const Animation* animation); - virtual void AnimationEnded(const Animation* animation); - - // NotificationObserver methods: - virtual void Observe(NotificationType type, - const NotificationSource& source, - const NotificationDetails& details); - - // Toggle fullscreen mode. - void OnFullscreenToggled(bool fullscreen); - - protected: - // View methods: - virtual void ChildPreferredSizeChanged(View* child); - - private: - class Toolstrip; - friend class Toolstrip; - class PlaceholderView; - - // Dragging toolstrips - void DropExtension(Toolstrip* handle, const gfx::Point& pt, bool cancel); - - // Expand the specified toolstrip, navigating to |url| if non-empty, - // and setting the |height|. - void ExpandToolstrip(ExtensionHost* host, const GURL& url, int height); - - // Collapse the specified toolstrip, navigating to |url| if non-empty. - void CollapseToolstrip(ExtensionHost* host, const GURL& url); - - // Initializes the background bitmaps for all views. - void InitBackground(gfx::Canvas* canvas); - - // Returns the Toolstrip at |x| coordinate. If |x| is out of bounds, returns - // NULL. - Toolstrip* ToolstripAtX(int x); - - // Returns the Toolstrip at |index|. - Toolstrip* ToolstripAtIndex(int index); - - // Returns the toolstrip associated with |view|. - Toolstrip* ToolstripForView(ExtensionView* view); - - // Loads initial state from |model_|. - void LoadFromModel(); - - // This method computes the bounds for the extension shelf items. If - // |compute_bounds_only| = TRUE, the bounds for the items are just computed, - // but are not set. This mode is used by GetPreferredSize() to obtain the - // desired bounds. If |compute_bounds_only| = FALSE, the bounds are set. - gfx::Size LayoutItems(bool compute_bounds_only); - - // Returns whether the extension shelf always shown (checks pref value). - bool IsAlwaysShown() const; - - // Returns whether the extension shelf is being displayed over the new tab - // page. - bool OnNewTabPage() const; - - int top_margin_; - - NotificationRegistrar registrar_; - - // Background bitmap to draw under extension views. - bool background_needs_repaint_; - - // The browser this extension shelf belongs to. - Browser* browser_; - - // The model representing the toolstrips on the shelf. - ExtensionShelfModel* model_; - - // Animation controlling showing and hiding of the shelf. - scoped_ptr<SlideAnimation> size_animation_; - - // Are we in fullscreen mode or not. - bool fullscreen_; - - DISALLOW_COPY_AND_ASSIGN(ExtensionShelf); -}; - -#endif // CHROME_BROWSER_VIEWS_EXTENSIONS_EXTENSION_SHELF_H_ diff --git a/chrome/browser/views/extensions/extension_view.cc b/chrome/browser/views/extensions/extension_view.cc index 355e455..4e7f1ae 100644 --- a/chrome/browser/views/extensions/extension_view.cc +++ b/chrome/browser/views/extensions/extension_view.cc @@ -120,13 +120,7 @@ void ExtensionView::ShowIfCompletelyLoaded() { // We wait to show the ExtensionView until it has loaded, and the view has // actually been created. These can happen in different orders. if (host_->did_stop_loading()) { - // For toolstrips, also wait until our parent has given us a background. - if (host_->GetRenderViewType() == ViewType::EXTENSION_TOOLSTRIP && - render_view_host()->view()->background().empty()) { - return; - } SetVisible(true); - UpdatePreferredSize(pending_preferred_size_); } } diff --git a/chrome/browser/views/frame/browser_view.cc b/chrome/browser/views/frame/browser_view.cc index 0174537..85c2d16 100644 --- a/chrome/browser/views/frame/browser_view.cc +++ b/chrome/browser/views/frame/browser_view.cc @@ -10,6 +10,7 @@ #include "app/l10n_util.h" #include "app/resource_bundle.h" +#include "base/command_line.h" #include "base/i18n/rtl.h" #include "base/string_number_conversions.h" #include "base/utf_string_conversions.h" @@ -37,7 +38,6 @@ #include "chrome/browser/views/bookmark_bar_view.h" #include "chrome/browser/views/browser_dialogs.h" #include "chrome/browser/views/download_shelf_view.h" -#include "chrome/browser/views/extensions/extension_shelf.h" #include "chrome/browser/views/frame/browser_view_layout.h" #include "chrome/browser/views/fullscreen_exit_bubble.h" #include "chrome/browser/views/status_bubble_views.h" @@ -488,12 +488,12 @@ BrowserView::BrowserView(Browser* browser) contents_(NULL), contents_split_(NULL), initialized_(false), - ignore_layout_(true), + ignore_layout_(true) #if defined(OS_WIN) - hung_window_detector_(&hung_plugin_action_), - ticker_(0), + ,hung_window_detector_(&hung_plugin_action_), + ticker_(0) #endif - extension_shelf_(NULL) { + { browser_->tabstrip_model()->AddObserver(this); } @@ -807,10 +807,6 @@ void BrowserView::SelectedTabToolbarSizeChanged(bool is_animating) { } } -void BrowserView::SelectedTabExtensionShelfSizeChanged() { - Layout(); -} - void BrowserView::UpdateTitleBar() { frame_->GetWindow()->UpdateWindowTitle(); if (ShouldShowWindowIcon() && !loading_animation_timer_.IsRunning()) @@ -1068,10 +1064,6 @@ void BrowserView::ToggleBookmarkBar() { bookmark_utils::ToggleWhenVisible(browser_->profile()); } -void BrowserView::ToggleExtensionShelf() { - ExtensionShelf::ToggleWhenExtensionShelfVisible(browser_->profile()); -} - views::Window* BrowserView::ShowAboutChromeDialog() { return browser::ShowAboutChromeView(GetWindow()->GetNativeWindow(), browser_->profile()); @@ -1872,16 +1864,6 @@ void BrowserView::Init() { status_bubble_.reset(new StatusBubbleViews(GetWidget())); - if (browser_->SupportsWindowFeature(Browser::FEATURE_EXTENSIONSHELF)) { - extension_shelf_ = new ExtensionShelf(browser_.get()); - extension_shelf_->set_background( - new BookmarkExtensionBackground(this, extension_shelf_, - browser_.get())); - extension_shelf_-> - SetAccessibleName(l10n_util::GetString(IDS_ACCNAME_EXTENSIONS)); - AddChildView(extension_shelf_); - } - #if defined(OS_WIN) InitSystemMenu(); @@ -2113,11 +2095,6 @@ void BrowserView::ProcessFullscreen(bool fullscreen) { if (bookmark_bar_view_.get()) bookmark_bar_view_->OnFullscreenToggled(fullscreen); - // Notify extension shelf, so it can set itself to the appropriate drawing - // state. - if (extension_shelf_) - extension_shelf_->OnFullscreenToggled(fullscreen); - // Toggle fullscreen mode. #if defined(OS_WIN) frame_->GetWindow()->SetFullscreen(fullscreen); diff --git a/chrome/browser/views/frame/browser_view.h b/chrome/browser/views/frame/browser_view.h index 62c628c..4cdd39e 100644 --- a/chrome/browser/views/frame/browser_view.h +++ b/chrome/browser/views/frame/browser_view.h @@ -46,7 +46,6 @@ class BrowserBubble; class BrowserViewLayout; class DownloadShelfView; class EncodingMenuModel; -class ExtensionShelf; class FullscreenExitBubble; class HtmlDialogUIDelegate; class InfoBarContainer; @@ -152,9 +151,6 @@ class BrowserView : public BrowserBubbleHost, // Accessor for the Toolbar. ToolbarView* toolbar() const { return toolbar_; } - // Accessor for the ExtensionShelf. - ExtensionShelf* extension_shelf() const { return extension_shelf_; } - // Returns true if various window components are visible. bool IsTabStripVisible() const; @@ -251,7 +247,6 @@ class BrowserView : public BrowserBubbleHost, virtual BrowserWindowTesting* GetBrowserWindowTesting(); virtual StatusBubble* GetStatusBubble(); virtual void SelectedTabToolbarSizeChanged(bool is_animating); - virtual void SelectedTabExtensionShelfSizeChanged(); virtual void UpdateTitleBar(); virtual void ShelfVisibilityChanged(); virtual void UpdateDevTools(); @@ -279,7 +274,6 @@ class BrowserView : public BrowserBubbleHost, virtual void ConfirmAddSearchProvider(const TemplateURL* template_url, Profile* profile); virtual void ToggleBookmarkBar(); - virtual void ToggleExtensionShelf(); virtual views::Window* ShowAboutChromeDialog(); virtual void ShowUpdateChromeDialog(); virtual void ShowTaskManager(); @@ -592,9 +586,6 @@ class BrowserView : public BrowserBubbleHost, // The timer used to update frames for the Loading Animation. base::RepeatingTimer<BrowserView> loading_animation_timer_; - // A bottom bar for showing extensions. - ExtensionShelf* extension_shelf_; - UnhandledKeyboardEventHandler unhandled_keyboard_event_handler_; scoped_ptr<AccessibleViewHelper> accessible_view_helper_; diff --git a/chrome/browser/views/frame/browser_view_layout.cc b/chrome/browser/views/frame/browser_view_layout.cc index e7d807b..8af0a07 100644 --- a/chrome/browser/views/frame/browser_view_layout.cc +++ b/chrome/browser/views/frame/browser_view_layout.cc @@ -9,7 +9,6 @@ #include "chrome/browser/view_ids.h" #include "chrome/browser/views/bookmark_bar_view.h" #include "chrome/browser/views/download_shelf_view.h" -#include "chrome/browser/views/extensions/extension_shelf.h" #include "chrome/browser/views/frame/browser_frame.h" #include "chrome/browser/views/frame/browser_view.h" #include "chrome/browser/views/tabs/side_tab_strip.h" @@ -45,7 +44,6 @@ BrowserViewLayout::BrowserViewLayout() contents_container_(NULL), infobar_container_(NULL), download_shelf_(NULL), - extension_shelf_(NULL), active_bookmark_bar_(NULL), browser_view_(NULL), find_bar_y_(0) { @@ -199,7 +197,6 @@ void BrowserViewLayout::Installed(views::View* host) { contents_container_ = NULL; infobar_container_ = NULL; download_shelf_ = NULL; - extension_shelf_ = NULL; active_bookmark_bar_ = NULL; tabstrip_ = NULL; browser_view_ = static_cast<BrowserView*>(host); @@ -219,9 +216,6 @@ void BrowserViewLayout::ViewAdded(views::View* host, views::View* view) { case VIEW_ID_DOWNLOAD_SHELF: download_shelf_ = static_cast<DownloadShelfView*>(view); break; - case VIEW_ID_DEV_EXTENSION_SHELF: - extension_shelf_ = static_cast<ExtensionShelf*>(view); - break; case VIEW_ID_BOOKMARK_BAR: active_bookmark_bar_ = static_cast<BookmarkBarView*>(view); break; @@ -247,7 +241,7 @@ void BrowserViewLayout::Layout(views::View* host) { int top = LayoutTabStrip(); top = LayoutToolbar(top); top = LayoutBookmarkAndInfoBars(top); - int bottom = LayoutExtensionAndDownloadShelves(); + int bottom = LayoutDownloadShelf(browser_view_->height()); LayoutTabContents(top, bottom); // This must be done _after_ we lay out the TabContents since this // code calls back into us to find the bounding box the find bar @@ -368,24 +362,6 @@ void BrowserViewLayout::LayoutTabContents(int top, int bottom) { vertical_layout_rect_.width(), bottom - top); } -int BrowserViewLayout::LayoutExtensionAndDownloadShelves() { - // If we're showing the Extension bar in detached style, then we - // need to show Download shelf _above_ the Extension bar, since - // the Extension bar is styled to look like it's part of the page. - // - // TODO(Oshima): confirm this comment. - int bottom = browser_view_->height(); - if (extension_shelf_) { - if (extension_shelf_->IsDetached()) { - bottom = LayoutDownloadShelf(bottom); - return LayoutExtensionShelf(bottom); - } - // Otherwise, Extension shelf first, Download shelf second. - bottom = LayoutExtensionShelf(bottom); - } - return LayoutDownloadShelf(bottom); -} - int BrowserViewLayout::LayoutDownloadShelf(int bottom) { // Re-layout the shelf either if it is visible or if it's close animation // is currently running. @@ -404,17 +380,3 @@ int BrowserViewLayout::LayoutDownloadShelf(int bottom) { return bottom; } -int BrowserViewLayout::LayoutExtensionShelf(int bottom) { - if (extension_shelf_) { - bool visible = browser()->SupportsWindowFeature( - Browser::FEATURE_EXTENSIONSHELF); - int height = - visible ? extension_shelf_->GetPreferredSize().height() : 0; - extension_shelf_->SetVisible(visible && height != 0); - extension_shelf_->SetBounds(vertical_layout_rect_.x(), bottom - height, - vertical_layout_rect_.width(), height); - extension_shelf_->Layout(); - bottom -= height; - } - return bottom; -} diff --git a/chrome/browser/views/frame/browser_view_layout.h b/chrome/browser/views/frame/browser_view_layout.h index 30f3756..e0e0975 100644 --- a/chrome/browser/views/frame/browser_view_layout.h +++ b/chrome/browser/views/frame/browser_view_layout.h @@ -58,16 +58,11 @@ class BrowserViewLayout : public views::LayoutManager { // Layout the TabContents container, between the coordinates |top| and // |bottom|. void LayoutTabContents(int top, int bottom); - int LayoutExtensionAndDownloadShelves(); // Layout the Download Shelf, returns the coordinate of the top of the // control, for laying out the previous control. int LayoutDownloadShelf(int bottom); - // Layout the Extension Shelf, returns the coordinate of the top of the - // control, for laying out the previous control. - int LayoutExtensionShelf(int bottom); - // See description above vertical_layout_rect_ for details. void set_vertical_layout_rect(const gfx::Rect& bounds) { vertical_layout_rect_ = bounds; @@ -83,7 +78,6 @@ class BrowserViewLayout : public views::LayoutManager { views::View* contents_container_; views::View* infobar_container_; DownloadShelfView* download_shelf_; - ExtensionShelf* extension_shelf_; BookmarkBarView* active_bookmark_bar_; BrowserView* browser_view_; diff --git a/chrome/chrome_browser.gypi b/chrome/chrome_browser.gypi index 35807fa..c43c430 100644 --- a/chrome/chrome_browser.gypi +++ b/chrome/chrome_browser.gypi @@ -1374,8 +1374,6 @@ 'browser/extensions/extension_proxy_api.h', 'browser/extensions/extension_rlz_module.cc', 'browser/extensions/extension_rlz_module.h', - 'browser/extensions/extension_shelf_model.cc', - 'browser/extensions/extension_shelf_model.h', 'browser/extensions/extension_tabs_module.cc', 'browser/extensions/extension_tabs_module.h', 'browser/extensions/extension_tabs_module_constants.cc', @@ -1386,8 +1384,6 @@ 'browser/extensions/extension_tts_api.h', 'browser/extensions/extension_toolbar_model.cc', 'browser/extensions/extension_toolbar_model.h', - 'browser/extensions/extension_toolstrip_api.cc', - 'browser/extensions/extension_toolstrip_api.h', 'browser/extensions/extension_updater.cc', 'browser/extensions/extension_updater.h', 'browser/extensions/extension_web_navigation_api_constants.cc', @@ -2685,8 +2681,6 @@ 'browser/views/extensions/extension_installed_bubble.h', 'browser/views/extensions/extension_popup.cc', 'browser/views/extensions/extension_popup.h', - 'browser/views/extensions/extension_shelf.cc', - 'browser/views/extensions/extension_shelf.h', 'browser/views/extensions/extension_view.cc', 'browser/views/extensions/extension_view.h', 'browser/views/external_protocol_dialog.cc', @@ -3021,9 +3015,6 @@ ], }, 'sources!': [ - # Exclude extension shelf for toolstrips. - 'browser/views/extensions/extension_shelf.cc', - 'browser/views/extensions/extension_shelf.h', 'browser/views/extensions/extension_view.cc', 'browser/views/extensions/extension_view.h', ], @@ -3097,8 +3088,6 @@ 'browser/renderer_host/gpu_view_host.h', 'browser/renderer_host/video_layer_proxy.cc', 'browser/renderer_host/video_layer_proxy.h', - 'browser/views/extensions/extension_shelf.cc', - 'browser/views/extensions/extension_shelf.h', 'browser/views/extensions/extension_view.cc', 'browser/views/extensions/extension_view.h', ], @@ -3383,8 +3372,6 @@ ['include', '^browser/views/extensions/extension_installed_bubble.h'], ['include', '^browser/views/extensions/extension_popup.cc'], ['include', '^browser/views/extensions/extension_popup.h'], - ['include', '^browser/views/extensions/extension_shelf.cc'], - ['include', '^browser/views/extensions/extension_shelf.h'], ['include', '^browser/views/extensions/extension_view.cc'], ['include', '^browser/views/extensions/extension_view.h'], ['include', '^browser/views/extension_view.cc'], diff --git a/chrome/chrome_tests.gypi b/chrome/chrome_tests.gypi index 2f3d647..a6e49b0 100644 --- a/chrome/chrome_tests.gypi +++ b/chrome/chrome_tests.gypi @@ -1602,14 +1602,12 @@ 'browser/extensions/extension_proxy_apitest.cc', 'browser/extensions/extension_processes_apitest.cc', 'browser/extensions/extension_rlz_apitest.cc', - 'browser/extensions/extension_shelf_model_browsertest.cc', 'browser/extensions/extension_startup_browsertest.cc', 'browser/extensions/extension_storage_apitest.cc', 'browser/extensions/extension_tabs_apitest.cc', 'browser/extensions/extension_test_message_listener.cc', 'browser/extensions/extension_test_message_listener.h', 'browser/extensions/extension_toolbar_model_browsertest.cc', - 'browser/extensions/extension_toolstrip_apitest.cc', 'browser/extensions/extension_tts_apitest.cc', 'browser/extensions/extension_webnavigation_apitest.cc', 'browser/extensions/extension_webrequest_apitest.cc', @@ -1714,7 +1712,6 @@ 'app/chrome_dll_version.rc.version', 'browser/extensions/extension_popup_apitest.cc', 'browser/extensions/extension_rlz_apitest.cc', - 'browser/extensions/extension_shelf_model_browsertest.cc', # TODO(jam): http://crbug.com/15101 These tests fail on Linux and # Mac. 'browser/child_process_security_policy_browsertest.cc', diff --git a/chrome/common/chrome_switches.cc b/chrome/common/chrome_switches.cc index 3f8b0f5..16a6800 100644 --- a/chrome/common/chrome_switches.cc +++ b/chrome/common/chrome_switches.cc @@ -345,9 +345,6 @@ const char kEnableExperimentalWebGL[] = "enable-webgl"; // Enable experimental timeline API. const char kEnableExtensionTimelineApi[] = "enable-extension-timeline-api"; -// Enable extension toolstrips (deprecated API - will be removed). -const char kEnableExtensionToolstrips[] = "enable-extension-toolstrips"; - // Enable the fastback page cache. const char kEnableFastback[] = "enable-fastback"; diff --git a/chrome/common/chrome_switches.h b/chrome/common/chrome_switches.h index dde93de..0078657 100644 --- a/chrome/common/chrome_switches.h +++ b/chrome/common/chrome_switches.h @@ -114,7 +114,6 @@ extern const char kEnableDNSSECCerts[]; extern const char kEnableExperimentalExtensionApis[]; extern const char kEnableExperimentalWebGL[]; extern const char kEnableExtensionTimelineApi[]; -extern const char kEnableExtensionToolstrips[]; extern const char kEnableFastback[]; extern const char kEnableFileCookies[]; extern const char kEnableGPUPlugin[]; diff --git a/chrome/common/extensions/api/extension_api.json b/chrome/common/extensions/api/extension_api.json index e0530b9..670d72b 100644 --- a/chrome/common/extensions/api/extension_api.json +++ b/chrome/common/extensions/api/extension_api.json @@ -2148,46 +2148,6 @@ ] }, { - "namespace": "toolstrip", - "nodoc": true, - "types": [], - "functions": [ - { - "name": "expand", - "type": "function", - "description": "", - "parameters": [ - { - "type": "object", - "name": "expandInfo", - "properties": { - "height": { "type": "integer", "minimum": 0, "description": "The vertical pixel height required of the toolstrip area." }, - "url": { "type": "string", "optional": true, "description": "If present, the toolstrip mole will change it's content to the provided URL. Otherwise, the current page will just be expanded in size." } - } - }, - {"type": "function", "name": "callback", "optional": true, "parameters": []} - ] - }, - { - "name": "collapse", - "type": "function", - "description": "", - "parameters": [ - { - "type": "object", - "name": "collapseInfo", - "optional": true, - "properties": { - "url": { "type": "string", "optional": true, "description": "If present, the toolstrip mole will change it's content to the provided URL. Otherwise, the current page will just be collapsed in size." } - } - }, - {"type": "function", "name": "callback", "optional": true, "parameters": []} - ] - } - ], - "events": [] - }, - { "namespace": "i18n", "unprivileged": true, "types": [], diff --git a/chrome/common/extensions/extension.cc b/chrome/common/extensions/extension.cc index d69527e..3e5701d 100644 --- a/chrome/common/extensions/extension.cc +++ b/chrome/common/extensions/extension.cc @@ -1257,10 +1257,11 @@ bool Extension::InitFromValue(const DictionaryValue& source, bool require_key, options_url_ = GetResourceURL(options_str); } - // Initialize toolstrips (deprecated and optional). - // TODO(erikkay) remove this altogether. + // Initialize toolstrips. This is deprecated for public use. + // NOTE(erikkay) Although deprecated, we intend to preserve this parsing + // code indefinitely. Please contact me or Joi for details as to why. if (CommandLine::ForCurrentProcess()->HasSwitch( - switches::kEnableExtensionToolstrips) && + switches::kEnableExperimentalExtensionApis) && source.HasKey(keys::kToolstrips)) { ListValue* list_value; if (!source.GetList(keys::kToolstrips, &list_value)) { @@ -1269,12 +1270,12 @@ bool Extension::InitFromValue(const DictionaryValue& source, bool require_key, } for (size_t i = 0; i < list_value->GetSize(); ++i) { - ToolstripInfo toolstrip; + GURL toolstrip; DictionaryValue* toolstrip_value; std::string toolstrip_path; if (list_value->GetString(i, &toolstrip_path)) { // Support a simple URL value for backwards compatibility. - toolstrip.toolstrip = GetResourceURL(toolstrip_path); + toolstrip = GetResourceURL(toolstrip_path); } else if (list_value->GetDictionary(i, &toolstrip_value)) { if (!toolstrip_value->GetString(keys::kToolstripPath, &toolstrip_path)) { @@ -1282,25 +1283,7 @@ bool Extension::InitFromValue(const DictionaryValue& source, bool require_key, errors::kInvalidToolstrip, base::IntToString(i)); return false; } - toolstrip.toolstrip = GetResourceURL(toolstrip_path); - if (toolstrip_value->HasKey(keys::kToolstripMolePath)) { - std::string mole_path; - if (!toolstrip_value->GetString(keys::kToolstripMolePath, - &mole_path)) { - *error = ExtensionErrorUtils::FormatErrorMessage( - errors::kInvalidToolstrip, base::IntToString(i)); - return false; - } - int height; - if (!toolstrip_value->GetInteger(keys::kToolstripMoleHeight, - &height) || (height < 0)) { - *error = ExtensionErrorUtils::FormatErrorMessage( - errors::kInvalidToolstrip, base::IntToString(i)); - return false; - } - toolstrip.mole = GetResourceURL(mole_path); - toolstrip.mole_height = height; - } + toolstrip = GetResourceURL(toolstrip_path); } else { *error = ExtensionErrorUtils::FormatErrorMessage( errors::kInvalidToolstrip, base::IntToString(i)); diff --git a/chrome/common/extensions/extension.h b/chrome/common/extensions/extension.h index 9bcd7b1..3ab2482 100644 --- a/chrome/common/extensions/extension.h +++ b/chrome/common/extensions/extension.h @@ -125,15 +125,6 @@ class Extension { bool is_public; // False if only this extension can load this plugin. }; - // A toolstrip and its associated mole. - struct ToolstripInfo { - ToolstripInfo() : mole_height(0) {} - - GURL toolstrip; - GURL mole; - int mole_height; - }; - // The name of the manifest inside an extension. static const FilePath::CharType kManifestFilename[]; @@ -265,7 +256,7 @@ class Extension { const GURL& background_url() const { return background_url_; } const GURL& options_url() const { return options_url_; } const GURL& devtools_url() const { return devtools_url_; } - const std::vector<ToolstripInfo>& toolstrips() const { return toolstrips_; } + const std::vector<GURL>& toolstrips() const { return toolstrips_; } const std::vector<std::string>& api_permissions() const { return api_permissions_; } @@ -495,7 +486,7 @@ class Extension { GURL devtools_url_; // Optional list of toolstrips_ and associated properties. - std::vector<ToolstripInfo> toolstrips_; + std::vector<GURL> toolstrips_; // The public key ('key' in the manifest) used to sign the contents of the // crx package ('signature' in the manifest) diff --git a/chrome/common/extensions/extension_constants.cc b/chrome/common/extensions/extension_constants.cc index 0f4f5dd..a14b244 100644 --- a/chrome/common/extensions/extension_constants.cc +++ b/chrome/common/extensions/extension_constants.cc @@ -57,8 +57,6 @@ const char* kThemeColors = "colors"; const char* kThemeDisplayProperties = "properties"; const char* kThemeImages = "images"; const char* kThemeTints = "tints"; -const char* kToolstripMoleHeight = "mole_height"; -const char* kToolstripMolePath = "mole"; const char* kToolstripPath = "path"; const char* kToolstrips = "toolstrips"; const char* kType = "type"; diff --git a/chrome/common/extensions/extension_constants.h b/chrome/common/extensions/extension_constants.h index 3258449..83817b8 100644 --- a/chrome/common/extensions/extension_constants.h +++ b/chrome/common/extensions/extension_constants.h @@ -59,8 +59,6 @@ namespace extension_manifest_keys { extern const char* kThemeDisplayProperties; extern const char* kThemeImages; extern const char* kThemeTints; - extern const char* kToolstripMoleHeight; - extern const char* kToolstripMolePath; extern const char* kToolstripPath; extern const char* kToolstrips; extern const char* kType; diff --git a/chrome/common/notification_type.h b/chrome/common/notification_type.h index 7c19c9e..f07cb59 100644 --- a/chrome/common/notification_type.h +++ b/chrome/common/notification_type.h @@ -476,11 +476,6 @@ class NotificationType { // NoDetails. BOOKMARK_BAR_VISIBILITY_PREF_CHANGED, - // This is sent when the user's preference (for when the extension shelf - // should be shown) changes. The source is the profile, and the details are - // NoDetails. - EXTENSION_SHELF_VISIBILITY_PREF_CHANGED, - // Sent just before the installation confirm dialog is shown. The source // is the ExtensionInstallUI, the details are NoDetails. EXTENSION_WILL_SHOW_CONFIRM_DIALOG, @@ -845,9 +840,6 @@ class NotificationType { // during browser shutdown. EXTENSION_PROCESS_TERMINATED, - // Sent when the contents or order of toolstrips in the shelf model change. - EXTENSION_SHELF_MODEL_CHANGED, - // Sent when a background page is ready so other components can load. EXTENSION_BACKGROUND_PAGE_READY, diff --git a/chrome/common/pref_names.cc b/chrome/common/pref_names.cc index 7eab2f9..01f3a6a2 100644 --- a/chrome/common/pref_names.cc +++ b/chrome/common/pref_names.cc @@ -808,9 +808,6 @@ const char kDisableVideoAndChat[] = "disable_video_chat"; // Whether Extensions are enabled. const char kDisableExtensions[] = "extensions.disabled"; -// Boolean which specifies whether the Extension Shelf is visible on all tabs. -const char kShowExtensionShelf[] = "extensions.shelf.show_on_all_tabs"; - // Integer boolean representing the width (in pixels) of the container for // browser actions. const char kBrowserActionContainerWidth[] = diff --git a/chrome/common/pref_names.h b/chrome/common/pref_names.h index 2fa8b7b..21d44db 100644 --- a/chrome/common/pref_names.h +++ b/chrome/common/pref_names.h @@ -298,7 +298,6 @@ extern const char kNumKeywords[]; extern const char kDisableVideoAndChat[]; extern const char kDisableExtensions[]; -extern const char kShowExtensionShelf[]; extern const char kBrowserActionContainerWidth[]; extern const char kLastExtensionsUpdateCheck[]; diff --git a/chrome/common/view_types.cc b/chrome/common/view_types.cc index c32174b..73c604f 100644 --- a/chrome/common/view_types.cc +++ b/chrome/common/view_types.cc @@ -5,8 +5,6 @@ #include "chrome/common/view_types.h" const char* ViewType::kTabContents = "TAB"; -const char* ViewType::kToolstrip = "TOOLSTRIP"; -const char* ViewType::kMole = "MOLE"; const char* ViewType::kBackgroundPage = "BACKGROUND"; const char* ViewType::kPopup = "POPUP"; const char* ViewType::kInfobar = "INFOBAR"; diff --git a/chrome/common/view_types.h b/chrome/common/view_types.h index 2947a29..2d9c539 100644 --- a/chrome/common/view_types.h +++ b/chrome/common/view_types.h @@ -15,8 +15,6 @@ class ViewType { INVALID, BACKGROUND_CONTENTS, TAB_CONTENTS, - EXTENSION_TOOLSTRIP, - EXTENSION_MOLE, EXTENSION_BACKGROUND_PAGE, EXTENSION_POPUP, EXTENSION_INFOBAR, @@ -28,8 +26,6 @@ class ViewType { // Constant strings corresponding to the Type enumeration values. Used // when converting JS arguments. static const char* kTabContents; - static const char* kToolstrip; - static const char* kMole; static const char* kBackgroundPage; static const char* kPopup; static const char* kInfobar; diff --git a/chrome/renderer/extensions/extension_process_bindings.cc b/chrome/renderer/extensions/extension_process_bindings.cc index 8057e67..1a97872 100644 --- a/chrome/renderer/extensions/extension_process_bindings.cc +++ b/chrome/renderer/extensions/extension_process_bindings.cc @@ -1,732 +1,700 @@ -// 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. - -#include "chrome/renderer/extensions/extension_process_bindings.h" - -#include <map> -#include <set> -#include <string> -#include <vector> - -#include "base/command_line.h" -#include "base/json/json_reader.h" -#include "base/scoped_ptr.h" -#include "base/singleton.h" -#include "base/string_util.h" -#include "chrome/common/chrome_switches.h" -#include "chrome/common/extensions/extension.h" -#include "chrome/common/extensions/extension_constants.h" -#include "chrome/common/extensions/url_pattern.h" -#include "chrome/common/render_messages.h" -#include "chrome/common/url_constants.h" -#include "chrome/renderer/extensions/bindings_utils.h" -#include "chrome/renderer/extensions/event_bindings.h" -#include "chrome/renderer/extensions/js_only_v8_extensions.h" -#include "chrome/renderer/extensions/renderer_extension_bindings.h" -#include "chrome/renderer/user_script_slave.h" -#include "chrome/renderer/render_thread.h" -#include "chrome/renderer/render_view.h" -#include "chrome/renderer/render_view_visitor.h" -#include "grit/common_resources.h" -#include "grit/renderer_resources.h" -#include "third_party/skia/include/core/SkBitmap.h" -#include "third_party/skia/include/core/SkColor.h" -#include "third_party/WebKit/WebKit/chromium/public/WebFrame.h" -#include "third_party/WebKit/WebKit/chromium/public/WebURL.h" -#include "third_party/WebKit/WebKit/chromium/public/WebKit.h" -#include "third_party/WebKit/WebKit/chromium/public/WebSecurityPolicy.h" -#include "third_party/WebKit/WebKit/chromium/public/WebView.h" - -using bindings_utils::GetStringResource; -using bindings_utils::ContextInfo; -using bindings_utils::ContextList; -using bindings_utils::GetContexts; -using bindings_utils::GetPendingRequestMap; -using bindings_utils::PendingRequest; -using bindings_utils::PendingRequestMap; -using bindings_utils::ExtensionBase; -using WebKit::WebFrame; -using WebKit::WebSecurityPolicy; -using WebKit::WebView; - -namespace { - -// A map of extension ID to vector of page action ids. -typedef std::map< std::string, std::vector<std::string> > PageActionIdMap; - -// A map of permission name to whether its enabled for this extension. -typedef std::map<std::string, bool> PermissionsMap; - -// A map of extension ID to permissions map. -typedef std::map<std::string, PermissionsMap> ExtensionPermissionsMap; - -// A map of extension ID to whether this extension was enabled in incognito. -typedef std::map<std::string, bool> IncognitoEnabledMap; - -const char kExtensionName[] = "chrome/ExtensionProcessBindings"; -const char* kExtensionDeps[] = { - BaseJsV8Extension::kName, - EventBindings::kName, - JsonSchemaJsV8Extension::kName, - RendererExtensionBindings::kName, - ExtensionApiTestV8Extension::kName, -}; - -// A list of the API packages which have no associated permission. -// TODO(erikkay) It might be nice if for consistency we could merge these with -// the permissions list, or at least have them in one place. -const char* kNonPermissionExtensionPackages[] = { - "extension", - // TODO(erikkay): We're inconsistent about the the package name in the events - // for pageAction and browserAction. - "pageAction", - "pageActions", - "browserAction", - "browserActions", - "i18n", - "devtools", - "test" -}; - -struct SingletonData { - std::set<std::string> function_names_; - PageActionIdMap page_action_ids_; - ExtensionPermissionsMap permissions_; - IncognitoEnabledMap incognito_enabled_map_; -}; - -static std::set<std::string>* GetFunctionNameSet() { - return &Singleton<SingletonData>()->function_names_; -} - -static PageActionIdMap* GetPageActionMap() { - return &Singleton<SingletonData>()->page_action_ids_; -} - -static PermissionsMap* GetPermissionsMap(const std::string& extension_id) { - return &Singleton<SingletonData>()->permissions_[extension_id]; -} - -static IncognitoEnabledMap* GetIncognitoEnabledMap() { - return &Singleton<SingletonData>()->incognito_enabled_map_; -} - -static void GetActiveExtensionIDs(std::set<std::string>* extension_ids) { - ExtensionPermissionsMap& permissions = - Singleton<SingletonData>()->permissions_; - - for (ExtensionPermissionsMap::iterator iter = permissions.begin(); - iter != permissions.end(); ++iter) { - extension_ids->insert(iter->first); - } -} - -// A RenderViewVisitor class that iterates through the set of available -// views, looking for a view of the given type, in the given browser window -// and within the given extension. -// Used to accumulate the list of views associated with an extension. -class ExtensionViewAccumulator : public RenderViewVisitor { - public: - ExtensionViewAccumulator(const std::string& extension_id, - int browser_window_id, - ViewType::Type view_type) - : extension_id_(extension_id), - browser_window_id_(browser_window_id), - view_type_(view_type), - views_(v8::Array::New()), - index_(0) { - } - - v8::Local<v8::Array> views() { return views_; } - - virtual bool Visit(RenderView* render_view) { - if (!ViewTypeMatches(render_view->view_type(), view_type_)) - return true; - - GURL url = render_view->webview()->mainFrame()->url(); - if (!url.SchemeIs(chrome::kExtensionScheme)) - return true; - const std::string& extension_id = url.host(); - if (extension_id != extension_id_) - return true; - - // If we are searching for a pop-up, it may be the case that the pop-up - // is not attached to a browser window instance. (It is hosted in a - // ExternalTabContainer.) If so, then bypass validation of - // same-browser-window origin. - // TODO(twiz): The browser window id of the views visited should always - // match that of the arguments to the accumulator. - // See bug: http://crbug.com/29646 - if (!(view_type_ == ViewType::EXTENSION_POPUP && - render_view->browser_window_id() == - extension_misc::kUnknownWindowId)) { - if (browser_window_id_ != extension_misc::kUnknownWindowId && - render_view->browser_window_id() != browser_window_id_) { - return true; - } - } - - v8::Local<v8::Context> context = - render_view->webview()->mainFrame()->mainWorldScriptContext(); - if (!context.IsEmpty()) { - v8::Local<v8::Value> window = context->Global(); - DCHECK(!window.IsEmpty()); - - if (!OnMatchedView(window)) - return false; - } - return true; - } - - private: - // Called on each view found matching the search criteria. Returns false - // to terminate the iteration. - bool OnMatchedView(const v8::Local<v8::Value>& view_window) { - views_->Set(v8::Integer::New(index_), view_window); - index_++; - - if (view_type_ == ViewType::EXTENSION_BACKGROUND_PAGE) - return false; // There can be only one... - - return true; - } - - // Returns true is |type| "isa" |match|. - static bool ViewTypeMatches(ViewType::Type type, ViewType::Type match) { - if (type == match) - return true; - - // INVALID means match all. - if (match == ViewType::INVALID) - return true; - - // TODO(erikkay) for now, special case mole as a type of toolstrip. - // Perhaps this isn't the right long-term thing to do. - if (match == ViewType::EXTENSION_TOOLSTRIP && - type == ViewType::EXTENSION_MOLE) { - return true; - } - - return false; - } - - std::string extension_id_; - int browser_window_id_; - ViewType::Type view_type_; - v8::Local<v8::Array> views_; - int index_; -}; - -class ExtensionImpl : public ExtensionBase { - public: - ExtensionImpl() : ExtensionBase( - kExtensionName, GetStringResource<IDR_EXTENSION_PROCESS_BINDINGS_JS>(), - arraysize(kExtensionDeps), kExtensionDeps) {} - - static void SetFunctionNames(const std::vector<std::string>& names) { - std::set<std::string>* name_set = GetFunctionNameSet(); - for (size_t i = 0; i < names.size(); ++i) { - name_set->insert(names[i]); - } - } - - // Note: do not call this function before or during the chromeHidden.onLoad - // event dispatch. The URL might not have been committed yet and might not - // be an extension URL. - static std::string ExtensionIdForCurrentContext() { - RenderView* renderview = bindings_utils::GetRenderViewForCurrentContext(); - if (!renderview) - return std::string(); // this can happen as a tab is closing. - - GURL url = renderview->webview()->mainFrame()->url(); - if (!url.SchemeIs(chrome::kExtensionScheme)) - return std::string(); - - return url.host(); - } - - virtual v8::Handle<v8::FunctionTemplate> GetNativeFunction( - v8::Handle<v8::String> name) { - if (name->Equals(v8::String::New("GetExtensionAPIDefinition"))) { - return v8::FunctionTemplate::New(GetExtensionAPIDefinition); - } else if (name->Equals(v8::String::New("GetExtensionViews"))) { - return v8::FunctionTemplate::New(GetExtensionViews); - } else if (name->Equals(v8::String::New("GetNextRequestId"))) { - return v8::FunctionTemplate::New(GetNextRequestId); - } else if (name->Equals(v8::String::New("OpenChannelToTab"))) { - return v8::FunctionTemplate::New(OpenChannelToTab); - } else if (name->Equals(v8::String::New("GetCurrentPageActions"))) { - return v8::FunctionTemplate::New(GetCurrentPageActions); - } else if (name->Equals(v8::String::New("StartRequest"))) { - return v8::FunctionTemplate::New(StartRequest); - } else if (name->Equals(v8::String::New("GetRenderViewId"))) { - return v8::FunctionTemplate::New(GetRenderViewId); - } else if (name->Equals(v8::String::New("GetPopupView"))) { - return v8::FunctionTemplate::New(GetPopupView); - } else if (name->Equals(v8::String::New("GetPopupParentWindow"))) { - return v8::FunctionTemplate::New(GetPopupParentWindow); - } else if (name->Equals(v8::String::New("SetExtensionActionIcon"))) { - return v8::FunctionTemplate::New(SetExtensionActionIcon); - } else if (name->Equals(v8::String::New("IsExtensionProcess"))) { - return v8::FunctionTemplate::New(IsExtensionProcess); - } - - return ExtensionBase::GetNativeFunction(name); - } - - private: - static v8::Handle<v8::Value> GetExtensionAPIDefinition( - const v8::Arguments& args) { - return v8::String::New(GetStringResource<IDR_EXTENSION_API_JSON>()); - } - - static v8::Handle<v8::Value> PopupViewFinder( - const v8::Arguments& args, - ViewType::Type viewtype_to_find) { - // TODO(twiz) Correct the logic that ties the ownership of the pop-up view - // to the hosting view. At the moment we assume that there may only be - // a single pop-up view for a given extension. By doing so, we can find - // the pop-up view by simply searching for the only pop-up view present. - // We also assume that if the current view is a pop-up, we can find the - // hosting view by searching for a TOOLSTRIP view. - if (args.Length() != 0) - return v8::Undefined(); - - if (viewtype_to_find != ViewType::EXTENSION_POPUP && - viewtype_to_find != ViewType::EXTENSION_TOOLSTRIP) { - NOTREACHED() << "Requesting invalid view type."; - } - - // Disallow searching for a host view if we are a popup view, and likewise - // if we are a toolstrip view. - RenderView* render_view = bindings_utils::GetRenderViewForCurrentContext(); - if (!render_view || - render_view->view_type() == viewtype_to_find) { - return v8::Undefined(); - } - - int browser_window_id = render_view->browser_window_id(); - std::string extension_id = ExtensionIdForCurrentContext(); - if (extension_id.empty()) - return v8::Undefined(); - - ExtensionViewAccumulator popup_matcher(extension_id, - browser_window_id, - viewtype_to_find); - RenderView::ForEach(&popup_matcher); - - if (0 == popup_matcher.views()->Length()) - return v8::Undefined(); - DCHECK(1 == popup_matcher.views()->Length()); - - // Return the first view found. - return popup_matcher.views()->Get(v8::Integer::New(0)); - } - - static v8::Handle<v8::Value> GetPopupView(const v8::Arguments& args) { - return PopupViewFinder(args, ViewType::EXTENSION_POPUP); - } - - static v8::Handle<v8::Value> GetPopupParentWindow(const v8::Arguments& args) { - return PopupViewFinder(args, ViewType::EXTENSION_TOOLSTRIP); - } - - static v8::Handle<v8::Value> GetExtensionViews(const v8::Arguments& args) { - if (args.Length() != 2) - return v8::Undefined(); - - if (!args[0]->IsInt32() || !args[1]->IsString()) - return v8::Undefined(); - - // |browser_window_id| == extension_misc::kUnknownWindowId means getting - // views attached to any browser window. - int browser_window_id = args[0]->Int32Value(); - - std::string view_type_string = *v8::String::Utf8Value(args[1]->ToString()); - StringToUpperASCII(&view_type_string); - // |view_type| == ViewType::INVALID means getting any type of views. - ViewType::Type view_type = ViewType::INVALID; - if (view_type_string == ViewType::kToolstrip) { - view_type = ViewType::EXTENSION_TOOLSTRIP; - } else if (view_type_string == ViewType::kMole) { - view_type = ViewType::EXTENSION_MOLE; - } else if (view_type_string == ViewType::kBackgroundPage) { - view_type = ViewType::EXTENSION_BACKGROUND_PAGE; - } else if (view_type_string == ViewType::kInfobar) { - view_type = ViewType::EXTENSION_INFOBAR; - } else if (view_type_string == ViewType::kNotification) { - view_type = ViewType::NOTIFICATION; - } else if (view_type_string == ViewType::kTabContents) { - view_type = ViewType::TAB_CONTENTS; - } else if (view_type_string == ViewType::kPopup) { - view_type = ViewType::EXTENSION_POPUP; - } else if (view_type_string != ViewType::kAll) { - return v8::Undefined(); - } - - std::string extension_id = ExtensionIdForCurrentContext(); - if (extension_id.empty()) - return v8::Undefined(); - - ExtensionViewAccumulator accumulator(extension_id, browser_window_id, - view_type); - RenderView::ForEach(&accumulator); - return accumulator.views(); - } - - static v8::Handle<v8::Value> GetNextRequestId(const v8::Arguments& args) { - static int next_request_id = 0; - return v8::Integer::New(next_request_id++); - } - - // Creates a new messaging channel to the tab with the given ID. - static v8::Handle<v8::Value> OpenChannelToTab(const v8::Arguments& args) { - // Get the current RenderView so that we can send a routed IPC message from - // the correct source. - RenderView* renderview = bindings_utils::GetRenderViewForCurrentContext(); - if (!renderview) - return v8::Undefined(); - - if (args.Length() >= 3 && args[0]->IsInt32() && args[1]->IsString() && - args[2]->IsString()) { - int tab_id = args[0]->Int32Value(); - std::string extension_id = *v8::String::Utf8Value(args[1]->ToString()); - std::string channel_name = *v8::String::Utf8Value(args[2]->ToString()); - int port_id = -1; - renderview->Send(new ViewHostMsg_OpenChannelToTab( - renderview->routing_id(), tab_id, extension_id, channel_name, - &port_id)); - return v8::Integer::New(port_id); - } - return v8::Undefined(); - } - - static v8::Handle<v8::Value> GetCurrentPageActions( - const v8::Arguments& args) { - std::string extension_id = *v8::String::Utf8Value(args[0]->ToString()); - PageActionIdMap* page_action_map = GetPageActionMap(); - PageActionIdMap::const_iterator it = page_action_map->find(extension_id); - - std::vector<std::string> page_actions; - size_t size = 0; - if (it != page_action_map->end()) { - page_actions = it->second; - size = page_actions.size(); - } - - v8::Local<v8::Array> page_action_vector = v8::Array::New(size); - for (size_t i = 0; i < size; ++i) { - std::string page_action_id = page_actions[i]; - page_action_vector->Set(v8::Integer::New(i), - v8::String::New(page_action_id.c_str())); - } - - return page_action_vector; - } - - // Common code for starting an API request to the browser. |value_args| - // contains the request's arguments. - static v8::Handle<v8::Value> StartRequestCommon( - const v8::Arguments& args, const ListValue& value_args) { - // Get the current RenderView so that we can send a routed IPC message from - // the correct source. - RenderView* renderview = bindings_utils::GetRenderViewForCurrentContext(); - if (!renderview) - return v8::Undefined(); - - std::string name = *v8::String::AsciiValue(args[0]); - if (GetFunctionNameSet()->find(name) == GetFunctionNameSet()->end()) { - NOTREACHED() << "Unexpected function " << name; - return v8::Undefined(); - } - - if (!ExtensionProcessBindings::CurrentContextHasPermission(name)) { - return ExtensionProcessBindings::ThrowPermissionDeniedException(name); - } - - GURL source_url; - WebFrame* webframe = WebFrame::frameForCurrentContext(); - if (webframe) - source_url = webframe->url(); - - int request_id = args[2]->Int32Value(); - bool has_callback = args[3]->BooleanValue(); - - v8::Persistent<v8::Context> current_context = - v8::Persistent<v8::Context>::New(v8::Context::GetCurrent()); - DCHECK(!current_context.IsEmpty()); - GetPendingRequestMap()[request_id].reset(new PendingRequest( - current_context, name)); - - renderview->SendExtensionRequest(name, value_args, source_url, - request_id, has_callback); - - return v8::Undefined(); - } - - // Starts an API request to the browser, with an optional callback. The - // callback will be dispatched to EventBindings::HandleResponse. - static v8::Handle<v8::Value> StartRequest(const v8::Arguments& args) { - std::string str_args = *v8::String::Utf8Value(args[1]); - base::JSONReader reader; - scoped_ptr<Value> value_args; - value_args.reset(reader.JsonToValue(str_args, false, false)); - - // Since we do the serialization in the v8 extension, we should always get - // valid JSON. - if (!value_args.get() || !value_args->IsType(Value::TYPE_LIST)) { - NOTREACHED() << "Invalid JSON passed to StartRequest."; - return v8::Undefined(); - } - - return StartRequestCommon(args, static_cast<const ListValue&>( - *value_args.get())); - } - - // A special request for setting the extension action icon. This function - // accepts a canvas ImageData object, so it needs to do extra processing - // before sending the request to the browser. - static v8::Handle<v8::Value> SetExtensionActionIcon( - const v8::Arguments& args) { - v8::Local<v8::Object> extension_args = args[1]->ToObject(); - v8::Local<v8::Object> details = - extension_args->Get(v8::String::New("0"))->ToObject(); - v8::Local<v8::Object> image_data = - details->Get(v8::String::New("imageData"))->ToObject(); - v8::Local<v8::Object> data = - image_data->Get(v8::String::New("data"))->ToObject(); - int width = image_data->Get(v8::String::New("width"))->Int32Value(); - int height = image_data->Get(v8::String::New("height"))->Int32Value(); - - int data_length = data->Get(v8::String::New("length"))->Int32Value(); - if (data_length != 4 * width * height) { - NOTREACHED() << "Invalid argument to setIcon. Expecting ImageData."; - return v8::Undefined(); - } - - SkBitmap bitmap; - bitmap.setConfig(SkBitmap::kARGB_8888_Config, width, height); - bitmap.allocPixels(); - bitmap.eraseARGB(0, 0, 0, 0); - - uint32_t* pixels = bitmap.getAddr32(0, 0); - for (int t = 0; t < width*height; t++) { - // |data| is RGBA, pixels is ARGB. - pixels[t] = SkPreMultiplyColor( - ((data->Get(v8::Integer::New(4*t + 3))->Int32Value() & 0xFF) << 24) | - ((data->Get(v8::Integer::New(4*t + 0))->Int32Value() & 0xFF) << 16) | - ((data->Get(v8::Integer::New(4*t + 1))->Int32Value() & 0xFF) << 8) | - ((data->Get(v8::Integer::New(4*t + 2))->Int32Value() & 0xFF) << 0)); - } - - // Construct the Value object. - IPC::Message bitmap_pickle; - IPC::WriteParam(&bitmap_pickle, bitmap); - Value* bitmap_value = BinaryValue::CreateWithCopiedBuffer( - static_cast<const char*>(bitmap_pickle.data()), bitmap_pickle.size()); - - DictionaryValue* dict = new DictionaryValue(); - dict->Set("imageData", bitmap_value); - - if (details->Has(v8::String::New("tabId"))) { - dict->SetInteger("tabId", - details->Get(v8::String::New("tabId"))->Int32Value()); - } - - ListValue list_value; - list_value.Append(dict); - - return StartRequestCommon(args, list_value); - } - - static v8::Handle<v8::Value> GetRenderViewId(const v8::Arguments& args) { - RenderView* renderview = bindings_utils::GetRenderViewForCurrentContext(); - if (!renderview) - return v8::Undefined(); - return v8::Integer::New(renderview->routing_id()); - } - - static v8::Handle<v8::Value> IsExtensionProcess(const v8::Arguments& args) { - bool retval = false; - if (EventBindings::GetRenderThread()) - retval = EventBindings::GetRenderThread()->IsExtensionProcess(); - return v8::Boolean::New(retval); - } -}; - -} // namespace - -v8::Extension* ExtensionProcessBindings::Get() { - static v8::Extension* extension = new ExtensionImpl(); - return extension; -} - -void ExtensionProcessBindings::GetActiveExtensions( - std::set<std::string>* extension_ids) { - GetActiveExtensionIDs(extension_ids); -} - -void ExtensionProcessBindings::SetFunctionNames( - const std::vector<std::string>& names) { - ExtensionImpl::SetFunctionNames(names); -} - -void ExtensionProcessBindings::SetIncognitoEnabled( - const std::string& extension_id, bool enabled) { - (*GetIncognitoEnabledMap())[extension_id] = enabled; -} - -// static -bool ExtensionProcessBindings::HasIncognitoEnabled( - const std::string& extension_id) { - return (!extension_id.empty() && (*GetIncognitoEnabledMap())[extension_id]); -} - -// static -void ExtensionProcessBindings::HandleResponse(int request_id, bool success, - const std::string& response, - const std::string& error) { - PendingRequestMap& pending_requests = GetPendingRequestMap(); - PendingRequestMap::iterator request = pending_requests.find(request_id); - if (request == pending_requests.end()) - return; // The frame went away. - - v8::HandleScope handle_scope; - v8::Handle<v8::Value> argv[5]; - argv[0] = v8::Integer::New(request_id); - argv[1] = v8::String::New(request->second->name.c_str()); - argv[2] = v8::Boolean::New(success); - argv[3] = v8::String::New(response.c_str()); - argv[4] = v8::String::New(error.c_str()); - v8::Handle<v8::Value> retval = bindings_utils::CallFunctionInContext( - request->second->context, "handleResponse", arraysize(argv), argv); - // In debug, the js will validate the callback parameters and return a - // string if a validation error has occured. -#ifdef _DEBUG - if (!retval.IsEmpty() && !retval->IsUndefined()) { - std::string error = *v8::String::AsciiValue(retval); - DCHECK(false) << error; - } -#endif - - request->second->context.Dispose(); - request->second->context.Clear(); - pending_requests.erase(request); -} - -// static -void ExtensionProcessBindings::SetPageActions( - const std::string& extension_id, - const std::vector<std::string>& page_actions) { - PageActionIdMap& page_action_map = *GetPageActionMap(); - if (!page_actions.empty()) { - page_action_map[extension_id] = page_actions; - } else { - if (page_action_map.find(extension_id) != page_action_map.end()) - page_action_map.erase(extension_id); - } -} - -// static -void ExtensionProcessBindings::SetAPIPermissions( - const std::string& extension_id, - const std::vector<std::string>& permissions) { - PermissionsMap& permissions_map = *GetPermissionsMap(extension_id); - - // Default all the API permissions to off. We will reset them below. - for (size_t i = 0; i < Extension::kNumPermissions; ++i) - permissions_map[Extension::kPermissionNames[i]] = false; - for (size_t i = 0; i < permissions.size(); ++i) - permissions_map[permissions[i]] = true; -} - -// static -void ExtensionProcessBindings::SetHostPermissions( - const GURL& extension_url, - const std::vector<URLPattern>& permissions) { - for (size_t i = 0; i < permissions.size(); ++i) { - const char* schemes[] = { - chrome::kHttpScheme, - chrome::kHttpsScheme, - chrome::kFileScheme, - chrome::kChromeUIScheme, - }; - for (size_t j = 0; j < arraysize(schemes); ++j) { - if (permissions[i].MatchesScheme(schemes[j])) { - WebSecurityPolicy::addOriginAccessWhitelistEntry( - extension_url, - WebKit::WebString::fromUTF8(schemes[j]), - WebKit::WebString::fromUTF8(permissions[i].host()), - permissions[i].match_subdomains()); - } - } - } -} - -// static -bool ExtensionProcessBindings::CurrentContextHasPermission( - const std::string& function_name) { - std::string extension_id = ExtensionImpl::ExtensionIdForCurrentContext(); - return HasPermission(extension_id, function_name); -} - -// static -bool ExtensionProcessBindings::HasPermission(const std::string& extension_id, - const std::string& permission) { - std::string permission_name = permission; - - // See if this is a function or event name first and strip out the package. - // Functions will be of the form package.function - // Events will be of the form package/id or package.optional.stuff - size_t separator = permission.find_first_of("./"); - if (separator != std::string::npos) - permission_name = permission.substr(0, separator); - - // windows and tabs are the same permission. - if (permission_name == "windows") - permission_name = Extension::kTabPermission; - - for (size_t i = 0; i < arraysize(kNonPermissionExtensionPackages); ++i) - if (permission_name == kNonPermissionExtensionPackages[i]) - return true; - - PermissionsMap& permissions_map = *GetPermissionsMap(extension_id); - PermissionsMap::iterator it = permissions_map.find(permission_name); - return (it != permissions_map.end() && it->second); -} - -// static -v8::Handle<v8::Value> - ExtensionProcessBindings::ThrowPermissionDeniedException( - const std::string& function_name) { - static const char kMessage[] = - "You do not have permission to use '%s'. Be sure to declare" - " in your manifest what permissions you need."; - std::string error_msg = StringPrintf(kMessage, function_name.c_str()); - - return v8::ThrowException(v8::Exception::Error( - v8::String::New(error_msg.c_str()))); -} - -// static -void ExtensionProcessBindings::SetViewType(WebView* view, - ViewType::Type type) { - DCHECK(type == ViewType::EXTENSION_MOLE || - type == ViewType::EXTENSION_TOOLSTRIP); - const char* type_str; - if (type == ViewType::EXTENSION_MOLE) - type_str = "mole"; - else if (type == ViewType::EXTENSION_TOOLSTRIP) - type_str = "toolstrip"; - else - return; - - v8::HandleScope handle_scope; - WebFrame* frame = view->mainFrame(); - v8::Local<v8::Context> context = frame->mainWorldScriptContext(); - v8::Handle<v8::Value> argv[1]; - argv[0] = v8::String::New(type_str); - bindings_utils::CallFunctionInContext(context, "setViewType", - arraysize(argv), argv); -} +// 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.
+
+#include "chrome/renderer/extensions/extension_process_bindings.h"
+
+#include <map>
+#include <set>
+#include <string>
+#include <vector>
+
+#include "base/command_line.h"
+#include "base/json/json_reader.h"
+#include "base/scoped_ptr.h"
+#include "base/singleton.h"
+#include "base/string_util.h"
+#include "chrome/common/chrome_switches.h"
+#include "chrome/common/extensions/extension.h"
+#include "chrome/common/extensions/extension_constants.h"
+#include "chrome/common/extensions/url_pattern.h"
+#include "chrome/common/render_messages.h"
+#include "chrome/common/url_constants.h"
+#include "chrome/renderer/extensions/bindings_utils.h"
+#include "chrome/renderer/extensions/event_bindings.h"
+#include "chrome/renderer/extensions/js_only_v8_extensions.h"
+#include "chrome/renderer/extensions/renderer_extension_bindings.h"
+#include "chrome/renderer/user_script_slave.h"
+#include "chrome/renderer/render_thread.h"
+#include "chrome/renderer/render_view.h"
+#include "chrome/renderer/render_view_visitor.h"
+#include "grit/common_resources.h"
+#include "grit/renderer_resources.h"
+#include "third_party/skia/include/core/SkBitmap.h"
+#include "third_party/skia/include/core/SkColor.h"
+#include "third_party/WebKit/WebKit/chromium/public/WebFrame.h"
+#include "third_party/WebKit/WebKit/chromium/public/WebURL.h"
+#include "third_party/WebKit/WebKit/chromium/public/WebKit.h"
+#include "third_party/WebKit/WebKit/chromium/public/WebSecurityPolicy.h"
+#include "third_party/WebKit/WebKit/chromium/public/WebView.h"
+
+using bindings_utils::GetStringResource;
+using bindings_utils::ContextInfo;
+using bindings_utils::ContextList;
+using bindings_utils::GetContexts;
+using bindings_utils::GetPendingRequestMap;
+using bindings_utils::PendingRequest;
+using bindings_utils::PendingRequestMap;
+using bindings_utils::ExtensionBase;
+using WebKit::WebFrame;
+using WebKit::WebSecurityPolicy;
+using WebKit::WebView;
+
+namespace {
+
+// A map of extension ID to vector of page action ids.
+typedef std::map< std::string, std::vector<std::string> > PageActionIdMap;
+
+// A map of permission name to whether its enabled for this extension.
+typedef std::map<std::string, bool> PermissionsMap;
+
+// A map of extension ID to permissions map.
+typedef std::map<std::string, PermissionsMap> ExtensionPermissionsMap;
+
+// A map of extension ID to whether this extension was enabled in incognito.
+typedef std::map<std::string, bool> IncognitoEnabledMap;
+
+const char kExtensionName[] = "chrome/ExtensionProcessBindings";
+const char* kExtensionDeps[] = {
+ BaseJsV8Extension::kName,
+ EventBindings::kName,
+ JsonSchemaJsV8Extension::kName,
+ RendererExtensionBindings::kName,
+ ExtensionApiTestV8Extension::kName,
+};
+
+// A list of the API packages which have no associated permission.
+// TODO(erikkay) It might be nice if for consistency we could merge these with
+// the permissions list, or at least have them in one place.
+const char* kNonPermissionExtensionPackages[] = {
+ "extension",
+ // TODO(erikkay): We're inconsistent about the the package name in the events
+ // for pageAction and browserAction.
+ "pageAction",
+ "pageActions",
+ "browserAction",
+ "browserActions",
+ "i18n",
+ "devtools",
+ "test"
+};
+
+struct SingletonData {
+ std::set<std::string> function_names_;
+ PageActionIdMap page_action_ids_;
+ ExtensionPermissionsMap permissions_;
+ IncognitoEnabledMap incognito_enabled_map_;
+};
+
+static std::set<std::string>* GetFunctionNameSet() {
+ return &Singleton<SingletonData>()->function_names_;
+}
+
+static PageActionIdMap* GetPageActionMap() {
+ return &Singleton<SingletonData>()->page_action_ids_;
+}
+
+static PermissionsMap* GetPermissionsMap(const std::string& extension_id) {
+ return &Singleton<SingletonData>()->permissions_[extension_id];
+}
+
+static IncognitoEnabledMap* GetIncognitoEnabledMap() {
+ return &Singleton<SingletonData>()->incognito_enabled_map_;
+}
+
+static void GetActiveExtensionIDs(std::set<std::string>* extension_ids) {
+ ExtensionPermissionsMap& permissions =
+ Singleton<SingletonData>()->permissions_;
+
+ for (ExtensionPermissionsMap::iterator iter = permissions.begin();
+ iter != permissions.end(); ++iter) {
+ extension_ids->insert(iter->first);
+ }
+}
+
+// A RenderViewVisitor class that iterates through the set of available
+// views, looking for a view of the given type, in the given browser window
+// and within the given extension.
+// Used to accumulate the list of views associated with an extension.
+class ExtensionViewAccumulator : public RenderViewVisitor {
+ public:
+ ExtensionViewAccumulator(const std::string& extension_id,
+ int browser_window_id,
+ ViewType::Type view_type)
+ : extension_id_(extension_id),
+ browser_window_id_(browser_window_id),
+ view_type_(view_type),
+ views_(v8::Array::New()),
+ index_(0) {
+ }
+
+ v8::Local<v8::Array> views() { return views_; }
+
+ virtual bool Visit(RenderView* render_view) {
+ if (!ViewTypeMatches(render_view->view_type(), view_type_))
+ return true;
+
+ GURL url = render_view->webview()->mainFrame()->url();
+ if (!url.SchemeIs(chrome::kExtensionScheme))
+ return true;
+ const std::string& extension_id = url.host();
+ if (extension_id != extension_id_)
+ return true;
+
+ // If we are searching for a pop-up, it may be the case that the pop-up
+ // is not attached to a browser window instance. (It is hosted in a
+ // ExternalTabContainer.) If so, then bypass validation of
+ // same-browser-window origin.
+ // TODO(twiz): The browser window id of the views visited should always
+ // match that of the arguments to the accumulator.
+ // See bug: http://crbug.com/29646
+ if (!(view_type_ == ViewType::EXTENSION_POPUP &&
+ render_view->browser_window_id() ==
+ extension_misc::kUnknownWindowId)) {
+ if (browser_window_id_ != extension_misc::kUnknownWindowId &&
+ render_view->browser_window_id() != browser_window_id_) {
+ return true;
+ }
+ }
+
+ v8::Local<v8::Context> context =
+ render_view->webview()->mainFrame()->mainWorldScriptContext();
+ if (!context.IsEmpty()) {
+ v8::Local<v8::Value> window = context->Global();
+ DCHECK(!window.IsEmpty());
+
+ if (!OnMatchedView(window))
+ return false;
+ }
+ return true;
+ }
+
+ private:
+ // Called on each view found matching the search criteria. Returns false
+ // to terminate the iteration.
+ bool OnMatchedView(const v8::Local<v8::Value>& view_window) {
+ views_->Set(v8::Integer::New(index_), view_window);
+ index_++;
+
+ if (view_type_ == ViewType::EXTENSION_BACKGROUND_PAGE)
+ return false; // There can be only one...
+
+ return true;
+ }
+
+ // Returns true is |type| "isa" |match|.
+ static bool ViewTypeMatches(ViewType::Type type, ViewType::Type match) {
+ if (type == match)
+ return true;
+
+ // INVALID means match all.
+ if (match == ViewType::INVALID)
+ return true;
+
+ return false;
+ }
+
+ std::string extension_id_;
+ int browser_window_id_;
+ ViewType::Type view_type_;
+ v8::Local<v8::Array> views_;
+ int index_;
+};
+
+class ExtensionImpl : public ExtensionBase {
+ public:
+ ExtensionImpl() : ExtensionBase(
+ kExtensionName, GetStringResource<IDR_EXTENSION_PROCESS_BINDINGS_JS>(),
+ arraysize(kExtensionDeps), kExtensionDeps) {}
+
+ static void SetFunctionNames(const std::vector<std::string>& names) {
+ std::set<std::string>* name_set = GetFunctionNameSet();
+ for (size_t i = 0; i < names.size(); ++i) {
+ name_set->insert(names[i]);
+ }
+ }
+
+ // Note: do not call this function before or during the chromeHidden.onLoad
+ // event dispatch. The URL might not have been committed yet and might not
+ // be an extension URL.
+ static std::string ExtensionIdForCurrentContext() {
+ RenderView* renderview = bindings_utils::GetRenderViewForCurrentContext();
+ if (!renderview)
+ return std::string(); // this can happen as a tab is closing.
+
+ GURL url = renderview->webview()->mainFrame()->url();
+ if (!url.SchemeIs(chrome::kExtensionScheme))
+ return std::string();
+
+ return url.host();
+ }
+
+ virtual v8::Handle<v8::FunctionTemplate> GetNativeFunction(
+ v8::Handle<v8::String> name) {
+ if (name->Equals(v8::String::New("GetExtensionAPIDefinition"))) {
+ return v8::FunctionTemplate::New(GetExtensionAPIDefinition);
+ } else if (name->Equals(v8::String::New("GetExtensionViews"))) {
+ return v8::FunctionTemplate::New(GetExtensionViews);
+ } else if (name->Equals(v8::String::New("GetNextRequestId"))) {
+ return v8::FunctionTemplate::New(GetNextRequestId);
+ } else if (name->Equals(v8::String::New("OpenChannelToTab"))) {
+ return v8::FunctionTemplate::New(OpenChannelToTab);
+ } else if (name->Equals(v8::String::New("GetCurrentPageActions"))) {
+ return v8::FunctionTemplate::New(GetCurrentPageActions);
+ } else if (name->Equals(v8::String::New("StartRequest"))) {
+ return v8::FunctionTemplate::New(StartRequest);
+ } else if (name->Equals(v8::String::New("GetRenderViewId"))) {
+ return v8::FunctionTemplate::New(GetRenderViewId);
+ } else if (name->Equals(v8::String::New("GetPopupView"))) {
+ return v8::FunctionTemplate::New(GetPopupView);
+ } else if (name->Equals(v8::String::New("GetPopupParentWindow"))) {
+ return v8::FunctionTemplate::New(GetPopupParentWindow);
+ } else if (name->Equals(v8::String::New("SetExtensionActionIcon"))) {
+ return v8::FunctionTemplate::New(SetExtensionActionIcon);
+ } else if (name->Equals(v8::String::New("IsExtensionProcess"))) {
+ return v8::FunctionTemplate::New(IsExtensionProcess);
+ }
+
+ return ExtensionBase::GetNativeFunction(name);
+ }
+
+ private:
+ static v8::Handle<v8::Value> GetExtensionAPIDefinition(
+ const v8::Arguments& args) {
+ return v8::String::New(GetStringResource<IDR_EXTENSION_API_JSON>());
+ }
+
+ static v8::Handle<v8::Value> PopupViewFinder(
+ const v8::Arguments& args,
+ ViewType::Type viewtype_to_find) {
+ // TODO(twiz) Correct the logic that ties the ownership of the pop-up view
+ // to the hosting view. At the moment we assume that there may only be
+ // a single pop-up view for a given extension. By doing so, we can find
+ // the pop-up view by simply searching for the only pop-up view present.
+ // We also assume that if the current view is a pop-up, we can find the
+ // hosting view by searching for a tab contents view.
+ if (args.Length() != 0)
+ return v8::Undefined();
+
+ if (viewtype_to_find != ViewType::EXTENSION_POPUP &&
+ viewtype_to_find != ViewType::TAB_CONTENTS) {
+ NOTREACHED() << "Requesting invalid view type.";
+ }
+
+ // Disallow searching for the same view type as the current view:
+ // Popups can only look for hosts, and hosts can only look for popups.
+ RenderView* render_view = bindings_utils::GetRenderViewForCurrentContext();
+ if (!render_view ||
+ render_view->view_type() == viewtype_to_find) {
+ return v8::Undefined();
+ }
+
+ int browser_window_id = render_view->browser_window_id();
+ std::string extension_id = ExtensionIdForCurrentContext();
+ if (extension_id.empty())
+ return v8::Undefined();
+
+ ExtensionViewAccumulator popup_matcher(extension_id,
+ browser_window_id,
+ viewtype_to_find);
+ RenderView::ForEach(&popup_matcher);
+
+ if (0 == popup_matcher.views()->Length())
+ return v8::Undefined();
+ DCHECK(1 == popup_matcher.views()->Length());
+
+ // Return the first view found.
+ return popup_matcher.views()->Get(v8::Integer::New(0));
+ }
+
+ static v8::Handle<v8::Value> GetPopupView(const v8::Arguments& args) {
+ return PopupViewFinder(args, ViewType::EXTENSION_POPUP);
+ }
+
+ static v8::Handle<v8::Value> GetPopupParentWindow(const v8::Arguments& args) {
+ return PopupViewFinder(args, ViewType::TAB_CONTENTS);
+ }
+
+ static v8::Handle<v8::Value> GetExtensionViews(const v8::Arguments& args) {
+ if (args.Length() != 2)
+ return v8::Undefined();
+
+ if (!args[0]->IsInt32() || !args[1]->IsString())
+ return v8::Undefined();
+
+ // |browser_window_id| == extension_misc::kUnknownWindowId means getting
+ // views attached to any browser window.
+ int browser_window_id = args[0]->Int32Value();
+
+ std::string view_type_string = *v8::String::Utf8Value(args[1]->ToString());
+ StringToUpperASCII(&view_type_string);
+ // |view_type| == ViewType::INVALID means getting any type of views.
+ ViewType::Type view_type = ViewType::INVALID;
+ if (view_type_string == ViewType::kBackgroundPage) {
+ view_type = ViewType::EXTENSION_BACKGROUND_PAGE;
+ } else if (view_type_string == ViewType::kInfobar) {
+ view_type = ViewType::EXTENSION_INFOBAR;
+ } else if (view_type_string == ViewType::kNotification) {
+ view_type = ViewType::NOTIFICATION;
+ } else if (view_type_string == ViewType::kTabContents) {
+ view_type = ViewType::TAB_CONTENTS;
+ } else if (view_type_string == ViewType::kPopup) {
+ view_type = ViewType::EXTENSION_POPUP;
+ } else if (view_type_string != ViewType::kAll) {
+ return v8::Undefined();
+ }
+
+ std::string extension_id = ExtensionIdForCurrentContext();
+ if (extension_id.empty())
+ return v8::Undefined();
+
+ ExtensionViewAccumulator accumulator(extension_id, browser_window_id,
+ view_type);
+ RenderView::ForEach(&accumulator);
+ return accumulator.views();
+ }
+
+ static v8::Handle<v8::Value> GetNextRequestId(const v8::Arguments& args) {
+ static int next_request_id = 0;
+ return v8::Integer::New(next_request_id++);
+ }
+
+ // Creates a new messaging channel to the tab with the given ID.
+ static v8::Handle<v8::Value> OpenChannelToTab(const v8::Arguments& args) {
+ // Get the current RenderView so that we can send a routed IPC message from
+ // the correct source.
+ RenderView* renderview = bindings_utils::GetRenderViewForCurrentContext();
+ if (!renderview)
+ return v8::Undefined();
+
+ if (args.Length() >= 3 && args[0]->IsInt32() && args[1]->IsString() &&
+ args[2]->IsString()) {
+ int tab_id = args[0]->Int32Value();
+ std::string extension_id = *v8::String::Utf8Value(args[1]->ToString());
+ std::string channel_name = *v8::String::Utf8Value(args[2]->ToString());
+ int port_id = -1;
+ renderview->Send(new ViewHostMsg_OpenChannelToTab(
+ renderview->routing_id(), tab_id, extension_id, channel_name,
+ &port_id));
+ return v8::Integer::New(port_id);
+ }
+ return v8::Undefined();
+ }
+
+ static v8::Handle<v8::Value> GetCurrentPageActions(
+ const v8::Arguments& args) {
+ std::string extension_id = *v8::String::Utf8Value(args[0]->ToString());
+ PageActionIdMap* page_action_map = GetPageActionMap();
+ PageActionIdMap::const_iterator it = page_action_map->find(extension_id);
+
+ std::vector<std::string> page_actions;
+ size_t size = 0;
+ if (it != page_action_map->end()) {
+ page_actions = it->second;
+ size = page_actions.size();
+ }
+
+ v8::Local<v8::Array> page_action_vector = v8::Array::New(size);
+ for (size_t i = 0; i < size; ++i) {
+ std::string page_action_id = page_actions[i];
+ page_action_vector->Set(v8::Integer::New(i),
+ v8::String::New(page_action_id.c_str()));
+ }
+
+ return page_action_vector;
+ }
+
+ // Common code for starting an API request to the browser. |value_args|
+ // contains the request's arguments.
+ static v8::Handle<v8::Value> StartRequestCommon(
+ const v8::Arguments& args, const ListValue& value_args) {
+ // Get the current RenderView so that we can send a routed IPC message from
+ // the correct source.
+ RenderView* renderview = bindings_utils::GetRenderViewForCurrentContext();
+ if (!renderview)
+ return v8::Undefined();
+
+ std::string name = *v8::String::AsciiValue(args[0]);
+ if (GetFunctionNameSet()->find(name) == GetFunctionNameSet()->end()) {
+ NOTREACHED() << "Unexpected function " << name;
+ return v8::Undefined();
+ }
+
+ if (!ExtensionProcessBindings::CurrentContextHasPermission(name)) {
+ return ExtensionProcessBindings::ThrowPermissionDeniedException(name);
+ }
+
+ GURL source_url;
+ WebFrame* webframe = WebFrame::frameForCurrentContext();
+ if (webframe)
+ source_url = webframe->url();
+
+ int request_id = args[2]->Int32Value();
+ bool has_callback = args[3]->BooleanValue();
+
+ v8::Persistent<v8::Context> current_context =
+ v8::Persistent<v8::Context>::New(v8::Context::GetCurrent());
+ DCHECK(!current_context.IsEmpty());
+ GetPendingRequestMap()[request_id].reset(new PendingRequest(
+ current_context, name));
+
+ renderview->SendExtensionRequest(name, value_args, source_url,
+ request_id, has_callback);
+
+ return v8::Undefined();
+ }
+
+ // Starts an API request to the browser, with an optional callback. The
+ // callback will be dispatched to EventBindings::HandleResponse.
+ static v8::Handle<v8::Value> StartRequest(const v8::Arguments& args) {
+ std::string str_args = *v8::String::Utf8Value(args[1]);
+ base::JSONReader reader;
+ scoped_ptr<Value> value_args;
+ value_args.reset(reader.JsonToValue(str_args, false, false));
+
+ // Since we do the serialization in the v8 extension, we should always get
+ // valid JSON.
+ if (!value_args.get() || !value_args->IsType(Value::TYPE_LIST)) {
+ NOTREACHED() << "Invalid JSON passed to StartRequest.";
+ return v8::Undefined();
+ }
+
+ return StartRequestCommon(args, static_cast<const ListValue&>(
+ *value_args.get()));
+ }
+
+ // A special request for setting the extension action icon. This function
+ // accepts a canvas ImageData object, so it needs to do extra processing
+ // before sending the request to the browser.
+ static v8::Handle<v8::Value> SetExtensionActionIcon(
+ const v8::Arguments& args) {
+ v8::Local<v8::Object> extension_args = args[1]->ToObject();
+ v8::Local<v8::Object> details =
+ extension_args->Get(v8::String::New("0"))->ToObject();
+ v8::Local<v8::Object> image_data =
+ details->Get(v8::String::New("imageData"))->ToObject();
+ v8::Local<v8::Object> data =
+ image_data->Get(v8::String::New("data"))->ToObject();
+ int width = image_data->Get(v8::String::New("width"))->Int32Value();
+ int height = image_data->Get(v8::String::New("height"))->Int32Value();
+
+ int data_length = data->Get(v8::String::New("length"))->Int32Value();
+ if (data_length != 4 * width * height) {
+ NOTREACHED() << "Invalid argument to setIcon. Expecting ImageData.";
+ return v8::Undefined();
+ }
+
+ SkBitmap bitmap;
+ bitmap.setConfig(SkBitmap::kARGB_8888_Config, width, height);
+ bitmap.allocPixels();
+ bitmap.eraseARGB(0, 0, 0, 0);
+
+ uint32_t* pixels = bitmap.getAddr32(0, 0);
+ for (int t = 0; t < width*height; t++) {
+ // |data| is RGBA, pixels is ARGB.
+ pixels[t] = SkPreMultiplyColor(
+ ((data->Get(v8::Integer::New(4*t + 3))->Int32Value() & 0xFF) << 24) |
+ ((data->Get(v8::Integer::New(4*t + 0))->Int32Value() & 0xFF) << 16) |
+ ((data->Get(v8::Integer::New(4*t + 1))->Int32Value() & 0xFF) << 8) |
+ ((data->Get(v8::Integer::New(4*t + 2))->Int32Value() & 0xFF) << 0));
+ }
+
+ // Construct the Value object.
+ IPC::Message bitmap_pickle;
+ IPC::WriteParam(&bitmap_pickle, bitmap);
+ Value* bitmap_value = BinaryValue::CreateWithCopiedBuffer(
+ static_cast<const char*>(bitmap_pickle.data()), bitmap_pickle.size());
+
+ DictionaryValue* dict = new DictionaryValue();
+ dict->Set("imageData", bitmap_value);
+
+ if (details->Has(v8::String::New("tabId"))) {
+ dict->SetInteger("tabId",
+ details->Get(v8::String::New("tabId"))->Int32Value());
+ }
+
+ ListValue list_value;
+ list_value.Append(dict);
+
+ return StartRequestCommon(args, list_value);
+ }
+
+ static v8::Handle<v8::Value> GetRenderViewId(const v8::Arguments& args) {
+ RenderView* renderview = bindings_utils::GetRenderViewForCurrentContext();
+ if (!renderview)
+ return v8::Undefined();
+ return v8::Integer::New(renderview->routing_id());
+ }
+
+ static v8::Handle<v8::Value> IsExtensionProcess(const v8::Arguments& args) {
+ bool retval = false;
+ if (EventBindings::GetRenderThread())
+ retval = EventBindings::GetRenderThread()->IsExtensionProcess();
+ return v8::Boolean::New(retval);
+ }
+};
+
+} // namespace
+
+v8::Extension* ExtensionProcessBindings::Get() {
+ static v8::Extension* extension = new ExtensionImpl();
+ return extension;
+}
+
+void ExtensionProcessBindings::GetActiveExtensions(
+ std::set<std::string>* extension_ids) {
+ GetActiveExtensionIDs(extension_ids);
+}
+
+void ExtensionProcessBindings::SetFunctionNames(
+ const std::vector<std::string>& names) {
+ ExtensionImpl::SetFunctionNames(names);
+}
+
+void ExtensionProcessBindings::SetIncognitoEnabled(
+ const std::string& extension_id, bool enabled) {
+ (*GetIncognitoEnabledMap())[extension_id] = enabled;
+}
+
+// static
+bool ExtensionProcessBindings::HasIncognitoEnabled(
+ const std::string& extension_id) {
+ return (!extension_id.empty() && (*GetIncognitoEnabledMap())[extension_id]);
+}
+
+// static
+void ExtensionProcessBindings::HandleResponse(int request_id, bool success,
+ const std::string& response,
+ const std::string& error) {
+ PendingRequestMap& pending_requests = GetPendingRequestMap();
+ PendingRequestMap::iterator request = pending_requests.find(request_id);
+ if (request == pending_requests.end())
+ return; // The frame went away.
+
+ v8::HandleScope handle_scope;
+ v8::Handle<v8::Value> argv[5];
+ argv[0] = v8::Integer::New(request_id);
+ argv[1] = v8::String::New(request->second->name.c_str());
+ argv[2] = v8::Boolean::New(success);
+ argv[3] = v8::String::New(response.c_str());
+ argv[4] = v8::String::New(error.c_str());
+ v8::Handle<v8::Value> retval = bindings_utils::CallFunctionInContext(
+ request->second->context, "handleResponse", arraysize(argv), argv);
+ // In debug, the js will validate the callback parameters and return a
+ // string if a validation error has occured.
+#ifdef _DEBUG
+ if (!retval.IsEmpty() && !retval->IsUndefined()) {
+ std::string error = *v8::String::AsciiValue(retval);
+ DCHECK(false) << error;
+ }
+#endif
+
+ request->second->context.Dispose();
+ request->second->context.Clear();
+ pending_requests.erase(request);
+}
+
+// static
+void ExtensionProcessBindings::SetPageActions(
+ const std::string& extension_id,
+ const std::vector<std::string>& page_actions) {
+ PageActionIdMap& page_action_map = *GetPageActionMap();
+ if (!page_actions.empty()) {
+ page_action_map[extension_id] = page_actions;
+ } else {
+ if (page_action_map.find(extension_id) != page_action_map.end())
+ page_action_map.erase(extension_id);
+ }
+}
+
+// static
+void ExtensionProcessBindings::SetAPIPermissions(
+ const std::string& extension_id,
+ const std::vector<std::string>& permissions) {
+ PermissionsMap& permissions_map = *GetPermissionsMap(extension_id);
+
+ // Default all the API permissions to off. We will reset them below.
+ for (size_t i = 0; i < Extension::kNumPermissions; ++i)
+ permissions_map[Extension::kPermissionNames[i]] = false;
+ for (size_t i = 0; i < permissions.size(); ++i)
+ permissions_map[permissions[i]] = true;
+}
+
+// static
+void ExtensionProcessBindings::SetHostPermissions(
+ const GURL& extension_url,
+ const std::vector<URLPattern>& permissions) {
+ for (size_t i = 0; i < permissions.size(); ++i) {
+ const char* schemes[] = {
+ chrome::kHttpScheme,
+ chrome::kHttpsScheme,
+ chrome::kFileScheme,
+ chrome::kChromeUIScheme,
+ };
+ for (size_t j = 0; j < arraysize(schemes); ++j) {
+ if (permissions[i].MatchesScheme(schemes[j])) {
+ WebSecurityPolicy::addOriginAccessWhitelistEntry(
+ extension_url,
+ WebKit::WebString::fromUTF8(schemes[j]),
+ WebKit::WebString::fromUTF8(permissions[i].host()),
+ permissions[i].match_subdomains());
+ }
+ }
+ }
+}
+
+// static
+bool ExtensionProcessBindings::CurrentContextHasPermission(
+ const std::string& function_name) {
+ std::string extension_id = ExtensionImpl::ExtensionIdForCurrentContext();
+ return HasPermission(extension_id, function_name);
+}
+
+// static
+bool ExtensionProcessBindings::HasPermission(const std::string& extension_id,
+ const std::string& permission) {
+ std::string permission_name = permission;
+
+ // See if this is a function or event name first and strip out the package.
+ // Functions will be of the form package.function
+ // Events will be of the form package/id or package.optional.stuff
+ size_t separator = permission.find_first_of("./");
+ if (separator != std::string::npos)
+ permission_name = permission.substr(0, separator);
+
+ // windows and tabs are the same permission.
+ if (permission_name == "windows")
+ permission_name = Extension::kTabPermission;
+
+ for (size_t i = 0; i < arraysize(kNonPermissionExtensionPackages); ++i)
+ if (permission_name == kNonPermissionExtensionPackages[i])
+ return true;
+
+ PermissionsMap& permissions_map = *GetPermissionsMap(extension_id);
+ PermissionsMap::iterator it = permissions_map.find(permission_name);
+ return (it != permissions_map.end() && it->second);
+}
+
+// static
+v8::Handle<v8::Value>
+ ExtensionProcessBindings::ThrowPermissionDeniedException(
+ const std::string& function_name) {
+ static const char kMessage[] =
+ "You do not have permission to use '%s'. Be sure to declare"
+ " in your manifest what permissions you need.";
+ std::string error_msg = StringPrintf(kMessage, function_name.c_str());
+
+ return v8::ThrowException(v8::Exception::Error(
+ v8::String::New(error_msg.c_str())));
+}
+
diff --git a/chrome/renderer/extensions/extension_process_bindings.h b/chrome/renderer/extensions/extension_process_bindings.h index 2710901..d64b4255 100644 --- a/chrome/renderer/extensions/extension_process_bindings.h +++ b/chrome/renderer/extensions/extension_process_bindings.h @@ -71,11 +71,6 @@ class ExtensionProcessBindings { // denied. Must be called with a valid V8 context in scope. static v8::Handle<v8::Value> ThrowPermissionDeniedException( const std::string& function_name); - - // For EXTENSION_* |type| values, adds/replaces a special class name on to - // the document element (e.g. "extension_toolstrip", "extension_mole") so - // that the page can use CSS rules to control its display appropriately. - static void SetViewType(WebKit::WebView* view, ViewType::Type type); }; #endif // CHROME_RENDERER_EXTENSIONS_EXTENSION_PROCESS_BINDINGS_H_ diff --git a/chrome/renderer/render_view.cc b/chrome/renderer/render_view.cc index 919ee4c..768bdcb 100644 --- a/chrome/renderer/render_view.cc +++ b/chrome/renderer/render_view.cc @@ -2954,11 +2954,6 @@ void RenderView::didCreateDocumentElement(WebFrame* frame) { RenderThread::current()->user_script_slave()->InjectScripts( frame, UserScript::DOCUMENT_START); } - if (view_type_ == ViewType::EXTENSION_TOOLSTRIP || - view_type_ == ViewType::EXTENSION_MOLE) { - InjectToolstripCSS(); - ExtensionProcessBindings::SetViewType(webview(), view_type_); - } // Notify the browser about non-blank documents loading in the top frame. GURL url = frame->url(); @@ -4191,15 +4186,6 @@ void RenderView::OnMediaPlayerActionAt(const gfx::Point& location, } void RenderView::OnNotifyRendererViewType(ViewType::Type type) { - // When this is first set, the bindings aren't fully loaded. We only need - // to call through this API after the page has already been loaded. It's - // also called in didCreateDocumentElement to bootstrap. - if (view_type_ != ViewType::INVALID) { - if (type == ViewType::EXTENSION_MOLE || - type == ViewType::EXTENSION_TOOLSTRIP) { - ExtensionProcessBindings::SetViewType(webview(), type); - } - } view_type_ = type; } @@ -4584,17 +4570,6 @@ void RenderView::OnExtensionResponse(int request_id, request_id, success, response, error); } -void RenderView::InjectToolstripCSS() { - if (view_type_ != ViewType::EXTENSION_TOOLSTRIP) - return; - - static const base::StringPiece toolstrip_css( - ResourceBundle::GetSharedInstance().GetRawDataResource( - IDR_EXTENSION_TOOLSTRIP_CSS)); - std::string css = toolstrip_css.as_string(); - InsertCSS(L"", css, "ToolstripDefaultCSS"); -} - void RenderView::OnExtensionMessageInvoke(const std::string& function_name, const ListValue& args, bool requires_incognito_access, diff --git a/chrome/renderer/render_view.h b/chrome/renderer/render_view.h index 53e3d6d..2837f946 100644 --- a/chrome/renderer/render_view.h +++ b/chrome/renderer/render_view.h @@ -925,9 +925,6 @@ class RenderView : public RenderWidget, // Decodes a data: URL image or returns an empty image in case of failure. SkBitmap ImageFromDataUrl(const GURL&) const; - // Inject toolstrip CSS for extension moles and toolstrips. - void InjectToolstripCSS(); - // Inserts a string of CSS in a particular frame. |id| can be specified to // give the CSS style element an id, and (if specified) will replace the // element with the same id. @@ -1156,8 +1153,7 @@ class RenderView : public RenderWidget, // View ---------------------------------------------------------------------- - // Type of view attached with RenderView, it could be INVALID, TAB_CONTENTS, - // EXTENSION_TOOLSTRIP, EXTENSION_BACKGROUND_PAGE, DEV_TOOLS_UI. + // Type of view attached with RenderView. See view_types.h ViewType::Type view_type_; // Id number of browser window which RenderView is attached to. This is used diff --git a/chrome/renderer/renderer_resources.grd b/chrome/renderer/renderer_resources.grd index 295ccac..a084b31 100644 --- a/chrome/renderer/renderer_resources.grd +++ b/chrome/renderer/renderer_resources.grd @@ -18,7 +18,6 @@ without changes to the corresponding grd file. fb9 --> <include name="IDR_EVENT_BINDINGS_JS" file="resources\event_bindings.js" type="BINDATA" /> <include name="IDR_EXTENSION_APITEST_JS" file="resources\extension_apitest.js" type="BINDATA" /> <include name="IDR_EXTENSION_PROCESS_BINDINGS_JS" file="resources\extension_process_bindings.js" type="BINDATA" /> - <include name="IDR_EXTENSION_TOOLSTRIP_CSS" file="resources\extension_toolstrip.css" flattenhtml="true" type="BINDATA" /> <include name="IDR_GREASEMONKEY_API_JS" file="resources\greasemonkey_api.js" type="BINDATA" /> <include name="IDR_JSON_SCHEMA_JS" file="resources\json_schema.js" type="BINDATA" /> <include name="IDR_NET_ERROR_HTML" file="resources\neterror.html" flattenhtml="true" type="BINDATA" /> diff --git a/chrome/renderer/resources/extension_toolstrip.css b/chrome/renderer/resources/extension_toolstrip.css deleted file mode 100644 index f4843c6..0000000 --- a/chrome/renderer/resources/extension_toolstrip.css +++ /dev/null @@ -1,100 +0,0 @@ -/** - * Body styles. This makes the toolstrip layout fit in with the Windows - * bookmarkbar. Note that the background is provided separately, by - * RenderWidget. - */ -body { - display:-webkit-box; - -webkit-box-orient:horizontal; - -webkit-box-align:center; - white-space:nowrap; - overflow: hidden; - margin: 0; - padding:0; - font: menu; - -webkit-user-select:none; - cursor:default; -} - -/** - * This, combined with -webkit-box-align:center on body, makes content inside - * the body tag center itself vertically by default. - */ -body>* { - display:-webkit-box; -} - -/** - * Set display property of <script> and <style> as none explicitly to avoid - * inheriting from <body>. - */ -body>script, -body>style { - display:none; -} - -/** - * Toolstrip Buttons. The following styles make - * <div class="toolstrip-button"><img><span>Woot</span></div> look like the - * bookmarkbar buttons on Windows. - * - * TODO(aa): We may have to come up with a way to modify these slightly on - * different platforms. - * - * TODO(aa): It would be nice if we could use actual <button> tags work here, - * which should work once https://bugs.webkit.org/show_bug.cgi?id=25406 is - * fixed. - */ -div.toolstrip-button { - -webkit-box-orient:horizontal; - -webkit-box-align:center; - -webkit-box-sizing:border-box; - border:7px solid transparent; - font:menu; - background:transparent; - line-height:100%; - height:100%; - padding:0; -} - -div.toolstrip-button>img { - display:-webkit-box; - width:16px; - height:16px; - /** - * We inset the image slightly, so that the button can be shorter - * than would otherwise be possibe with our fat borders. The 5px right border - * just creates the spacing between the icon and the text. - */ - margin:-2px 5px -2px -1px; -} - -div.toolstrip-button>span { - display:-webkit-box; - margin-right:1px; - /** - * Hack: WebKit appears to measure text height slightly differently than we do - * in native code, making us not line up when centering, so we shift ourselves - * up one pixel to match. - */ - margin-top:-1px; -} - -/** - * NOTE: These images were created by pasting src/app/resources/textbutton_* - * into a 15px square 9 grid. If they look funky, check to see if they match - * the bookmark buttons. If they don't, they probably need to be regenerated. - * - * TODO(aa): It would be neat-o if these were generated magically from the - * underlying images. Since the dimensions of the images are arbitrary, though, - * it would be tricky. - */ -div.toolstrip-button:hover { - border-width:7px; - -webkit-border-image:url() 7 round round; -} - -div.toolstrip-button:active { - border-width:7px; - -webkit-border-image:url() 7 round round; -} diff --git a/chrome/test/data/extensions/api_test/README.txt b/chrome/test/data/extensions/api_test/README.txt index a356855..06088f1 100644 --- a/chrome/test/data/extensions/api_test/README.txt +++ b/chrome/test/data/extensions/api_test/README.txt @@ -15,7 +15,7 @@ extension_bookmarks_apitest.cc for an example. (2) Create an extension of in this directory of the same name as the extension that your test referred to ("extension_name" above). This test should load -either a background page or a toolstrip which immediately starts its test. +either a background page which immediately starts its test. (3) In your extension page, call chrome.test.runTests with an array of functions which represent your subtests. Each of these functions will most diff --git a/chrome/test/data/extensions/api_test/toolstrip/folder/relative.html b/chrome/test/data/extensions/api_test/toolstrip/folder/relative.html deleted file mode 100644 index 9be5b62..0000000 --- a/chrome/test/data/extensions/api_test/toolstrip/folder/relative.html +++ /dev/null @@ -1,8 +0,0 @@ -<script>
-/*
-chrome.toolstrip.onExpanded.addListener(function() {
- chrome.test.log("relative expanded");
-});*/
-</script>
-relative
-
diff --git a/chrome/test/data/extensions/api_test/toolstrip/manifest.json b/chrome/test/data/extensions/api_test/toolstrip/manifest.json deleted file mode 100644 index 63b5798..0000000 --- a/chrome/test/data/extensions/api_test/toolstrip/manifest.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "name": "chrome.toolstrip", - "version": "0.1", - "description": "end-to-end browser test for chrome.toolstrip API", - "toolstrips": ["test.html", "test2.html"] -} diff --git a/chrome/test/data/extensions/api_test/toolstrip/test.html b/chrome/test/data/extensions/api_test/toolstrip/test.html deleted file mode 100644 index 985e751..0000000 --- a/chrome/test/data/extensions/api_test/toolstrip/test.html +++ /dev/null @@ -1,42 +0,0 @@ -<script>
-chrome.test.runTests([
- function expand() {
- chrome.test.listenOnce(chrome.toolstrip.onExpanded, function(){});
- chrome.toolstrip.expand({height:200},
- chrome.test.callbackPass(function(){}));
- },
-
- function collapse() {
- chrome.test.listenOnce(chrome.toolstrip.onCollapsed, function(){});
- chrome.toolstrip.collapse({}, chrome.test.callbackPass(function(){}));
- },
-
- /* TODO(mpcomplete): this is failing in part due to bug 21905
- function expandOther() {
- var orig = window.location;
- var relative = "folder/relative.html";
-
- // Get the other toolstrip.
- var toolstrips = chrome.extension.getToolstrips();
- var other = (toolstrips[0].location == location) ?
- toolstrips[1] : toolstrips[0];
-
- other.chrome.toolstrip.expand({height:200, url:relative},
- chrome.test.callbackPass(function() {
- // TODO(mpcomplete) this never gets called
- chrome.test.log(other.location.toString());
- chrome.test.listenOnce(other.onLoad, function() {
- chrome.test.log(other.location.toString());
- chrome.test.assertEq(other.location.toString(),
- chrome.extension.getURL(relative));
- other.chrome.toolstrip.collapse({url:"../test2.html"},
- chrome.test.callbackPass(function() {
- chrome.test.assertEq(other.location.toString(), orig);
- }));
- });
- }));
- },
- */
-]);
-</script>
-test
\ No newline at end of file diff --git a/chrome/test/data/extensions/api_test/toolstrip/test2.html b/chrome/test/data/extensions/api_test/toolstrip/test2.html deleted file mode 100644 index 957f4e4..0000000 --- a/chrome/test/data/extensions/api_test/toolstrip/test2.html +++ /dev/null @@ -1,9 +0,0 @@ -<script>
-chrome.toolstrip.onExpanded.addListener(function() {
- chrome.test.log("test2 expanded");
-});
-chrome.toolstrip.onCollapsed.addListener(function() {
- chrome.test.log("test2 collapsed");
-});
-</script>
-test2
diff --git a/chrome/test/data/extensions/browsertest/last_error/toolstrip.html b/chrome/test/data/extensions/browsertest/last_error/bg.html index 6df972e..6df972e 100644 --- a/chrome/test/data/extensions/browsertest/last_error/toolstrip.html +++ b/chrome/test/data/extensions/browsertest/last_error/bg.html diff --git a/chrome/test/data/extensions/browsertest/last_error/manifest.json b/chrome/test/data/extensions/browsertest/last_error/manifest.json index e0c6ad7..71bf252 100644 --- a/chrome/test/data/extensions/browsertest/last_error/manifest.json +++ b/chrome/test/data/extensions/browsertest/last_error/manifest.json @@ -2,6 +2,6 @@ "name": "lastError", "description": "Used by browsertest to test the setting of lastError for callbacks.", "version": "0.1", - "toolstrips": ["toolstrip.html"], + "background_page": "bg.html", "permissions": ["tabs"] } diff --git a/chrome/test/data/extensions/common/one_in_shelf/manifest.json b/chrome/test/data/extensions/common/one_in_shelf/manifest.json deleted file mode 100644 index f714a17..0000000 --- a/chrome/test/data/extensions/common/one_in_shelf/manifest.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "description": "Extension which has exactly one item in the shelf", - "name": "one_in_shelf", - "toolstrips": [ - "shelf.html" - ], - "version": "0.1" -}
\ No newline at end of file diff --git a/chrome/test/data/extensions/common/one_in_shelf/shelf.html b/chrome/test/data/extensions/common/one_in_shelf/shelf.html deleted file mode 100644 index e2a5d5a..0000000 --- a/chrome/test/data/extensions/common/one_in_shelf/shelf.html +++ /dev/null @@ -1,2 +0,0 @@ -<div class="toolstrip-button">Hello World!</div> - diff --git a/chrome/test/data/extensions/good/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/manifest.json b/chrome/test/data/extensions/good/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/manifest.json index 7362c99..7f119e6 100644 --- a/chrome/test/data/extensions/good/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/manifest.json +++ b/chrome/test/data/extensions/good/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/manifest.json @@ -7,14 +7,6 @@ "128": "icon_128.png" }, "default_locale": "en_US", - "toolstrips": [ - { - "path": "toolstrip1.html", - "mole": "lorem_ipsum.html", - "mole_height": 200 - }, - "toolstrip2.html" - ], "background_page": "backgroundpage.html", "permissions": ["tabs", "http://*.google.com/*", "https://*.google.com/*"], "content_scripts": [ diff --git a/chrome/test/data/extensions/good/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/toolstrip1.html b/chrome/test/data/extensions/good/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/toolstrip1.html deleted file mode 100644 index da7cdae..0000000 --- a/chrome/test/data/extensions/good/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/toolstrip1.html +++ /dev/null @@ -1,59 +0,0 @@ -<script> -var isToolstrip = 1; -// This function is called from the C++ browser test. It does a basic sanity -// test that we can call extension APIs. -function testTabsAPI() { - console.log(chrome.tabs); - - chrome.tabs.getAllInWindow(null, function(tabs) { - window.domAutomationController.send(tabs.length == 1); - }); -} - -// This function is called from the C++ browser test. It tests the getLanguage -// function to make sure it can be used as an extension API. This will pass if -// the browser navigates to a page in French language before this is called. -function testTabsLanguageAPI() { - chrome.tabs.detectLanguage(null, function(language) { - window.domAutomationController.send(language == 'fr'); - }); -} - -// This function is called from the C++ browser test. It tests the getToolstrips -// function to make sure it can be used as an extension API. This will pass if -// getToolstrips returns all toolstrip views. -function testgetToolstripsAPI() { - var views = chrome.extension.getToolstrips(); - window.domAutomationController.send(views.length == 2 && - views[0].isToolstrip == 1 && - views[1].isToolstrip == 1); -} - -// This function is called from the C++ browser test. It tests the -// getBackgroundPage function to make sure it can be used as an extension API. -// This will pass if getBackgroundPage returns background page view. -function testgetBackgroundPageAPI() { - var view = chrome.extension.getBackgroundPage(); - window.domAutomationController.send(view != null && - view.isBackgroundPage == 1); -} - -// This function is called from the C++ browser test. It tests the -// getExtensionTabs function to make sure it can be used as an extension API. -// This will pass if getExtensionTabs returns tabcontent view. -function testgetExtensionTabsAPI() { - var views = chrome.extension.getExtensionTabs(); - // getTabContentses is here for backwards compatibility - var views2 = chrome.extension.getTabContentses(); - window.domAutomationController.send(views.length == 1 && - views[0].isTabContents == 1 && - views2.length == 1 && - views2[0].isTabContents == 1); -} - -</script> -<select> - <option>one</option> - <option>two</option> - <option>three</option> -</select> diff --git a/chrome/test/data/extensions/good/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/toolstrip2.html b/chrome/test/data/extensions/good/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/toolstrip2.html deleted file mode 100644 index 2f0bc54..0000000 --- a/chrome/test/data/extensions/good/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/toolstrip2.html +++ /dev/null @@ -1,4 +0,0 @@ -<script> - var isToolstrip = 1; -</script> -<button onclick="window.open('http://www.google.com', 'mywindow', 'width=640, height=480');">HTML button</button> diff --git a/chrome/test/data/extensions/good/Preferences b/chrome/test/data/extensions/good/Preferences index 6d5c369..fc5524c 100644 --- a/chrome/test/data/extensions/good/Preferences +++ b/chrome/test/data/extensions/good/Preferences @@ -15,14 +15,6 @@ "128": "icon_128.png" }, "default_locale": "en_US", - "toolstrips": [ - { - "path": "toolstrip1.html", - "mole": "lorem_ipsum.html", - "mole_height": 200 - }, - "toolstrip2.html" - ], "background_page": "backgroundpage.html", "permissions": ["tabs", "http://*.google.com/*", "https://*.google.com/*"], "content_scripts": [ diff --git a/chrome/test/data/extensions/profiles/toolstrips1/Default/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/manifest.json b/chrome/test/data/extensions/profiles/toolstrips1/Default/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/manifest.json deleted file mode 100644 index 94c0e712..0000000 --- a/chrome/test/data/extensions/profiles/toolstrips1/Default/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/manifest.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "key": "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDuUZGKCDbff6IRaxa4Pue7PPkxwPaNhGT3JEqppEsNWFjM80imEdqMbf3lrWqEfaHgaNku7nlpwPO1mu3/4Hr+XdNa5MhfnOnuPee4hyTLwOs3Vzz81wpbdzUxZSi2OmqMyI5oTaBYICfNHLwcuc65N5dbt6WKGeKgTpp4v7j7zwIDAQAB", - "version": "1.0.0.0", - "name": "1 toolstrip", - "toolstrips": [ - "toolstrip1.html" - ] -} diff --git a/chrome/test/data/extensions/profiles/toolstrips1/Default/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/toolstrip1.html b/chrome/test/data/extensions/profiles/toolstrips1/Default/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/toolstrip1.html deleted file mode 100644 index d45660f..0000000 --- a/chrome/test/data/extensions/profiles/toolstrips1/Default/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/toolstrip1.html +++ /dev/null @@ -1,5 +0,0 @@ -<select> - <option>one</option> - <option>two</option> - <option>three</option> -</select> diff --git a/chrome/test/data/extensions/profiles/toolstrips1/Default/Preferences b/chrome/test/data/extensions/profiles/toolstrips1/Default/Preferences deleted file mode 100644 index a9b9760..0000000 --- a/chrome/test/data/extensions/profiles/toolstrips1/Default/Preferences +++ /dev/null @@ -1,36 +0,0 @@ -{ - "download": { - "directory_upgrade": true, - "extensions_to_open": "" - }, - "extensions": { - "autoupdate": { - "next_check": "12897640036342487" - }, - "settings": { - "behllobkkfkfnphdnhnkndlbkcpglgmj": { - "location": 1, - "manifest": - { - "key": "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDuUZGKCDbff6IRaxa4Pue7PPkxwPaNhGT3JEqppEsNWFjM80imEdqMbf3lrWqEfaHgaNku7nlpwPO1mu3/4Hr+XdNa5MhfnOnuPee4hyTLwOs3Vzz81wpbdzUxZSi2OmqMyI5oTaBYICfNHLwcuc65N5dbt6WKGeKgTpp4v7j7zwIDAQAB", - "version": "1.0.0.0", - "name": "1 toolstrip", - "toolstrips": [ - "toolstrip1.html" - ] - }, - "path": "behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0", - "state": 1 - } - } - }, - "profile": { - "exited_cleanly": true, - "id": "not-signed-in", - "name": "", - "nickname": "" - }, - "session": { - "urls_to_restore_on_startup": [ ] - } -} diff --git a/chrome/test/data/extensions/profiles/toolstrips50/Default/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/manifest.json b/chrome/test/data/extensions/profiles/toolstrips50/Default/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/manifest.json deleted file mode 100644 index 2053464..0000000 --- a/chrome/test/data/extensions/profiles/toolstrips50/Default/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/manifest.json +++ /dev/null @@ -1,73 +0,0 @@ -{ - "key": "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDuUZGKCDbff6IRaxa4Pue7PPkxwPaNhGT3JEqppEsNWFjM80imEdqMbf3lrWqEfaHgaNku7nlpwPO1mu3/4Hr+XdNa5MhfnOnuPee4hyTLwOs3Vzz81wpbdzUxZSi2OmqMyI5oTaBYICfNHLwcuc65N5dbt6WKGeKgTpp4v7j7zwIDAQAB", - "version": "1.0.0.0", - "name": "50 toolstrips", - "toolstrips": [ - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html" - ] -} diff --git a/chrome/test/data/extensions/profiles/toolstrips50/Default/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/toolstrip1.html b/chrome/test/data/extensions/profiles/toolstrips50/Default/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/toolstrip1.html deleted file mode 100644 index d45660f..0000000 --- a/chrome/test/data/extensions/profiles/toolstrips50/Default/Extensions/behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0/toolstrip1.html +++ /dev/null @@ -1,5 +0,0 @@ -<select> - <option>one</option> - <option>two</option> - <option>three</option> -</select> diff --git a/chrome/test/data/extensions/profiles/toolstrips50/Default/Preferences b/chrome/test/data/extensions/profiles/toolstrips50/Default/Preferences deleted file mode 100644 index d4b478c..0000000 --- a/chrome/test/data/extensions/profiles/toolstrips50/Default/Preferences +++ /dev/null @@ -1,101 +0,0 @@ -{ - "download": { - "directory_upgrade": true, - "extensions_to_open": "" - }, - "extensions": { - "autoupdate": { - "next_check": "12897640036342487" - }, - "settings": { - "behllobkkfkfnphdnhnkndlbkcpglgmj": { - "location": 1, - "manifest": - { - "key": "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDuUZGKCDbff6IRaxa4Pue7PPkxwPaNhGT3JEqppEsNWFjM80imEdqMbf3lrWqEfaHgaNku7nlpwPO1mu3/4Hr+XdNa5MhfnOnuPee4hyTLwOs3Vzz81wpbdzUxZSi2OmqMyI5oTaBYICfNHLwcuc65N5dbt6WKGeKgTpp4v7j7zwIDAQAB", - "version": "1.0.0.0", - "name": "50 toolstrips", - "toolstrips": [ - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html", - "toolstrip1.html" - ] - }, - "path": "behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0", - "state": 1 - } - } - }, - "profile": { - "exited_cleanly": true, - "id": "not-signed-in", - "name": "", - "nickname": "" - }, - "session": { - "urls_to_restore_on_startup": [ ] - } -} diff --git a/chrome/test/startup/startup_test.cc b/chrome/test/startup/startup_test.cc index e33e113..1422e49 100644 --- a/chrome/test/startup/startup_test.cc +++ b/chrome/test/startup/startup_test.cc @@ -79,9 +79,6 @@ class StartupTest : public UITest { data_dir = data_dir.AppendASCII("extensions").AppendASCII("profiles"). AppendASCII(profile); set_template_user_data(data_dir); - - // For now, these tests still depend on toolstrips. - launch_arguments_.AppendSwitch(switches::kEnableExtensionToolstrips); } // Runs a test which loads |tab_count| tabs on startup, either as command line @@ -343,20 +340,6 @@ TEST_F(StartupTest, PerfExtensionEmpty) { UITest::DEFAULT_THEME, 1, 0); } -TEST_F(StartupTest, PerfExtensionToolstrips1) { - SetUpWithFileURL(); - SetUpWithExtensionsProfile("toolstrips1"); - RunStartupTest("warm", "extension_toolstrip1", WARM, NOT_IMPORTANT, - UITest::DEFAULT_THEME, 1, 0); -} - -TEST_F(StartupTest, PerfExtensionToolstrips50) { - SetUpWithFileURL(); - SetUpWithExtensionsProfile("toolstrips50"); - RunStartupTest("warm", "extension_toolstrip50", WARM, NOT_IMPORTANT, - UITest::DEFAULT_THEME, 1, 0); -} - TEST_F(StartupTest, PerfExtensionContentScript1) { SetUpWithFileURL(); SetUpWithExtensionsProfile("content_scripts1"); diff --git a/chrome/test/test_browser_window.h b/chrome/test/test_browser_window.h index 878bf72..d35e04c 100644 --- a/chrome/test/test_browser_window.h +++ b/chrome/test/test_browser_window.h @@ -30,7 +30,6 @@ class TestBrowserWindow : public BrowserWindow { virtual BrowserWindowTesting* GetBrowserWindowTesting() { return NULL; } virtual StatusBubble* GetStatusBubble() { return NULL; } virtual void SelectedTabToolbarSizeChanged(bool is_animating) {} - virtual void SelectedTabExtensionShelfSizeChanged() {} virtual void UpdateTitleBar() {} virtual void ShelfVisibilityChanged() {} virtual void UpdateDevTools() {} @@ -71,7 +70,6 @@ class TestBrowserWindow : public BrowserWindow { virtual void ConfirmAddSearchProvider(const TemplateURL* template_url, Profile* profile) {} virtual void ToggleBookmarkBar() {} - virtual void ToggleExtensionShelf() {} virtual views::Window* ShowAboutChromeDialog() { return NULL; } virtual void ShowUpdateChromeDialog() {} virtual void ShowTaskManager() {} |