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

Unified Diff: ui/base/events/key_identifier_conversion.cc

Issue 13957005: Move KeyIdentifier->KeyEvent conversion to src/ui/. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: gyp fix Created 7 years, 8 months 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « ui/base/events/key_identifier_conversion.h ('k') | ui/base/events/key_identifier_conversion_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ui/base/events/key_identifier_conversion.cc
diff --git a/chrome/browser/extensions/key_identifier_conversion_views.cc b/ui/base/events/key_identifier_conversion.cc
similarity index 96%
rename from chrome/browser/extensions/key_identifier_conversion_views.cc
rename to ui/base/events/key_identifier_conversion.cc
index d87b61a0341c6b2e0c0dc50de6df5b2df712c79b..12092b6993d7aac284d7f59e28b7aecd406efec0 100644
--- a/chrome/browser/extensions/key_identifier_conversion_views.cc
+++ b/ui/base/events/key_identifier_conversion.cc
@@ -2,24 +2,19 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-#include "chrome/browser/extensions/key_identifier_conversion_views.h"
+#include "ui/base/events/key_identifier_conversion.h"
#include <string.h>
-
#include <utility>
#include "base/basictypes.h"
#include "base/hash_tables.h"
-#include "base/logging.h"
-#include "content/public/browser/browser_thread.h"
#include "ui/base/events/event.h"
#include "ui/base/keycodes/keyboard_codes.h"
-using content::BrowserThread;
-
namespace {
-static const int kNumIdentifierTypes = 3;
+const int kNumIdentifierTypes = 3;
typedef struct KeyIdentifier {
// In order: key identifier, character and unicode codepoint. They are
@@ -34,8 +29,8 @@ typedef struct KeyIdentifier {
// Taken from Section 6.3.3 here:
// http://www.w3.org/TR/DOM-Level-3-Events/#keyset-keyidentifiers
-// TODO(bryeung): keycodes could be wrong: I took the keydown code only
-static const KeyIdentifier kKeyIdentifiers[] = {
+// WARNING: keycodes could be wrong, as they are based soley on keydown
+const KeyIdentifier kKeyIdentifiers[] = {
{ {"Accept", "", ""}, ui::VKEY_ACCEPT, 0 },
{ {"Add", "", ""}, ui::VKEY_ADD, 0 },
{ {"Again", "", ""}, ui::VKEY_UNKNOWN, 0 },
@@ -286,15 +281,15 @@ static const KeyIdentifier kKeyIdentifiers[] = {
{ {"DeadSemivoicedSound", "", "U+309A"}, ui::VKEY_UNKNOWN, 0 }
};
-static const int kNumKeyIdentifiers = arraysize(kKeyIdentifiers);
+const int kNumKeyIdentifiers = arraysize(kKeyIdentifiers);
typedef base::hash_map<std::string, const ui::KeyEvent*> IdentifierMap;
typedef std::pair<std::string, const ui::KeyEvent*> IdentifierPair;
-static IdentifierMap* identifierMaps[kNumIdentifierTypes] = { NULL };
+IdentifierMap* identifierMaps[kNumIdentifierTypes] = { NULL };
-static ui::KeyEvent* kUnknownKeyEvent = NULL;
+ui::KeyEvent* kUnknownKeyEvent = NULL;
-static void InitializeMaps() {
+void InitializeMaps() {
if (identifierMaps[0])
return;
@@ -326,10 +321,12 @@ static void InitializeMaps() {
} // namespace
+namespace ui {
const ui::KeyEvent& KeyEventFromKeyIdentifier(
const std::string& key_identifier) {
- DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
+ // This lazily initializes lookup tables for the conversion. To prevent
+ // races, it should only ever be called from a single thread.
InitializeMaps();
for (int i = 0; i < kNumIdentifierTypes; ++i) {
@@ -342,3 +339,5 @@ const ui::KeyEvent& KeyEventFromKeyIdentifier(
return *kUnknownKeyEvent;
}
+
+} // namespace ui
« no previous file with comments | « ui/base/events/key_identifier_conversion.h ('k') | ui/base/events/key_identifier_conversion_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698