| Index: ui/base/ime/input_method_base.cc | 
| diff --git a/ui/base/ime/input_method_base.cc b/ui/base/ime/input_method_base.cc | 
| index 492d7f9a5e06700b527e90f9f6a60b9ae97c6503..f436c5d5199ada5cdcf1ed8e6501cbea8b0ebfc7 100644 | 
| --- a/ui/base/ime/input_method_base.cc | 
| +++ b/ui/base/ime/input_method_base.cc | 
| @@ -63,6 +63,12 @@ TextInputClient* InputMethodBase::GetTextInputClient() const { | 
| return text_input_client_; | 
| } | 
|  | 
| +void InputMethodBase::SetOnScreenKeyboardBounds(const gfx::Rect& new_bounds) { | 
| +  keyboard_bounds_ = new_bounds; | 
| +  if (text_input_client_) | 
| +    text_input_client_->EnsureCaretNotInRect(keyboard_bounds_); | 
| +} | 
| + | 
| void InputMethodBase::OnTextInputTypeChanged(const TextInputClient* client) { | 
| if (!IsTextInputClientFocused(client)) | 
| return; | 
| @@ -152,6 +158,10 @@ void InputMethodBase::SetFocusedTextInputClientInternal( | 
| text_input_client_ = client;  // nullptr allowed. | 
| OnDidChangeFocusedClient(old, client); | 
| NotifyTextInputStateChanged(text_input_client_); | 
| + | 
| +  // Move new focused window if necessary. | 
| +  if (text_input_client_) | 
| +    text_input_client_->EnsureCaretNotInRect(keyboard_bounds_); | 
| } | 
|  | 
| std::vector<gfx::Rect> InputMethodBase::GetCompositionBounds( | 
|  |