Index: chrome/browser/login_prompt_gtk.cc |
diff --git a/chrome/browser/login_prompt_gtk.cc b/chrome/browser/login_prompt_gtk.cc |
index b5045ad8ad5425be2bc9752cbb252239e8964e4c..bd7b908cd8344eb782a3b05060c70250a1c4164d 100644 |
--- a/chrome/browser/login_prompt_gtk.cc |
+++ b/chrome/browser/login_prompt_gtk.cc |
@@ -106,17 +106,20 @@ class LoginHandlerGtk : public LoginHandler, |
GtkWidget* hbox = gtk_hbox_new(FALSE, 12); |
gtk_box_pack_start(GTK_BOX(root_.get()), hbox, FALSE, FALSE, 0); |
- GtkWidget* ok = gtk_button_new_from_stock(GTK_STOCK_OK); |
+ ok_ = gtk_button_new_from_stock(GTK_STOCK_OK); |
gtk_button_set_label( |
- GTK_BUTTON(ok), |
+ GTK_BUTTON(ok_), |
l10n_util::GetStringUTF8(IDS_LOGIN_DIALOG_OK_BUTTON_LABEL).c_str()); |
- g_signal_connect(ok, "clicked", G_CALLBACK(OnOKClicked), this); |
- gtk_box_pack_end(GTK_BOX(hbox), ok, FALSE, FALSE, 0); |
+ g_signal_connect(ok_, "clicked", G_CALLBACK(OnOKClicked), this); |
+ gtk_box_pack_end(GTK_BOX(hbox), ok_, FALSE, FALSE, 0); |
GtkWidget* cancel = gtk_button_new_from_stock(GTK_STOCK_CANCEL); |
g_signal_connect(cancel, "clicked", G_CALLBACK(OnCancelClicked), this); |
gtk_box_pack_end(GTK_BOX(hbox), cancel, FALSE, FALSE, 0); |
+ g_signal_connect(root_.get(), "hierarchy-changed", |
+ G_CALLBACK(OnPromptShown), this); |
+ |
SetModel(manager); |
// Scary thread safety note: This can potentially be called *after* SetAuth |
@@ -126,12 +129,6 @@ class LoginHandlerGtk : public LoginHandler, |
// to happen after this is called (since this was InvokeLater'd first). |
dialog_ = GetTabContentsForLogin()->CreateConstrainedDialog(this); |
- // Now that we have attached ourself to the window, we can make our OK |
- // button the default action and mess with the focus. |
- GTK_WIDGET_SET_FLAGS(ok, GTK_CAN_DEFAULT); |
- gtk_widget_grab_default(ok); |
- gtk_widget_grab_focus(username_entry_); |
- |
SendNotifications(); |
} |
@@ -290,7 +287,7 @@ class LoginHandlerGtk : public LoginHandler, |
} |
} |
- static void OnOKClicked(GtkButton *button, LoginHandlerGtk* handler) { |
+ static void OnOKClicked(GtkButton* button, LoginHandlerGtk* handler) { |
DCHECK(ChromeThread::CurrentlyOn(ChromeThread::UI)); |
handler->SetAuth( |
@@ -298,11 +295,25 @@ class LoginHandlerGtk : public LoginHandler, |
UTF8ToWide(gtk_entry_get_text(GTK_ENTRY(handler->password_entry_)))); |
} |
- static void OnCancelClicked(GtkButton *button, LoginHandlerGtk* handler) { |
+ static void OnCancelClicked(GtkButton* button, LoginHandlerGtk* handler) { |
DCHECK(ChromeThread::CurrentlyOn(ChromeThread::UI)); |
handler->CancelAuth(); |
} |
+ static void OnPromptShown(GtkButton* root, |
+ GtkWidget* previous_toplevel, |
+ LoginHandlerGtk* handler) { |
+ DCHECK(ChromeThread::CurrentlyOn(ChromeThread::UI)); |
+ if (!GTK_WIDGET_TOPLEVEL(gtk_widget_get_toplevel(handler->ok_))) |
+ return; |
+ |
+ // Now that we have attached ourself to the window, we can make our OK |
+ // button the default action and mess with the focus. |
+ GTK_WIDGET_SET_FLAGS(handler->ok_, GTK_CAN_DEFAULT); |
+ gtk_widget_grab_default(handler->ok_); |
+ gtk_widget_grab_focus(handler->username_entry_); |
+ } |
+ |
// True if we've handled auth (SetAuth or CancelAuth has been called). |
bool handled_auth_; |
Lock handled_auth_lock_; |
@@ -336,6 +347,7 @@ class LoginHandlerGtk : public LoginHandler, |
// GtkEntry widgets that the user types into. |
GtkWidget* username_entry_; |
+ GtkWidget* ok_; |
GtkWidget* password_entry_; |
// If not null, points to a model we need to notify of our own destruction |