| Index: chrome/browser/chromeos/login/lock/screen_locker.cc
|
| diff --git a/chrome/browser/chromeos/login/lock/screen_locker.cc b/chrome/browser/chromeos/login/lock/screen_locker.cc
|
| index fe389ebebe60881ba2c10f2353e7ba33d8077487..e5889311403196f8f4e1aa7bc70352e8d364b28e 100644
|
| --- a/chrome/browser/chromeos/login/lock/screen_locker.cc
|
| +++ b/chrome/browser/chromeos/login/lock/screen_locker.cc
|
| @@ -204,11 +204,16 @@ void ScreenLocker::OnAuthSuccess(const UserContext& user_context) {
|
| const user_manager::User* user =
|
| UserManager::Get()->FindUser(user_context.GetUserID());
|
| if (user) {
|
| - if (!user->is_active())
|
| + if (user->is_active()) {
|
| + DCHECK(saved_ime_state_);
|
| + input_method::InputMethodManager::Get()->SetState(saved_ime_state_);
|
| + } else {
|
| UserManager::Get()->SwitchActiveUser(user_context.GetUserID());
|
| + }
|
| } else {
|
| NOTREACHED() << "Logged in user not found.";
|
| }
|
| + saved_ime_state_ = NULL;
|
|
|
| authentication_capture_.reset(new AuthenticationParametersCapture());
|
| authentication_capture_->user_context = user_context;
|
| @@ -473,6 +478,12 @@ void ScreenLocker::ScreenLockReady() {
|
| ash::Shell::GetInstance()->
|
| desktop_background_controller()->MoveDesktopToLockedContainer();
|
|
|
| + input_method::InputMethodManager* imm =
|
| + input_method::InputMethodManager::Get();
|
| + saved_ime_state_ = imm->GetActiveIMEState();
|
| + imm->SetState(saved_ime_state_->Clone());
|
| + imm->GetActiveIMEState()->EnableLockScreenLayouts();
|
| +
|
| bool state = true;
|
| VLOG(1) << "Emitting SCREEN_LOCK_STATE_CHANGED with state=" << state;
|
| content::NotificationService::current()->Notify(
|
|
|