VirtualBox

source: vbox/trunk/include/VBox/com/EventQueue.h@ 24130

Last change on this file since 24130 was 23092, checked in by vboxsync, 15 years ago

Main/glue: EventQueue bugfixes and code style adjustments and cleanups. Windows was polling instead of waiting and processEventQueue didn't return what it should on all platforms (nobody uses it currently, so that didn't break anything). Tested on 64-bit linux, 64-bit windows and 32-bit darwin.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.0 KB
Line 
1/** @file
2 * MS COM / XPCOM Abstraction Layer:
3 * Event and EventQueue class declaration
4 */
5
6/*
7 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 *
26 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
27 * Clara, CA 95054 USA or visit http://www.sun.com if you need
28 * additional information or have any questions.
29 */
30
31#ifndef ___VBox_com_EventQueue_h
32#define ___VBox_com_EventQueue_h
33
34#if !defined (VBOX_WITH_XPCOM)
35# include <Windows.h>
36#else
37# include <nsEventQueueUtils.h>
38#endif
39
40#include <VBox/com/defs.h>
41#include <VBox/com/assert.h>
42
43namespace com
44{
45
46class EventQueue;
47
48/**
49 * Base class for all events. Intended to be subclassed to introduce new events
50 * and handlers for them.
51 *
52 * Subclasses usually reimplement virtual #handler() (that does nothing by
53 * default) and add new data members describing the event.
54 */
55class Event
56{
57public:
58
59 Event() {}
60
61protected:
62
63 virtual ~Event() {};
64
65 /**
66 * Event handler. Called in the context of the event queue's thread.
67 * Always reimplemented by subclasses
68 *
69 * @return reserved, should be NULL.
70 */
71 virtual void *handler() { return NULL; }
72
73 friend class EventQueue;
74};
75
76/**
77 * Simple event queue.
78 *
79 * When using XPCOM, this will map onto the default XPCOM queue for the thread.
80 * So, if a queue is created on the main thread, it automatically processes
81 * XPCOM/IPC events while waiting for its own (Event) events.
82 *
83 * When using Windows, Darwin and OS/2, this will map onto the native thread
84 * queue/runloop. So, windows messages and want not will be processed while
85 * waiting for events.
86 */
87class EventQueue
88{
89public:
90
91 EventQueue();
92 ~EventQueue();
93
94 BOOL postEvent (Event *event);
95 BOOL waitForEvent (Event **event);
96 BOOL handleEvent (Event *event);
97 int processEventQueue(uint32_t cMsTimeout);
98 int interruptEventQueueProcessing();
99 int getSelectFD();
100 static int init();
101 static int uninit();
102 static EventQueue *getMainEventQueue();
103
104private:
105 static EventQueue *mMainQueue;
106
107#if !defined (VBOX_WITH_XPCOM)
108
109 /** The thread which the queue belongs to. */
110 DWORD mThreadId;
111 /** Duplicated thread handle for MsgWaitForMultipleObjects. */
112 HANDLE mhThread;
113
114#else
115
116 /** Whether it was created (and thus needs destroying) or if a queue already
117 * associated with the thread was used. */
118 BOOL mEQCreated;
119
120 nsCOMPtr <nsIEventQueue> mEventQ;
121 nsCOMPtr <nsIEventQueueService> mEventQService;
122
123 Event *mLastEvent;
124 BOOL mGotEvent;
125
126 struct MyPLEvent : public PLEvent
127 {
128 MyPLEvent (Event *e) : event (e) {}
129 Event *event;
130 };
131
132 static void * PR_CALLBACK plEventHandler (PLEvent* self)
133 {
134 // nsIEventQueue doesn't expose PL_GetEventOwner(), so use an internal
135 // field of PLEvent directly (hackish, but doesn' require an extra lib)
136 EventQueue *owner = (EventQueue *) self->owner;
137 Assert (owner);
138 owner->mLastEvent = ((MyPLEvent *) self)->event;
139 owner->mGotEvent = TRUE;
140 return 0;
141 }
142
143 static void PR_CALLBACK plEventDestructor (PLEvent* self) { delete self; }
144
145#endif
146};
147
148} /* namespace com */
149
150#endif
151
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette