Index: components/test_runner/text_input_controller.cc |
diff --git a/components/test_runner/text_input_controller.cc b/components/test_runner/text_input_controller.cc |
index 64d2a75656f3862abd36021d2a06f29d8ba7e269..eb0742133bf3d0c341bbdb2cb88a5876a80e67ac 100644 |
--- a/components/test_runner/text_input_controller.cc |
+++ b/components/test_runner/text_input_controller.cc |
@@ -257,14 +257,18 @@ void TextInputController::SetComposition(const std::string& text) { |
key_down.setKeyIdentifierFromWindowsKeyCode(); |
view()->handleInputEvent(key_down); |
+ // The value returned by std::string::length() may not correspond to the |
+ // actual number of encoded characters in sequences of multi-byte or |
+ // variable-length characters. |
+ blink::WebString newText = blink::WebString::fromUTF8(text); |
+ size_t textLength = newText.length(); |
+ |
std::vector<blink::WebCompositionUnderline> underlines; |
- underlines.push_back(blink::WebCompositionUnderline(0, text.length(), |
- SK_ColorBLACK, false, |
- SK_ColorTRANSPARENT)); |
+ underlines.push_back(blink::WebCompositionUnderline( |
+ 0, textLength, SK_ColorBLACK, false, SK_ColorTRANSPARENT)); |
view()->setComposition( |
- blink::WebString::fromUTF8(text), |
- blink::WebVector<blink::WebCompositionUnderline>(underlines), |
- text.length(), text.length()); |
+ newText, blink::WebVector<blink::WebCompositionUnderline>(underlines), |
+ textLength, textLength); |
} |
blink::WebView* TextInputController::view() { |