| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "components/test_runner/text_input_controller.h" | 5 #include "components/test_runner/text_input_controller.h" |
| 6 | 6 |
| 7 #include "base/macros.h" | 7 #include "base/macros.h" |
| 8 #include "components/test_runner/web_test_delegate.h" |
| 8 #include "components/test_runner/web_view_test_proxy.h" | 9 #include "components/test_runner/web_view_test_proxy.h" |
| 9 #include "gin/arguments.h" | 10 #include "gin/arguments.h" |
| 10 #include "gin/handle.h" | 11 #include "gin/handle.h" |
| 11 #include "gin/object_template_builder.h" | 12 #include "gin/object_template_builder.h" |
| 12 #include "gin/wrappable.h" | 13 #include "gin/wrappable.h" |
| 13 #include "third_party/WebKit/public/web/WebCompositionUnderline.h" | 14 #include "third_party/WebKit/public/web/WebCompositionUnderline.h" |
| 15 #include "third_party/WebKit/public/web/WebFrameWidget.h" |
| 14 #include "third_party/WebKit/public/web/WebInputEvent.h" | 16 #include "third_party/WebKit/public/web/WebInputEvent.h" |
| 17 #include "third_party/WebKit/public/web/WebInputMethodController.h" |
| 15 #include "third_party/WebKit/public/web/WebKit.h" | 18 #include "third_party/WebKit/public/web/WebKit.h" |
| 16 #include "third_party/WebKit/public/web/WebLocalFrame.h" | 19 #include "third_party/WebKit/public/web/WebLocalFrame.h" |
| 17 #include "third_party/WebKit/public/web/WebRange.h" | 20 #include "third_party/WebKit/public/web/WebRange.h" |
| 18 #include "third_party/WebKit/public/web/WebView.h" | 21 #include "third_party/WebKit/public/web/WebView.h" |
| 19 #include "third_party/skia/include/core/SkColor.h" | 22 #include "third_party/skia/include/core/SkColor.h" |
| 20 #include "v8/include/v8.h" | 23 #include "v8/include/v8.h" |
| 21 | 24 |
| 22 namespace test_runner { | 25 namespace test_runner { |
| 23 | 26 |
| 24 class TextInputControllerBindings | 27 class TextInputControllerBindings |
| (...skipping 16 matching lines...) Expand all Loading... |
| 41 void InsertText(const std::string& text); | 44 void InsertText(const std::string& text); |
| 42 void UnmarkText(); | 45 void UnmarkText(); |
| 43 void DoCommand(const std::string& text); | 46 void DoCommand(const std::string& text); |
| 44 void SetMarkedText(const std::string& text, int start, int length); | 47 void SetMarkedText(const std::string& text, int start, int length); |
| 45 bool HasMarkedText(); | 48 bool HasMarkedText(); |
| 46 std::vector<int> MarkedRange(); | 49 std::vector<int> MarkedRange(); |
| 47 std::vector<int> SelectedRange(); | 50 std::vector<int> SelectedRange(); |
| 48 std::vector<int> FirstRectForCharacterRange(unsigned location, | 51 std::vector<int> FirstRectForCharacterRange(unsigned location, |
| 49 unsigned length); | 52 unsigned length); |
| 50 void SetComposition(const std::string& text); | 53 void SetComposition(const std::string& text); |
| 54 void ForceTextInputStateUpdate(); |
| 51 | 55 |
| 52 base::WeakPtr<TextInputController> controller_; | 56 base::WeakPtr<TextInputController> controller_; |
| 53 | 57 |
| 54 DISALLOW_COPY_AND_ASSIGN(TextInputControllerBindings); | 58 DISALLOW_COPY_AND_ASSIGN(TextInputControllerBindings); |
| 55 }; | 59 }; |
| 56 | 60 |
| 57 gin::WrapperInfo TextInputControllerBindings::kWrapperInfo = { | 61 gin::WrapperInfo TextInputControllerBindings::kWrapperInfo = { |
| 58 gin::kEmbedderNativeGin}; | 62 gin::kEmbedderNativeGin}; |
| 59 | 63 |
| 60 // static | 64 // static |
| (...skipping 28 matching lines...) Expand all Loading... |
| 89 isolate) | 93 isolate) |
| 90 .SetMethod("insertText", &TextInputControllerBindings::InsertText) | 94 .SetMethod("insertText", &TextInputControllerBindings::InsertText) |
| 91 .SetMethod("unmarkText", &TextInputControllerBindings::UnmarkText) | 95 .SetMethod("unmarkText", &TextInputControllerBindings::UnmarkText) |
| 92 .SetMethod("doCommand", &TextInputControllerBindings::DoCommand) | 96 .SetMethod("doCommand", &TextInputControllerBindings::DoCommand) |
| 93 .SetMethod("setMarkedText", &TextInputControllerBindings::SetMarkedText) | 97 .SetMethod("setMarkedText", &TextInputControllerBindings::SetMarkedText) |
| 94 .SetMethod("hasMarkedText", &TextInputControllerBindings::HasMarkedText) | 98 .SetMethod("hasMarkedText", &TextInputControllerBindings::HasMarkedText) |
| 95 .SetMethod("markedRange", &TextInputControllerBindings::MarkedRange) | 99 .SetMethod("markedRange", &TextInputControllerBindings::MarkedRange) |
| 96 .SetMethod("selectedRange", &TextInputControllerBindings::SelectedRange) | 100 .SetMethod("selectedRange", &TextInputControllerBindings::SelectedRange) |
| 97 .SetMethod("firstRectForCharacterRange", | 101 .SetMethod("firstRectForCharacterRange", |
| 98 &TextInputControllerBindings::FirstRectForCharacterRange) | 102 &TextInputControllerBindings::FirstRectForCharacterRange) |
| 99 .SetMethod("setComposition", | 103 .SetMethod("setComposition", &TextInputControllerBindings::SetComposition) |
| 100 &TextInputControllerBindings::SetComposition); | 104 .SetMethod("forceTextInputStateUpdate", |
| 105 &TextInputControllerBindings::ForceTextInputStateUpdate); |
| 101 } | 106 } |
| 102 | 107 |
| 103 void TextInputControllerBindings::InsertText(const std::string& text) { | 108 void TextInputControllerBindings::InsertText(const std::string& text) { |
| 104 if (controller_) | 109 if (controller_) |
| 105 controller_->InsertText(text); | 110 controller_->InsertText(text); |
| 106 } | 111 } |
| 107 | 112 |
| 108 void TextInputControllerBindings::UnmarkText() { | 113 void TextInputControllerBindings::UnmarkText() { |
| 109 if (controller_) | 114 if (controller_) |
| 110 controller_->UnmarkText(); | 115 controller_->UnmarkText(); |
| (...skipping 27 matching lines...) Expand all Loading... |
| 138 unsigned location, | 143 unsigned location, |
| 139 unsigned length) { | 144 unsigned length) { |
| 140 return controller_ ? controller_->FirstRectForCharacterRange(location, length) | 145 return controller_ ? controller_->FirstRectForCharacterRange(location, length) |
| 141 : std::vector<int>(); | 146 : std::vector<int>(); |
| 142 } | 147 } |
| 143 | 148 |
| 144 void TextInputControllerBindings::SetComposition(const std::string& text) { | 149 void TextInputControllerBindings::SetComposition(const std::string& text) { |
| 145 if (controller_) | 150 if (controller_) |
| 146 controller_->SetComposition(text); | 151 controller_->SetComposition(text); |
| 147 } | 152 } |
| 148 | 153 void TextInputControllerBindings::ForceTextInputStateUpdate() { |
| 154 if (controller_) |
| 155 controller_->ForceTextInputStateUpdate(); |
| 156 } |
| 149 // TextInputController --------------------------------------------------------- | 157 // TextInputController --------------------------------------------------------- |
| 150 | 158 |
| 151 TextInputController::TextInputController( | 159 TextInputController::TextInputController( |
| 152 WebViewTestProxyBase* web_view_test_proxy_base) | 160 WebViewTestProxyBase* web_view_test_proxy_base) |
| 153 : web_view_test_proxy_base_(web_view_test_proxy_base), | 161 : web_view_test_proxy_base_(web_view_test_proxy_base), |
| 154 weak_factory_(this) {} | 162 weak_factory_(this) {} |
| 155 | 163 |
| 156 TextInputController::~TextInputController() {} | 164 TextInputController::~TextInputController() {} |
| 157 | 165 |
| 158 void TextInputController::Install(blink::WebLocalFrame* frame) { | 166 void TextInputController::Install(blink::WebLocalFrame* frame) { |
| 159 TextInputControllerBindings::Install(weak_factory_.GetWeakPtr(), frame); | 167 TextInputControllerBindings::Install(weak_factory_.GetWeakPtr(), frame); |
| 160 } | 168 } |
| 161 | 169 |
| 162 void TextInputController::InsertText(const std::string& text) { | 170 void TextInputController::InsertText(const std::string& text) { |
| 163 view()->commitText(blink::WebString::fromUTF8(text), 0); | 171 inputMethodController()->commitText(blink::WebString::fromUTF8(text), 0); |
| 164 } | 172 } |
| 165 | 173 |
| 166 void TextInputController::UnmarkText() { | 174 void TextInputController::UnmarkText() { |
| 167 view()->finishComposingText(blink::WebWidget::KeepSelection); | 175 inputMethodController()->finishComposingText( |
| 176 blink::WebInputMethodController::KeepSelection); |
| 168 } | 177 } |
| 169 | 178 |
| 170 void TextInputController::DoCommand(const std::string& text) { | 179 void TextInputController::DoCommand(const std::string& text) { |
| 171 if (view()->mainFrame()) { | 180 if (view()->mainFrame()) { |
| 172 if (!view()->mainFrame()->toWebLocalFrame()) { | 181 if (!view()->mainFrame()->toWebLocalFrame()) { |
| 173 CHECK(false) << "This function cannot be called if the main frame is not" | 182 CHECK(false) << "This function cannot be called if the main frame is not" |
| 174 "a local frame."; | 183 "a local frame."; |
| 175 } | 184 } |
| 176 view()->mainFrame()->toWebLocalFrame()->executeCommand( | 185 view()->mainFrame()->toWebLocalFrame()->executeCommand( |
| 177 blink::WebString::fromUTF8(text)); | 186 blink::WebString::fromUTF8(text)); |
| (...skipping 18 matching lines...) Expand all Loading... |
| 196 } | 205 } |
| 197 underline.thick = true; | 206 underline.thick = true; |
| 198 underlines.push_back(underline); | 207 underlines.push_back(underline); |
| 199 if (start + length < static_cast<int>(web_text.length())) { | 208 if (start + length < static_cast<int>(web_text.length())) { |
| 200 underline.startOffset = underline.endOffset; | 209 underline.startOffset = underline.endOffset; |
| 201 underline.endOffset = web_text.length(); | 210 underline.endOffset = web_text.length(); |
| 202 underline.thick = false; | 211 underline.thick = false; |
| 203 underlines.push_back(underline); | 212 underlines.push_back(underline); |
| 204 } | 213 } |
| 205 | 214 |
| 206 view()->setComposition(web_text, underlines, start, start + length); | 215 inputMethodController()->setComposition(web_text, underlines, start, |
| 216 start + length); |
| 207 } | 217 } |
| 208 | 218 |
| 209 bool TextInputController::HasMarkedText() { | 219 bool TextInputController::HasMarkedText() { |
| 210 if (!view()->mainFrame()) | 220 if (!view()->mainFrame()) |
| 211 return false; | 221 return false; |
| 212 | 222 |
| 213 if (!view()->mainFrame()->toWebLocalFrame()) { | 223 if (!view()->mainFrame()->toWebLocalFrame()) { |
| 214 CHECK(false) << "This function cannot be called if the main frame is not" | 224 CHECK(false) << "This function cannot be called if the main frame is not" |
| 215 "a local frame."; | 225 "a local frame."; |
| 216 } | 226 } |
| (...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 285 | 295 |
| 286 // The value returned by std::string::length() may not correspond to the | 296 // The value returned by std::string::length() may not correspond to the |
| 287 // actual number of encoded characters in sequences of multi-byte or | 297 // actual number of encoded characters in sequences of multi-byte or |
| 288 // variable-length characters. | 298 // variable-length characters. |
| 289 blink::WebString newText = blink::WebString::fromUTF8(text); | 299 blink::WebString newText = blink::WebString::fromUTF8(text); |
| 290 size_t textLength = newText.length(); | 300 size_t textLength = newText.length(); |
| 291 | 301 |
| 292 std::vector<blink::WebCompositionUnderline> underlines; | 302 std::vector<blink::WebCompositionUnderline> underlines; |
| 293 underlines.push_back(blink::WebCompositionUnderline( | 303 underlines.push_back(blink::WebCompositionUnderline( |
| 294 0, textLength, SK_ColorBLACK, false, SK_ColorTRANSPARENT)); | 304 0, textLength, SK_ColorBLACK, false, SK_ColorTRANSPARENT)); |
| 295 view()->setComposition( | 305 inputMethodController()->setComposition( |
| 296 newText, blink::WebVector<blink::WebCompositionUnderline>(underlines), | 306 newText, blink::WebVector<blink::WebCompositionUnderline>(underlines), |
| 297 textLength, textLength); | 307 textLength, textLength); |
| 298 } | 308 } |
| 299 | 309 |
| 310 void TextInputController::ForceTextInputStateUpdate() { |
| 311 web_view_test_proxy_base_->delegate()->ForceTextInputStateUpdate( |
| 312 view()->mainFrame()); |
| 313 } |
| 314 |
| 300 blink::WebView* TextInputController::view() { | 315 blink::WebView* TextInputController::view() { |
| 301 return web_view_test_proxy_base_->web_view(); | 316 return web_view_test_proxy_base_->web_view(); |
| 302 } | 317 } |
| 303 | 318 |
| 319 blink::WebInputMethodController* TextInputController::inputMethodController() { |
| 320 blink::WebLocalFrame* mainFrame = view()->mainFrame()->toWebLocalFrame(); |
| 321 if (!mainFrame) { |
| 322 CHECK(false) << "WebView does not have a local main frame and" |
| 323 " cannot handle input method controller tasks."; |
| 324 } |
| 325 return mainFrame->frameWidget()->getActiveWebInputMethodController(); |
| 326 } |
| 327 |
| 304 } // namespace test_runner | 328 } // namespace test_runner |
| OLD | NEW |