VirtualBox

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

Last change on this file since 43814 was 31598, checked in by vboxsync, 14 years ago

EventQueue: Don't return VERR_TIMEOUT if we processed a message in waitForEventsOnDarwin. return VINF_INTERRUPTED when encountering EINTR.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 3.8 KB
Line 
1/** @file
2 * MS COM / XPCOM Abstraction Layer:
3 * Event and EventQueue class declaration
4 */
5
6/*
7 * Copyright (C) 2006-2010 Oracle Corporation
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
27#ifndef ___VBox_com_EventQueue_h
28#define ___VBox_com_EventQueue_h
29
30#ifndef VBOX_WITH_XPCOM
31# include <Windows.h>
32#else // VBOX_WITH_XPCOM
33# include <nsEventQueueUtils.h>
34#endif // VBOX_WITH_XPCOM
35
36#include <VBox/com/defs.h>
37#include <VBox/com/assert.h>
38
39namespace com
40{
41
42class EventQueue;
43
44/**
45 * Base class for all events. Intended to be subclassed to introduce new
46 * events and handlers for them.
47 *
48 * Subclasses usually reimplement virtual #handler() (that does nothing by
49 * default) and add new data members describing the event.
50 */
51class Event
52{
53public:
54
55 Event() {}
56 virtual ~Event() {};
57
58protected:
59
60 /**
61 * Event handler. Called in the context of the event queue's thread.
62 * Always reimplemented by subclasses
63 *
64 * @return reserved, should be NULL.
65 */
66 virtual void *handler() { return NULL; }
67
68 friend class EventQueue;
69};
70
71/**
72 * Simple event queue.
73 *
74 * When using XPCOM, this will map onto the default XPCOM queue for the thread.
75 * So, if a queue is created on the main thread, it automatically processes
76 * XPCOM/IPC events while waiting.
77 *
78 * When using Windows, Darwin and OS/2, this will map onto the native thread
79 * queue/runloop. So, windows messages and what not will be processed while
80 * waiting for events.
81 *
82 * @note It is intentional that there is no way to retrieve arbitrary
83 * events and controlling their processing. There is no use case which
84 * warrants introducing the complexity of platform independent events.
85 */
86class EventQueue
87{
88public:
89
90 EventQueue();
91 ~EventQueue();
92
93 BOOL postEvent(Event *event);
94 int processEventQueue(RTMSINTERVAL cMsTimeout);
95 int interruptEventQueueProcessing();
96 int getSelectFD();
97 static int init();
98 static int uninit();
99 static EventQueue *getMainEventQueue();
100
101#ifdef VBOX_WITH_XPCOM
102 already_AddRefed<nsIEventQueue> getIEventQueue()
103 {
104 return mEventQ.get();
105 }
106#else
107 static int dispatchMessageOnWindows(MSG const *pMsg, int rc);
108#endif
109
110private:
111 static EventQueue *sMainQueue;
112
113#ifndef VBOX_WITH_XPCOM
114
115 /** The thread which the queue belongs to. */
116 DWORD mThreadId;
117 /** Duplicated thread handle for MsgWaitForMultipleObjects. */
118 HANDLE mhThread;
119
120#else // VBOX_WITH_XPCOM
121
122 /** Whether it was created (and thus needs destroying) or if a queue already
123 * associated with the thread was used. */
124 bool mEQCreated;
125
126 /** Whether event processing should be interrupted. */
127 bool mInterrupted;
128
129 nsCOMPtr <nsIEventQueue> mEventQ;
130 nsCOMPtr <nsIEventQueueService> mEventQService;
131
132 static void *PR_CALLBACK plEventHandler(PLEvent *self);
133 static void PR_CALLBACK plEventDestructor(PLEvent *self);
134
135#endif // VBOX_WITH_XPCOM
136};
137
138} /* namespace com */
139
140#endif
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