Index: webkit/tools/test_shell/event_sending_controller.cc |
=================================================================== |
--- webkit/tools/test_shell/event_sending_controller.cc (revision 10793) |
+++ webkit/tools/test_shell/event_sending_controller.cc (working copy) |
@@ -29,6 +29,7 @@ |
#include "base/ref_counted.h" |
#include "base/string_util.h" |
#include "base/time.h" |
+#include "webkit/glue/webinputevent_util.h" |
#include "webkit/glue/webview.h" |
#include "webkit/tools/test_shell/test_shell.h" |
@@ -377,23 +378,27 @@ |
generate_char = true; |
} |
- // NOTE(jnd):For one keydown event, we need to generate |
- // keyDown/keyUp pair, refer EventSender.cpp in |
- // WebKit/WebKitTools/DumpRenderTree/win. We may also need |
- // to generate a keyChar event in certain cases. |
+ // For one generated keyboard event, we need to generate a keyDown/keyUp |
+ // pair; refer to EventSender.cpp in WebKit/WebKitTools/DumpRenderTree/win. |
+ // On Windows, we might also need to generate a char event to mimic the |
+ // Windows event flow; on other platforms we create a merged event and test |
+ // the event flow that that platform provides. |
WebKeyboardEvent event_down, event_up; |
+#if defined(OS_WIN) |
+ event_down.type = WebInputEvent::RAW_KEY_DOWN; |
+#else |
event_down.type = WebInputEvent::KEY_DOWN; |
+#endif |
event_down.modifiers = 0; |
- event_down.key_code = code; |
-#if defined(OS_LINUX) |
- // TODO(deanm): This code is a confusing mix of different platform key |
- // codes. Since we're not working with a GDK event, we can't use our |
- // GDK -> WebKit converter, which means the Linux specific extra |text| |
- // field goes uninitialized. I don't know how to correctly calculate this |
- // field, but for now we will at least initialize it, even if it's wrong. |
- event_down.text = code; |
-#endif |
+ event_down.windows_key_code = code; |
+ event_down.text[0] = code; |
+ event_down.unmodified_text[0] = code; |
+ std::string key_identifier_str = |
+ webkit_glue::GetKeyIdentifierForWindowsKeyCode(code); |
+ base::strlcpy(event_down.key_identifier, key_identifier_str.c_str(), |
+ kIdentifierLengthCap); |
+ |
if (args.size() >= 2 && (args[1].isObject() || args[1].isString())) |
ApplyKeyModifiers(&(args[1]), &event_down); |
@@ -408,11 +413,14 @@ |
webview()->HandleInputEvent(&event_down); |
+#if defined(OS_WIN) |
if (generate_char) { |
WebKeyboardEvent event_char = event_down; |
event_char.type = WebInputEvent::CHAR; |
+ event_char.key_identifier[0] = '\0'; |
webview()->HandleInputEvent(&event_char); |
} |
+#endif |
webview()->HandleInputEvent(&event_up); |
} |