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

Side by Side Diff: chrome/browser/ui/libgtk2ui/x11_input_method_context_impl_gtk2.cc

Issue 235043005: x11: Remove X11 message-pump. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: tot-merge Created 6 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « chrome/browser/ui/libgtk2ui/gtk2_event_loop.cc ('k') | content/browser/browser_main_loop.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 "chrome/browser/ui/libgtk2ui/x11_input_method_context_impl_gtk2.h" 5 #include "chrome/browser/ui/libgtk2ui/x11_input_method_context_impl_gtk2.h"
6 6
7 #include <gdk/gdk.h> 7 #include <gdk/gdk.h>
8 #include <gdk/gdkkeysyms.h> 8 #include <gdk/gdkkeysyms.h>
9 #include <gdk/gdkx.h> 9 #include <gdk/gdkx.h>
10 10
11 #include <gtk/gtk.h> 11 #include <gtk/gtk.h>
12 12
13 #include <X11/X.h> 13 #include <X11/X.h>
14 #include <X11/Xlib.h> 14 #include <X11/Xlib.h>
15 15
16 #include "base/event_types.h" 16 #include "base/event_types.h"
17 #include "base/message_loop/message_loop.h" 17 #include "base/message_loop/message_loop.h"
18 #include "base/strings/utf_string_conversions.h" 18 #include "base/strings/utf_string_conversions.h"
19 #include "ui/base/ime/composition_text.h" 19 #include "ui/base/ime/composition_text.h"
20 #include "ui/base/ime/composition_text_util_pango.h" 20 #include "ui/base/ime/composition_text_util_pango.h"
21 #include "ui/base/ime/text_input_client.h" 21 #include "ui/base/ime/text_input_client.h"
22 #include "ui/events/event.h" 22 #include "ui/events/event.h"
23 #include "ui/gfx/x/x11_types.h"
23 24
24 namespace { 25 namespace {
25 26
26 // Constructs a GdkEventKey from a XKeyEvent and returns it. Otherwise, 27 // Constructs a GdkEventKey from a XKeyEvent and returns it. Otherwise,
27 // returns NULL. The returned GdkEvent must be freed by gdk_event_free. 28 // returns NULL. The returned GdkEvent must be freed by gdk_event_free.
28 GdkEvent* GdkEventFromXKeyEvent(XKeyEvent& xkey, bool is_modifier) { 29 GdkEvent* GdkEventFromXKeyEvent(XKeyEvent& xkey, bool is_modifier) {
29 DCHECK(xkey.type == KeyPress || xkey.type == KeyRelease); 30 DCHECK(xkey.type == KeyPress || xkey.type == KeyRelease);
30 31
31 // Get a GdkDisplay. 32 // Get a GdkDisplay.
32 GdkDisplay* display = gdk_x11_lookup_xdisplay(xkey.display); 33 GdkDisplay* display = gdk_x11_lookup_xdisplay(xkey.display);
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after
96 97
97 X11InputMethodContextImplGtk2::X11InputMethodContextImplGtk2( 98 X11InputMethodContextImplGtk2::X11InputMethodContextImplGtk2(
98 ui::LinuxInputMethodContextDelegate* delegate) 99 ui::LinuxInputMethodContextDelegate* delegate)
99 : delegate_(delegate), 100 : delegate_(delegate),
100 gtk_context_simple_(NULL), 101 gtk_context_simple_(NULL),
101 gtk_multicontext_(NULL), 102 gtk_multicontext_(NULL),
102 gtk_context_(NULL) { 103 gtk_context_(NULL) {
103 CHECK(delegate_); 104 CHECK(delegate_);
104 105
105 { 106 {
106 XModifierKeymap* keymap = XGetModifierMapping( 107 XModifierKeymap* keymap = XGetModifierMapping(gfx::GetXDisplay());
107 base::MessagePumpForUI::GetDefaultXDisplay());
108 for (int i = 0; i < 8 * keymap->max_keypermod; ++i) { 108 for (int i = 0; i < 8 * keymap->max_keypermod; ++i) {
109 if (keymap->modifiermap[i]) 109 if (keymap->modifiermap[i])
110 modifier_keycodes_.insert(keymap->modifiermap[i]); 110 modifier_keycodes_.insert(keymap->modifiermap[i]);
111 } 111 }
112 XFreeModifiermap(keymap); 112 XFreeModifiermap(keymap);
113 } 113 }
114 114
115 gtk_context_simple_ = gtk_im_context_simple_new(); 115 gtk_context_simple_ = gtk_im_context_simple_new();
116 gtk_multicontext_ = gtk_im_multicontext_new(); 116 gtk_multicontext_ = gtk_im_multicontext_new();
117 117
(...skipping 184 matching lines...) Expand 10 before | Expand all | Expand 10 after
302 text.length() == 1 && 302 text.length() == 1 &&
303 text[0] == gdk_keyval_to_unicode(gdk_event_key_keyval_)) { 303 text[0] == gdk_keyval_to_unicode(gdk_event_key_keyval_)) {
304 is_signal_caught_ = true; 304 is_signal_caught_ = true;
305 return true; 305 return true;
306 } else { 306 } else {
307 return false; 307 return false;
308 } 308 }
309 } 309 }
310 310
311 } // namespace libgtk2ui 311 } // namespace libgtk2ui
OLDNEW
« no previous file with comments | « chrome/browser/ui/libgtk2ui/gtk2_event_loop.cc ('k') | content/browser/browser_main_loop.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698