1 | /** @file
|
---|
2 | *
|
---|
3 | * Shared Clipboard
|
---|
4 | */
|
---|
5 |
|
---|
6 | /*
|
---|
7 | * Copyright (C) 2006-2007 innotek GmbH
|
---|
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 as published by the Free Software Foundation,
|
---|
13 | * in version 2 as it comes in the "COPYING" file of the VirtualBox OSE
|
---|
14 | * distribution. VirtualBox OSE is distributed in the hope that it will
|
---|
15 | * be useful, but WITHOUT ANY WARRANTY of any kind.
|
---|
16 | *
|
---|
17 | * If you received this file as part of a commercial VirtualBox
|
---|
18 | * distribution, then only the terms of your commercial VirtualBox
|
---|
19 | * license agreement apply instead of the previous paragraph.
|
---|
20 | */
|
---|
21 |
|
---|
22 | #ifndef __VBOXCLIPBOARD__H
|
---|
23 | #define __VBOXCLIPBOARD__H
|
---|
24 |
|
---|
25 | #define LOG_GROUP LOG_GROUP_HGCM
|
---|
26 | #include <VBox/log.h>
|
---|
27 |
|
---|
28 | /** Constants needed for string conversions done by the Linux clipboard code. */
|
---|
29 | enum {
|
---|
30 | /** In Linux, lines end with a linefeed character. */
|
---|
31 | LINEFEED = 0xa,
|
---|
32 | /** In Windows, lines end with a carriage return and a linefeed character. */
|
---|
33 | CARRIAGERETURN = 0xd,
|
---|
34 | /** Little endian "real" Utf16 strings start with this marker. */
|
---|
35 | UTF16LEMARKER = 0xfeff,
|
---|
36 | /** Big endian "real" Utf16 strings start with this marker. */
|
---|
37 | UTF16BEMARKER = 0xfffe
|
---|
38 | };
|
---|
39 |
|
---|
40 | enum {
|
---|
41 | /** The number of milliseconds before the clipboard times out. */
|
---|
42 | CLIPBOARDTIMEOUT = 2000
|
---|
43 | };
|
---|
44 |
|
---|
45 | struct _VBOXCLIPBOARDCONTEXT;
|
---|
46 | typedef struct _VBOXCLIPBOARDCONTEXT VBOXCLIPBOARDCONTEXT;
|
---|
47 |
|
---|
48 |
|
---|
49 | typedef struct _VBOXCLIPBOARDCLIENTDATA
|
---|
50 | {
|
---|
51 | struct _VBOXCLIPBOARDCLIENTDATA *pNext;
|
---|
52 | struct _VBOXCLIPBOARDCLIENTDATA *pPrev;
|
---|
53 |
|
---|
54 | VBOXCLIPBOARDCONTEXT *pCtx;
|
---|
55 |
|
---|
56 | uint32_t u32ClientID;
|
---|
57 |
|
---|
58 | bool fAsync: 1; /* Guest is waiting for a message. */
|
---|
59 |
|
---|
60 | bool fMsgQuit: 1;
|
---|
61 | bool fMsgReadData: 1;
|
---|
62 | bool fMsgFormats: 1;
|
---|
63 |
|
---|
64 | struct {
|
---|
65 | VBOXHGCMCALLHANDLE callHandle;
|
---|
66 | VBOXHGCMSVCPARM *paParms;
|
---|
67 | } async;
|
---|
68 |
|
---|
69 | struct {
|
---|
70 | void *pv;
|
---|
71 | uint32_t cb;
|
---|
72 | uint32_t u32Format;
|
---|
73 | } data;
|
---|
74 |
|
---|
75 | uint32_t u32AvailableFormats;
|
---|
76 | uint32_t u32RequestedFormat;
|
---|
77 |
|
---|
78 | } VBOXCLIPBOARDCLIENTDATA;
|
---|
79 |
|
---|
80 | /*
|
---|
81 | * The service functions. Locking is between the service thread and the platform dependedn windows thread.
|
---|
82 | */
|
---|
83 | bool vboxSvcClipboardLock (void);
|
---|
84 | void vboxSvcClipboardUnlock (void);
|
---|
85 |
|
---|
86 | void vboxSvcClipboardReportMsg (VBOXCLIPBOARDCLIENTDATA *pClient, uint32_t u32Msg, uint32_t u32Formats);
|
---|
87 |
|
---|
88 |
|
---|
89 | /*
|
---|
90 | * Platform dependent functions.
|
---|
91 | */
|
---|
92 | int vboxClipboardInit (void);
|
---|
93 | void vboxClipboardDestroy (void);
|
---|
94 |
|
---|
95 | int vboxClipboardConnect (VBOXCLIPBOARDCLIENTDATA *pClient);
|
---|
96 | void vboxClipboardDisconnect (VBOXCLIPBOARDCLIENTDATA *pClient);
|
---|
97 |
|
---|
98 | void vboxClipboardFormatAnnounce (VBOXCLIPBOARDCLIENTDATA *pClient, uint32_t u32Formats);
|
---|
99 |
|
---|
100 | int vboxClipboardReadData (VBOXCLIPBOARDCLIENTDATA *pClient, uint32_t u32Format, void *pv, uint32_t cb, uint32_t *pcbActual);
|
---|
101 |
|
---|
102 | void vboxClipboardWriteData (VBOXCLIPBOARDCLIENTDATA *pClient, void *pv, uint32_t cb, uint32_t u32Format);
|
---|
103 |
|
---|
104 | int vboxClipboardSync (VBOXCLIPBOARDCLIENTDATA *pClient);
|
---|
105 |
|
---|
106 | #endif /* __VBOXCLIPBOARD__H */
|
---|