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

Unified Diff: base/message_pump_glib_x.cc

Issue 7250001: Refactor the glib message-pump, and use it as the base for a gtk message pump and an X message pump. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: media.gyp update Created 9 years, 6 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 | « base/message_pump_glib_x.h ('k') | base/message_pump_glib_x_dispatch.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: base/message_pump_glib_x.cc
diff --git a/base/message_pump_glib_x.cc b/base/message_pump_glib_x.cc
deleted file mode 100644
index 430d9379944dd01d3efe5b50f5cc5eb40e49067f..0000000000000000000000000000000000000000
--- a/base/message_pump_glib_x.cc
+++ /dev/null
@@ -1,234 +0,0 @@
-// Copyright (c) 2011 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "base/message_pump_glib_x.h"
-
-#include <gdk/gdkx.h>
-#if defined(HAVE_XINPUT2)
-#include <X11/extensions/XInput2.h>
-#else
-#include <X11/Xlib.h>
-#endif
-
-#include "base/message_pump_glib_x_dispatch.h"
-
-namespace {
-
-gboolean PlaceholderDispatch(GSource* source,
- GSourceFunc cb,
- gpointer data) {
- return TRUE;
-}
-
-} // namespace
-
-namespace base {
-
-MessagePumpGlibX::MessagePumpGlibX() : base::MessagePumpForUI(),
-#if defined(HAVE_XINPUT2)
- xiopcode_(-1),
-#endif
- gdksource_(NULL),
- dispatching_event_(false),
- capture_x_events_(0),
- capture_gdk_events_(0) {
- gdk_window_add_filter(NULL, &GdkEventFilter, this);
- gdk_event_handler_set(&EventDispatcherX, this, NULL);
-
-#if defined(HAVE_XINPUT2)
- InitializeXInput2();
-#endif
- InitializeEventsToCapture();
-}
-
-MessagePumpGlibX::~MessagePumpGlibX() {
- gdk_window_remove_filter(NULL, &GdkEventFilter, this);
-
- // It is not necessary to reset the GDK event handler using
- // gdk_event_handler_set since it's done in the destructor for
- // MessagePumpForUI.
-}
-
-bool MessagePumpGlibX::ShouldCaptureXEvent(XEvent* xev) {
- return capture_x_events_[xev->type]
-#if defined(HAVE_XINPUT2)
- && (xev->type != GenericEvent || xev->xcookie.extension == xiopcode_)
-#endif
- ;
-}
-
-
-bool MessagePumpGlibX::ProcessXEvent(XEvent* xev) {
- bool should_quit = false;
-
-#if defined(HAVE_XINPUT2)
- bool have_cookie = false;
- if (xev->type == GenericEvent &&
- XGetEventData(xev->xgeneric.display, &xev->xcookie)) {
- have_cookie = true;
- }
-#endif
-
- if (!WillProcessXEvent(xev)) {
- MessagePumpGlibXDispatcher::DispatchStatus status =
- static_cast<MessagePumpGlibXDispatcher*>
- (GetDispatcher())->DispatchX(xev);
-
- if (status == MessagePumpGlibXDispatcher::EVENT_QUIT) {
- should_quit = true;
- Quit();
- } else if (status == MessagePumpGlibXDispatcher::EVENT_IGNORED) {
- VLOG(1) << "Event (" << xev->type << ") not handled.";
- }
- }
-
-#if defined(HAVE_XINPUT2)
- if (have_cookie) {
- XFreeEventData(xev->xgeneric.display, &xev->xcookie);
- }
-#endif
-
- return should_quit;
-}
-
-bool MessagePumpGlibX::RunOnce(GMainContext* context, bool block) {
- GdkDisplay* gdisp = gdk_display_get_default();
- if (!gdisp || !GetDispatcher())
- return MessagePumpForUI::RunOnce(context, block);
-
- Display* display = GDK_DISPLAY_XDISPLAY(gdisp);
-
- if (XPending(display)) {
- XEvent xev;
- XPeekEvent(display, &xev);
-
- if (ShouldCaptureXEvent(&xev)) {
- XNextEvent(display, &xev);
- if (ProcessXEvent(&xev))
- return true;
- } else {
- // TODO(sad): A couple of extra events can still sneak in during this.
- // Those should be sent back to the X queue from the dispatcher
- // EventDispatcherX.
- if (gdksource_)
- gdksource_->source_funcs->dispatch = gdkdispatcher_;
- g_main_context_iteration(context, FALSE);
- }
- }
-
- bool retvalue;
- if (gdksource_) {
- // Replace the dispatch callback of the GDK event source temporarily so that
- // it doesn't read events from X.
- gboolean (*cb)(GSource*, GSourceFunc, void*) =
- gdksource_->source_funcs->dispatch;
- gdksource_->source_funcs->dispatch = PlaceholderDispatch;
-
- dispatching_event_ = true;
- retvalue = g_main_context_iteration(context, block);
- dispatching_event_ = false;
-
- gdksource_->source_funcs->dispatch = cb;
- } else {
- retvalue = g_main_context_iteration(context, block);
- }
-
- return retvalue;
-}
-
-GdkFilterReturn MessagePumpGlibX::GdkEventFilter(GdkXEvent* gxevent,
- GdkEvent* gevent,
- gpointer data) {
- MessagePumpGlibX* pump = static_cast<MessagePumpGlibX*>(data);
- XEvent* xev = static_cast<XEvent*>(gxevent);
-
- if (pump->ShouldCaptureXEvent(xev) && pump->GetDispatcher()) {
- pump->ProcessXEvent(xev);
- return GDK_FILTER_REMOVE;
- }
-
- return GDK_FILTER_CONTINUE;
-}
-
-bool MessagePumpGlibX::WillProcessXEvent(XEvent* xevent) {
- ObserverListBase<Observer>::Iterator it(observers());
- Observer* obs;
- while ((obs = it.GetNext()) != NULL) {
- MessagePumpXObserver* xobs =
- static_cast<MessagePumpXObserver*>(obs);
- if (xobs->WillProcessXEvent(xevent))
- return true;
- }
- return false;
-}
-
-void MessagePumpGlibX::EventDispatcherX(GdkEvent* event, gpointer data) {
- MessagePumpGlibX* pump_x = reinterpret_cast<MessagePumpGlibX*>(data);
-
- if (!pump_x->gdksource_) {
- pump_x->gdksource_ = g_main_current_source();
- if (pump_x->gdksource_)
- pump_x->gdkdispatcher_ = pump_x->gdksource_->source_funcs->dispatch;
- } else if (!pump_x->IsDispatchingEvent()) {
- if (event->type != GDK_NOTHING &&
- pump_x->capture_gdk_events_[event->type]) {
- NOTREACHED() << "GDK received an event it shouldn't have";
- }
- }
-
- pump_x->DispatchEvents(event);
-}
-
-void MessagePumpGlibX::InitializeEventsToCapture(void) {
- // TODO(sad): Decide which events we want to capture and update the tables
- // accordingly.
- capture_x_events_[KeyPress] = true;
- capture_gdk_events_[GDK_KEY_PRESS] = true;
-
- capture_x_events_[KeyRelease] = true;
- capture_gdk_events_[GDK_KEY_RELEASE] = true;
-
- capture_x_events_[ButtonPress] = true;
- capture_gdk_events_[GDK_BUTTON_PRESS] = true;
-
- capture_x_events_[ButtonRelease] = true;
- capture_gdk_events_[GDK_BUTTON_RELEASE] = true;
-
- capture_x_events_[MotionNotify] = true;
- capture_gdk_events_[GDK_MOTION_NOTIFY] = true;
-
-#if defined(HAVE_XINPUT2)
- capture_x_events_[GenericEvent] = true;
-#endif
-}
-
-#if defined(HAVE_XINPUT2)
-void MessagePumpGlibX::InitializeXInput2(void) {
- GdkDisplay* display = gdk_display_get_default();
- if (!display)
- return;
-
- Display* xdisplay = GDK_DISPLAY_XDISPLAY(display);
- int event, err;
-
- if (!XQueryExtension(xdisplay, "XInputExtension", &xiopcode_, &event, &err)) {
- VLOG(1) << "X Input extension not available.";
- xiopcode_ = -1;
- return;
- }
-
- int major = 2, minor = 0;
- if (XIQueryVersion(xdisplay, &major, &minor) == BadRequest) {
- VLOG(1) << "XInput2 not supported in the server.";
- xiopcode_ = -1;
- return;
- }
-}
-#endif // HAVE_XINPUT2
-
-bool MessagePumpXObserver::WillProcessXEvent(XEvent* xev) {
- return false;
-}
-
-} // namespace base
« no previous file with comments | « base/message_pump_glib_x.h ('k') | base/message_pump_glib_x_dispatch.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698