Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(113)

Side by Side Diff: third_party/WebKit/Source/core/events/InputEvent.cpp

Issue 2457523003: Support 'insertReplacementText' for spellcheck (Closed)
Patch Set: yosin@ comment#57 #58 addressed Created 4 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 "core/events/InputEvent.h" 5 #include "core/events/InputEvent.h"
6 6
7 #include "core/dom/Range.h" 7 #include "core/dom/Range.h"
8 #include "core/events/EventDispatcher.h" 8 #include "core/events/EventDispatcher.h"
9 #include "public/platform/WebEditingCommandType.h" 9 #include "public/platform/WebEditingCommandType.h"
10 10
11 namespace blink { 11 namespace blink {
12 12
13 namespace { 13 namespace {
14 14
15 const struct { 15 const struct {
16 InputEvent::InputType inputType; 16 InputEvent::InputType inputType;
17 const char* stringName; 17 const char* stringName;
18 } kInputTypeStringNameMap[] = { 18 } kInputTypeStringNameMap[] = {
19 {InputEvent::InputType::None, ""}, 19 {InputEvent::InputType::None, ""},
20 {InputEvent::InputType::InsertText, "insertText"}, 20 {InputEvent::InputType::InsertText, "insertText"},
21 {InputEvent::InputType::InsertLineBreak, "insertLineBreak"}, 21 {InputEvent::InputType::InsertLineBreak, "insertLineBreak"},
22 {InputEvent::InputType::InsertParagraph, "insertParagraph"}, 22 {InputEvent::InputType::InsertParagraph, "insertParagraph"},
23 {InputEvent::InputType::InsertOrderedList, "insertOrderedList"}, 23 {InputEvent::InputType::InsertOrderedList, "insertOrderedList"},
24 {InputEvent::InputType::InsertUnorderedList, "insertUnorderedList"}, 24 {InputEvent::InputType::InsertUnorderedList, "insertUnorderedList"},
25 {InputEvent::InputType::InsertHorizontalRule, "insertHorizontalRule"}, 25 {InputEvent::InputType::InsertHorizontalRule, "insertHorizontalRule"},
26 {InputEvent::InputType::InsertFromPaste, "insertFromPaste"}, 26 {InputEvent::InputType::InsertFromPaste, "insertFromPaste"},
27 {InputEvent::InputType::InsertFromDrop, "insertFromDrop"}, 27 {InputEvent::InputType::InsertFromDrop, "insertFromDrop"},
28 {InputEvent::InputType::InsertReplacementText, "insertReplacementText"},
28 {InputEvent::InputType::DeleteComposedCharacterForward, 29 {InputEvent::InputType::DeleteComposedCharacterForward,
29 "deleteComposedCharacterForward"}, 30 "deleteComposedCharacterForward"},
30 {InputEvent::InputType::DeleteComposedCharacterBackward, 31 {InputEvent::InputType::DeleteComposedCharacterBackward,
31 "deleteComposedCharacterBackward"}, 32 "deleteComposedCharacterBackward"},
32 {InputEvent::InputType::DeleteWordBackward, "deleteWordBackward"}, 33 {InputEvent::InputType::DeleteWordBackward, "deleteWordBackward"},
33 {InputEvent::InputType::DeleteWordForward, "deleteWordForward"}, 34 {InputEvent::InputType::DeleteWordForward, "deleteWordForward"},
34 {InputEvent::InputType::DeleteLineBackward, "deleteLineBackward"}, 35 {InputEvent::InputType::DeleteLineBackward, "deleteLineBackward"},
35 {InputEvent::InputType::DeleteLineForward, "deleteLineForward"}, 36 {InputEvent::InputType::DeleteLineForward, "deleteLineForward"},
36 {InputEvent::InputType::DeleteContentBackward, "deleteContentBackward"}, 37 {InputEvent::InputType::DeleteContentBackward, "deleteContentBackward"},
37 {InputEvent::InputType::DeleteContentForward, "deleteContentForward"}, 38 {InputEvent::InputType::DeleteContentForward, "deleteContentForward"},
(...skipping 178 matching lines...) Expand 10 before | Expand all | Expand 10 after
216 // 3. We don't want authors to hold live |Range| indefinitely by holding 217 // 3. We don't want authors to hold live |Range| indefinitely by holding
217 // |InputEvent|, so we clear them after dispatch. 218 // |InputEvent|, so we clear them after dispatch.
218 // Authors should explicitly call |getTargetRanges()|->|toRange()| if they 219 // Authors should explicitly call |getTargetRanges()|->|toRange()| if they
219 // want to keep a copy of |Range|. See Editing TF meeting notes: 220 // want to keep a copy of |Range|. See Editing TF meeting notes:
220 // https://docs.google.com/document/d/1hCj6QX77NYIVY0RWrMHT1Yra6t8_Qu8PopaWLG0 AM58/edit?usp=sharing 221 // https://docs.google.com/document/d/1hCj6QX77NYIVY0RWrMHT1Yra6t8_Qu8PopaWLG0 AM58/edit?usp=sharing
221 event().m_ranges.clear(); 222 event().m_ranges.clear();
222 return result; 223 return result;
223 } 224 }
224 225
225 } // namespace blink 226 } // namespace blink
OLDNEW
« no previous file with comments | « third_party/WebKit/Source/core/events/InputEvent.h ('k') | third_party/WebKit/Source/web/WebLocalFrameImpl.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698