1 | /** @file
|
---|
2 | *
|
---|
3 | * Guest client: seamless mode
|
---|
4 | * Abstract class for interacting with the guest system
|
---|
5 | */
|
---|
6 |
|
---|
7 | /*
|
---|
8 | * Copyright (C) 2006-2007 Sun Microsystems, Inc.
|
---|
9 | *
|
---|
10 | * This file is part of VirtualBox Open Source Edition (OSE), as
|
---|
11 | * available from http://www.virtualbox.org. This file is free software;
|
---|
12 | * you can redistribute it and/or modify it under the terms of the GNU
|
---|
13 | * General Public License (GPL) as published by the Free Software
|
---|
14 | * Foundation, in version 2 as it comes in the "COPYING" file of the
|
---|
15 | * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
|
---|
16 | * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
|
---|
17 | *
|
---|
18 | * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
|
---|
19 | * Clara, CA 95054 USA or visit http://www.sun.com if you need
|
---|
20 | * additional information or have any questions.
|
---|
21 | */
|
---|
22 |
|
---|
23 | #ifndef __Additions_client_seamless_guest_h
|
---|
24 | # define __Additions_client_seamless_guest_h
|
---|
25 |
|
---|
26 | #include <memory> /* for auto_ptr */
|
---|
27 | #include <vector> /* for vector */
|
---|
28 |
|
---|
29 | #include <iprt/types.h> /* for RTRECT */
|
---|
30 |
|
---|
31 | #include "seamless-glue.h"
|
---|
32 |
|
---|
33 | /**
|
---|
34 | * Observable to monitor the state of the guest windows. This abstract class definition
|
---|
35 | * serves as a template (in the linguistic sense, not the C++ sense) for creating
|
---|
36 | * platform-specific child classes.
|
---|
37 | */
|
---|
38 | class VBoxGuestSeamlessGuest
|
---|
39 | {
|
---|
40 | public:
|
---|
41 | /** Events which can be reported by this class */
|
---|
42 | enum meEvent
|
---|
43 | {
|
---|
44 | /** Empty event */
|
---|
45 | NONE,
|
---|
46 | /** Seamless mode is now supported */
|
---|
47 | CAPABLE,
|
---|
48 | /** Seamless mode is no longer supported */
|
---|
49 | INCAPABLE
|
---|
50 | };
|
---|
51 |
|
---|
52 | /**
|
---|
53 | * Initialise the guest and ensure that it is capable of handling seamless mode
|
---|
54 | *
|
---|
55 | * @param pObserver An observer object to which to report changes in state and events
|
---|
56 | * by calling its notify() method. A state change to CAPABLE also
|
---|
57 | * signals new seamless data.
|
---|
58 | * @returns iprt status code
|
---|
59 | */
|
---|
60 | int init(VBoxGuestSeamlessObserver *pObserver);
|
---|
61 |
|
---|
62 | /**
|
---|
63 | * Shutdown seamless event monitoring.
|
---|
64 | */
|
---|
65 | void uninit(void);
|
---|
66 |
|
---|
67 | /**
|
---|
68 | * Initialise seamless event reporting in the guest.
|
---|
69 | *
|
---|
70 | * @returns IPRT status code
|
---|
71 | */
|
---|
72 | int start(void);
|
---|
73 | /** Stop reporting seamless events. */
|
---|
74 | void stop(void);
|
---|
75 | /** Get the current state of the guest (capable or incapable of seamless mode). */
|
---|
76 | // meEvent getState(void);
|
---|
77 | /** Get the current list of visible rectangles. */
|
---|
78 | std::auto_ptr<std::vector<RTRECT> > getRects(void);
|
---|
79 | /** Process next event in the guest event queue - called by the event thread. */
|
---|
80 | void nextEvent(void);
|
---|
81 | /** Wake up the event thread if it is waiting for an event so that it can exit. */
|
---|
82 | bool interruptEvent(void);
|
---|
83 | };
|
---|
84 |
|
---|
85 | #if defined(RT_OS_LINUX) || defined(RT_OS_SOLARIS) || defined(RT_OS_FREEBSD)
|
---|
86 | # include "seamless-x11.h" /* for VBoxGuestSeamlessGuestImpl */
|
---|
87 | #else
|
---|
88 | # error Port me
|
---|
89 | #endif
|
---|
90 |
|
---|
91 | #endif /* __Additions_client_seamless_guest_h not defined */
|
---|