| Index: chrome/browser/login_prompt_gtk.cc | 
| =================================================================== | 
| --- chrome/browser/login_prompt_gtk.cc	(revision 36364) | 
| +++ chrome/browser/login_prompt_gtk.cc	(working copy) | 
| @@ -106,17 +106,20 @@ | 
| 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 | 
| @@ -128,8 +131,8 @@ | 
|  | 
| // 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_SET_FLAGS(ok_, GTK_CAN_DEFAULT); | 
| +    gtk_widget_grab_default(ok_); | 
| gtk_widget_grab_focus(username_entry_); | 
|  | 
| SendNotifications(); | 
| @@ -305,6 +308,20 @@ | 
| 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_; | 
| @@ -339,6 +356,7 @@ | 
| // GtkEntry widgets that the user types into. | 
| GtkWidget* username_entry_; | 
| GtkWidget* password_entry_; | 
| +  GtkWidget* ok_; | 
|  | 
| // If not null, points to a model we need to notify of our own destruction | 
| // so it doesn't try and access this when its too late. | 
|  |