OLD | NEW |
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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 // This file contains the definition for EventSendingController. | 5 // This file contains the definition for EventSendingController. |
6 // | 6 // |
7 // Some notes about drag and drop handling: | 7 // Some notes about drag and drop handling: |
8 // Windows drag and drop goes through a system call to DoDragDrop. At that | 8 // Windows drag and drop goes through a system call to DoDragDrop. At that |
9 // point, program control is given to Windows which then periodically makes | 9 // point, program control is given to Windows which then periodically makes |
10 // callbacks into the webview. This won't work for layout tests, so instead, | 10 // callbacks into the webview. This won't work for layout tests, so instead, |
11 // we queue up all the mouse move and mouse up events. When the test tries to | 11 // we queue up all the mouse move and mouse up events. When the test tries to |
12 // start a drag (by calling EvenSendingController::DoDragDrop), we take the | 12 // start a drag (by calling EvenSendingController::DoDragDrop), we take the |
13 // events in the queue and replay them. | 13 // events in the queue and replay them. |
14 // The behavior of queuing events and replaying them can be disabled by a | 14 // The behavior of queuing events and replaying them can be disabled by a |
15 // layout test by setting eventSender.dragMode to false. | 15 // layout test by setting eventSender.dragMode to false. |
16 | 16 |
17 #include "webkit/tools/test_shell/event_sending_controller.h" | 17 #include "webkit/tools/test_shell/event_sending_controller.h" |
18 | 18 |
19 #include <queue> | 19 #include <queue> |
20 #include <vector> | 20 #include <vector> |
21 | 21 |
| 22 #include "app/keyboard_codes.h" |
22 #include "base/compiler_specific.h" | 23 #include "base/compiler_specific.h" |
23 #include "base/file_path.h" | 24 #include "base/file_path.h" |
24 #include "base/file_util.h" | 25 #include "base/file_util.h" |
25 #include "base/keyboard_codes.h" | |
26 #include "base/logging.h" | 26 #include "base/logging.h" |
27 #include "base/message_loop.h" | 27 #include "base/message_loop.h" |
28 #include "base/time.h" | 28 #include "base/time.h" |
29 #include "base/string_number_conversions.h" | 29 #include "base/string_number_conversions.h" |
30 #include "base/string_util.h" | 30 #include "base/string_util.h" |
31 #include "base/utf_string_conversions.h" | 31 #include "base/utf_string_conversions.h" |
32 #include "third_party/WebKit/WebKit/chromium/public/WebDragData.h" | 32 #include "third_party/WebKit/WebKit/chromium/public/WebDragData.h" |
33 #include "third_party/WebKit/WebKit/chromium/public/WebDragOperation.h" | 33 #include "third_party/WebKit/WebKit/chromium/public/WebDragOperation.h" |
34 #include "third_party/WebKit/WebKit/chromium/public/WebPoint.h" | 34 #include "third_party/WebKit/WebKit/chromium/public/WebPoint.h" |
35 #include "third_party/WebKit/WebKit/chromium/public/WebString.h" | 35 #include "third_party/WebKit/WebKit/chromium/public/WebString.h" |
(...skipping 172 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
208 // modifiers. These key events correspond to some special movement and | 208 // modifiers. These key events correspond to some special movement and |
209 // selection editor commands, and was supposed to be handled in | 209 // selection editor commands, and was supposed to be handled in |
210 // third_party/WebKit/WebKit/chromium/src/EditorClientImpl.cpp. But these keys | 210 // third_party/WebKit/WebKit/chromium/src/EditorClientImpl.cpp. But these keys |
211 // will be marked as system key, which prevents them from being handled. | 211 // will be marked as system key, which prevents them from being handled. |
212 // Thus they must be handled specially. | 212 // Thus they must be handled specially. |
213 if ((event.modifiers & ~WebKeyboardEvent::ShiftKey) != | 213 if ((event.modifiers & ~WebKeyboardEvent::ShiftKey) != |
214 WebKeyboardEvent::MetaKey) | 214 WebKeyboardEvent::MetaKey) |
215 return false; | 215 return false; |
216 | 216 |
217 switch (event.windowsKeyCode) { | 217 switch (event.windowsKeyCode) { |
218 case base::VKEY_LEFT: | 218 case app::VKEY_LEFT: |
219 *name = "MoveToBeginningOfLine"; | 219 *name = "MoveToBeginningOfLine"; |
220 break; | 220 break; |
221 case base::VKEY_RIGHT: | 221 case app::VKEY_RIGHT: |
222 *name = "MoveToEndOfLine"; | 222 *name = "MoveToEndOfLine"; |
223 break; | 223 break; |
224 case base::VKEY_UP: | 224 case app::VKEY_UP: |
225 *name = "MoveToBeginningOfDocument"; | 225 *name = "MoveToBeginningOfDocument"; |
226 break; | 226 break; |
227 case base::VKEY_DOWN: | 227 case app::VKEY_DOWN: |
228 *name = "MoveToEndOfDocument"; | 228 *name = "MoveToEndOfDocument"; |
229 break; | 229 break; |
230 default: | 230 default: |
231 return false; | 231 return false; |
232 } | 232 } |
233 | 233 |
234 if (event.modifiers & WebKeyboardEvent::ShiftKey) | 234 if (event.modifiers & WebKeyboardEvent::ShiftKey) |
235 name->append("AndModifySelection"); | 235 name->append("AndModifySelection"); |
236 | 236 |
237 return true; | 237 return true; |
(...skipping 310 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
548 // TODO(mpcomplete): Should we also generate a KEY_UP? | 548 // TODO(mpcomplete): Should we also generate a KEY_UP? |
549 std::wstring code_str = UTF8ToWide(args[0].ToString()); | 549 std::wstring code_str = UTF8ToWide(args[0].ToString()); |
550 | 550 |
551 // Convert \n -> VK_RETURN. Some layout tests use \n to mean "Enter", when | 551 // Convert \n -> VK_RETURN. Some layout tests use \n to mean "Enter", when |
552 // Windows uses \r for "Enter". | 552 // Windows uses \r for "Enter". |
553 int code = 0; | 553 int code = 0; |
554 int text = 0; | 554 int text = 0; |
555 bool needs_shift_key_modifier = false; | 555 bool needs_shift_key_modifier = false; |
556 if (L"\n" == code_str) { | 556 if (L"\n" == code_str) { |
557 generate_char = true; | 557 generate_char = true; |
558 text = code = base::VKEY_RETURN; | 558 text = code = app::VKEY_RETURN; |
559 } else if (L"rightArrow" == code_str) { | 559 } else if (L"rightArrow" == code_str) { |
560 code = base::VKEY_RIGHT; | 560 code = app::VKEY_RIGHT; |
561 } else if (L"downArrow" == code_str) { | 561 } else if (L"downArrow" == code_str) { |
562 code = base::VKEY_DOWN; | 562 code = app::VKEY_DOWN; |
563 } else if (L"leftArrow" == code_str) { | 563 } else if (L"leftArrow" == code_str) { |
564 code = base::VKEY_LEFT; | 564 code = app::VKEY_LEFT; |
565 } else if (L"upArrow" == code_str) { | 565 } else if (L"upArrow" == code_str) { |
566 code = base::VKEY_UP; | 566 code = app::VKEY_UP; |
567 } else if (L"insert" == code_str) { | 567 } else if (L"insert" == code_str) { |
568 code = base::VKEY_INSERT; | 568 code = app::VKEY_INSERT; |
569 } else if (L"delete" == code_str) { | 569 } else if (L"delete" == code_str) { |
570 code = base::VKEY_BACK; | 570 code = app::VKEY_BACK; |
571 } else if (L"pageUp" == code_str) { | 571 } else if (L"pageUp" == code_str) { |
572 code = base::VKEY_PRIOR; | 572 code = app::VKEY_PRIOR; |
573 } else if (L"pageDown" == code_str) { | 573 } else if (L"pageDown" == code_str) { |
574 code = base::VKEY_NEXT; | 574 code = app::VKEY_NEXT; |
575 } else if (L"home" == code_str) { | 575 } else if (L"home" == code_str) { |
576 code = base::VKEY_HOME; | 576 code = app::VKEY_HOME; |
577 } else if (L"end" == code_str) { | 577 } else if (L"end" == code_str) { |
578 code = base::VKEY_END; | 578 code = app::VKEY_END; |
579 } else if (L"printScreen" == code_str) { | 579 } else if (L"printScreen" == code_str) { |
580 code = base::VKEY_SNAPSHOT; | 580 code = app::VKEY_SNAPSHOT; |
581 } else { | 581 } else { |
582 // Compare the input string with the function-key names defined by the | 582 // Compare the input string with the function-key names defined by the |
583 // DOM spec (i.e. "F1",...,"F24"). If the input string is a function-key | 583 // DOM spec (i.e. "F1",...,"F24"). If the input string is a function-key |
584 // name, set its key code. | 584 // name, set its key code. |
585 for (int i = 1; i <= 24; ++i) { | 585 for (int i = 1; i <= 24; ++i) { |
586 std::wstring function_key_name; | 586 std::wstring function_key_name; |
587 function_key_name += L"F"; | 587 function_key_name += L"F"; |
588 function_key_name += UTF8ToWide(base::IntToString(i)); | 588 function_key_name += UTF8ToWide(base::IntToString(i)); |
589 if (function_key_name == code_str) { | 589 if (function_key_name == code_str) { |
590 code = base::VKEY_F1 + (i - 1); | 590 code = app::VKEY_F1 + (i - 1); |
591 break; | 591 break; |
592 } | 592 } |
593 } | 593 } |
594 if (!code) { | 594 if (!code) { |
595 DCHECK(code_str.length() == 1); | 595 DCHECK(code_str.length() == 1); |
596 text = code = code_str[0]; | 596 text = code = code_str[0]; |
597 needs_shift_key_modifier = NeedsShiftModifier(code); | 597 needs_shift_key_modifier = NeedsShiftModifier(code); |
598 if ((code & 0xFF) >= 'a' && (code & 0xFF) <= 'z') | 598 if ((code & 0xFF) >= 'a' && (code & 0xFF) <= 'z') |
599 code -= 'a' - 'A'; | 599 code -= 'a' - 'A'; |
600 generate_char = true; | 600 generate_char = true; |
(...skipping 385 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
986 | 986 |
987 void EventSendingController::fireKeyboardEventsToElement( | 987 void EventSendingController::fireKeyboardEventsToElement( |
988 const CppArgumentList& args, CppVariant* result) { | 988 const CppArgumentList& args, CppVariant* result) { |
989 result->SetNull(); | 989 result->SetNull(); |
990 } | 990 } |
991 | 991 |
992 void EventSendingController::clearKillRing( | 992 void EventSendingController::clearKillRing( |
993 const CppArgumentList& args, CppVariant* result) { | 993 const CppArgumentList& args, CppVariant* result) { |
994 result->SetNull(); | 994 result->SetNull(); |
995 } | 995 } |
OLD | NEW |