diff options
-rw-r--r-- | chrome/browser/browser_main.cc | 11 | ||||
-rw-r--r-- | chrome/browser/first_run_win.cc | 18 |
2 files changed, 24 insertions, 5 deletions
diff --git a/chrome/browser/browser_main.cc b/chrome/browser/browser_main.cc index f7145a4..9f03460 100644 --- a/chrome/browser/browser_main.cc +++ b/chrome/browser/browser_main.cc @@ -395,6 +395,17 @@ int BrowserMain(const MainFunctionParams& parameters) { ResourceBundle::GetSharedInstance().LoadThemeResources(); } +#if defined(OS_WIN) + // This is experimental code. See first_run_win.cc for more info. + if (parsed_command_line.HasSwitch(switches::kTryChromeAgain)) { + Upgrade::TryResult answer = Upgrade::ShowTryChromeDialog(); + if (answer == Upgrade::TD_NOT_NOW) + return ResultCodes::NORMAL_EXIT; + if (answer == Upgrade::TD_UNINSTALL_CHROME) + return ResultCodes::UNINSTALL_CHROME_ALIVE; + } +#endif // OS_WIN + BrowserInit browser_init; if (is_first_run) { diff --git a/chrome/browser/first_run_win.cc b/chrome/browser/first_run_win.cc index 2ac5cac..136350c 100644 --- a/chrome/browser/first_run_win.cc +++ b/chrome/browser/first_run_win.cc @@ -7,6 +7,7 @@ #include <atlbase.h> #include <atlcom.h> #include <windows.h> +#include <shellapi.h> #include <shlobj.h> #include <sstream> @@ -673,10 +674,8 @@ class TryChromeDialog : public views::ButtonListener, icon->SetImage(*rb.GetBitmapNamed(IDR_PRODUCT_ICON_32)); gfx::Size icon_size = icon->GetPreferredSize(); - const int width = 310; - const int height = 160; - gfx::Rect pos = ComputeWindowPosition(width, height); - + // An approximate window size. After Layout() we'll get better bounds. + gfx::Rect pos(310, 160); views::WidgetWin* popup = new views::WidgetWin(); if (!popup) { NOTREACHED(); @@ -778,8 +777,16 @@ class TryChromeDialog : public views::ButtonListener, link->SetController(this); layout->AddView(link); + // We resize the window according to the layout manager. This takes into + // account the differences between XP and Vista fonts and buttons. layout->Layout(root_view); - SetToastRegion(popup->GetNativeView(), width, height); + gfx::Size preferred = layout->GetPreferredSize(root_view); + pos = ComputeWindowPosition(preferred.width(), preferred.height()); + popup->SetBounds(pos); + + // Carve the toast shape into the window. + SetToastRegion(popup->GetNativeView(), + preferred.width(), preferred.height()); // Time to show the window in a modal loop. popup_ = popup; popup_->Show(); @@ -806,6 +813,7 @@ class TryChromeDialog : public views::ButtonListener, // fire off the default browser that by some convoluted logic should not be // chrome. virtual void LinkActivated(views::Link* source, int event_flags) { + ::ShellExecuteW(NULL, L"open", kHelpCenterUrl, NULL, NULL, SW_SHOW); } private: |