1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef BASE_MESSAGE_PUMP_GTK_H_
6 #define BASE_MESSAGE_PUMP_GTK_H_
8 #include "base/message_pump_glib.h"
10 typedef union _GdkEvent GdkEvent
;
11 typedef struct _XDisplay Display
;
15 // The documentation for this class is in message_pump_glib.h
16 class MessagePumpObserver
{
18 // This method is called before processing a message.
19 virtual void WillProcessEvent(GdkEvent
* event
) = 0;
21 // This method is called after processing a message.
22 virtual void DidProcessEvent(GdkEvent
* event
) = 0;
25 virtual ~MessagePumpObserver() {}
28 // The documentation for this class is in message_pump_glib.h
30 // The nested loop is exited by either posting a quit, or returning false
32 class MessagePumpDispatcher
{
34 // Dispatches the event. If true is returned processing continues as
35 // normal. If false is returned, the nested loop exits immediately.
36 virtual bool Dispatch(GdkEvent
* event
) = 0;
39 virtual ~MessagePumpDispatcher() {}
42 // This class implements a message-pump for dispatching GTK events.
43 class BASE_EXPORT MessagePumpGtk
: public MessagePumpGlib
{
47 // Dispatch an available GdkEvent. Essentially this allows a subclass to do
48 // some task before/after calling the default handler (EventDispatcher).
49 void DispatchEvents(GdkEvent
* event
);
51 // Returns default X Display.
52 static Display
* GetDefaultXDisplay();
55 virtual ~MessagePumpGtk();
58 // Invoked from EventDispatcher. Notifies all observers we're about to
60 void WillProcessEvent(GdkEvent
* event
);
62 // Invoked from EventDispatcher. Notifies all observers we processed an
64 void DidProcessEvent(GdkEvent
* event
);
66 // Callback prior to gdk dispatching an event.
67 static void EventDispatcher(GdkEvent
* event
, void* data
);
69 DISALLOW_COPY_AND_ASSIGN(MessagePumpGtk
);
72 typedef MessagePumpGtk MessagePumpForUI
;
76 #endif // BASE_MESSAGE_PUMP_GTK_H_