VirtualBox

source: vbox/trunk/include/VBox/GuestHost/DragAndDrop.h@ 82193

Last change on this file since 82193 was 79482, checked in by vboxsync, 6 years ago

x11/VBoxClient: Heed RT_NEED_NEW_AND_DELETE.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 10.2 KB
Line 
1/* $Id: DragAndDrop.h 79482 2019-07-03 02:35:37Z vboxsync $ */
2/** @file
3 * DnD - Shared functions between host and guest.
4 */
5
6/*
7 * Copyright (C) 2014-2019 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_INCLUDED_GuestHost_DragAndDrop_h
28#define VBOX_INCLUDED_GuestHost_DragAndDrop_h
29#ifndef RT_WITHOUT_PRAGMA_ONCE
30# pragma once
31#endif
32
33#include <iprt/assert.h>
34#include <iprt/fs.h>
35
36#include <iprt/cpp/list.h>
37#include <iprt/cpp/ministring.h>
38
39/** DnDURIDroppedFiles flags. */
40typedef uint32_t DNDURIDROPPEDFILEFLAGS;
41
42/** No flags specified. */
43#define DNDURIDROPPEDFILE_FLAGS_NONE 0
44
45/**
46 * Class for maintaining a "dropped files" directory
47 * on the host or guest. This will contain all received files & directories
48 * for a single drag and drop operation.
49 *
50 * In case of a failed drag and drop operation this class can also
51 * perform a gentle rollback if required.
52 */
53class DnDDroppedFiles
54{
55public:
56#ifdef RT_NEED_NEW_AND_DELETE
57 RTMEM_IMPLEMENT_NEW_AND_DELETE();
58#endif
59 DnDDroppedFiles(void);
60 DnDDroppedFiles(const char *pszPath, DNDURIDROPPEDFILEFLAGS fFlags = DNDURIDROPPEDFILE_FLAGS_NONE);
61 virtual ~DnDDroppedFiles(void);
62
63public:
64
65 int AddFile(const char *pszFile);
66 int AddDir(const char *pszDir);
67 int Close(void);
68 bool IsOpen(void) const;
69 int OpenEx(const char *pszPath, DNDURIDROPPEDFILEFLAGS fFlags = DNDURIDROPPEDFILE_FLAGS_NONE);
70 int OpenTemp(DNDURIDROPPEDFILEFLAGS fFlags = DNDURIDROPPEDFILE_FLAGS_NONE);
71 const char *GetDirAbs(void) const;
72 int Reopen(void);
73 int Reset(bool fDeleteContent);
74 int Rollback(void);
75
76protected:
77
78 int closeInternal(void);
79
80protected:
81
82 /** Open flags. */
83 uint32_t m_fOpen;
84 /** Directory handle for drop directory. */
85 RTDIR m_hDir;
86 /** Absolute path to drop directory. */
87 RTCString m_strPathAbs;
88 /** List for holding created directories in the case of a rollback. */
89 RTCList<RTCString> m_lstDirs;
90 /** List for holding created files in the case of a rollback. */
91 RTCList<RTCString> m_lstFiles;
92};
93
94bool DnDMIMEHasFileURLs(const char *pcszFormat, size_t cchFormatMax);
95bool DnDMIMENeedsDropDir(const char *pcszFormat, size_t cchFormatMax);
96
97int DnDPathSanitizeFilename(char *pszPath, size_t cbPath);
98int DnDPathSanitize(char *pszPath, size_t cbPath);
99
100/** DnDURIObject flags. */
101typedef uint32_t DNDURIOBJECTFLAGS;
102
103/** No flags specified. */
104#define DNDURIOBJECT_FLAGS_NONE 0
105
106/** Mask of all valid DnD URI object flags. */
107#define DNDURIOBJECT_FLAGS_VALID_MASK UINT32_C(0x0)
108
109/**
110 * Class for handling DnD URI objects.
111 * This class abstracts the access and handling objects when performing DnD actions.
112 */
113class DnDURIObject
114{
115public:
116
117 /**
118 * Enumeration for specifying an URI object type.
119 */
120 enum Type
121 {
122 /** Unknown type, do not use. */
123 Type_Unknown = 0,
124 /** Object is a file. */
125 Type_File,
126 /** Object is a directory. */
127 Type_Directory,
128 /** The usual 32-bit hack. */
129 Type_32Bit_Hack = 0x7fffffff
130 };
131
132 /**
133 * Enumeration for specifying an URI object view
134 * for representing its data accordingly.
135 */
136 enum View
137 {
138 /** Unknown view, do not use. */
139 View_Unknown = 0,
140 /** Handle data from the source point of view. */
141 View_Source,
142 /** Handle data from the destination point of view. */
143 View_Target,
144 /** The usual 32-bit hack. */
145 View_Dest_32Bit_Hack = 0x7fffffff
146 };
147
148#ifdef RT_NEED_NEW_AND_DELETE
149 RTMEM_IMPLEMENT_NEW_AND_DELETE();
150#endif
151 DnDURIObject(void);
152 DnDURIObject(Type type,
153 const RTCString &strSrcPathAbs = "",
154 const RTCString &strDstPathAbs = "");
155 virtual ~DnDURIObject(void);
156
157public:
158
159 /**
160 * Returns the given absolute source path of the object.
161 *
162 * @return Absolute source path of the object.
163 */
164 const RTCString &GetSourcePathAbs(void) const { return m_strSrcPathAbs; }
165
166 /**
167 * Returns the given, absolute destination path of the object.
168 *
169 * @return Absolute destination path of the object.
170 */
171 const RTCString &GetDestPathAbs(void) const { return m_strTgtPathAbs; }
172
173 RTFMODE GetMode(void) const;
174
175 uint64_t GetProcessed(void) const;
176
177 uint64_t GetSize(void) const;
178
179 /**
180 * Returns the object's type.
181 *
182 * @return The object's type.
183 */
184 Type GetType(void) const { return m_enmType; }
185
186 /**
187 * Returns the object's view.
188 *
189 * @return The object's view.
190 */
191 View GetView(void) const { return m_enmView; }
192
193public:
194
195 int SetSize(uint64_t cbSize);
196
197public:
198
199 void Close(void);
200 bool IsComplete(void) const;
201 bool IsOpen(void) const;
202 int Open(View enmView, uint64_t fOpen, RTFMODE fMode = 0);
203 int OpenEx(const RTCString &strPath, View enmView, uint64_t fOpen = 0, RTFMODE fMode = 0, DNDURIOBJECTFLAGS = DNDURIOBJECT_FLAGS_NONE);
204 int QueryInfo(View enmView);
205 int Read(void *pvBuf, size_t cbBuf, uint32_t *pcbRead);
206 void Reset(void);
207 int Write(const void *pvBuf, size_t cbBuf, uint32_t *pcbWritten);
208
209public:
210
211 static int RebaseURIPath(RTCString &strPath, const RTCString &strBaseOld = "", const RTCString &strBaseNew = "");
212
213protected:
214
215 void closeInternal(void);
216 int queryInfoInternal(View enmView);
217
218protected:
219
220 /** The object's type. */
221 Type m_enmType;
222 /** The object's view. */
223 View m_enmView;
224 /** Absolute path (base) for the source. */
225 RTCString m_strSrcPathAbs;
226 /** Absolute path (base) for the target. */
227 RTCString m_strTgtPathAbs;
228
229 /** Union containing data depending on the object's type. */
230 union
231 {
232 /** Structure containing members for objects that
233 * are files. */
234 struct
235 {
236 /** File handle. */
237 RTFILE hFile;
238 /** File system object information of this file. */
239 RTFSOBJINFO objInfo;
240 /** Bytes to proces for reading/writing. */
241 uint64_t cbToProcess;
242 /** Bytes processed reading/writing. */
243 uint64_t cbProcessed;
244 } File;
245 struct
246 {
247 /** Directory handle. */
248 RTDIR hDir;
249 /** File system object information of this directory. */
250 RTFSOBJINFO objInfo;
251 } Dir;
252 } u;
253};
254
255/** DnDURIList flags. */
256typedef uint32_t DNDURILISTFLAGS;
257
258/** No flags specified. */
259#define DNDURILIST_FLAGS_NONE 0
260/** Keep the original paths, don't convert paths to relative ones. */
261#define DNDURILIST_FLAGS_ABSOLUTE_PATHS RT_BIT(0)
262/** Resolve all symlinks. */
263#define DNDURILIST_FLAGS_RESOLVE_SYMLINKS RT_BIT(1)
264/** Keep the files + directory entries open while
265 * being in this list. */
266#define DNDURILIST_FLAGS_KEEP_OPEN RT_BIT(2)
267/** Lazy loading: Only enumerate sub directories when needed.
268 ** @todo Implement lazy loading. */
269#define DNDURILIST_FLAGS_LAZY RT_BIT(3)
270
271/** Mask of all valid DnD URI list flags. */
272#define DNDURILIST_FLAGS_VALID_MASK UINT32_C(0xF)
273
274class DnDURIList
275{
276public:
277#ifdef RT_NEED_NEW_AND_DELETE
278 RTMEM_IMPLEMENT_NEW_AND_DELETE();
279#endif
280 DnDURIList(void);
281 virtual ~DnDURIList(void);
282
283public:
284
285 int AppendNativePath(const char *pszPath, DNDURILISTFLAGS fFlags);
286 int AppendNativePathsFromList(const char *pszNativePaths, size_t cbNativePaths, DNDURILISTFLAGS fFlags);
287 int AppendNativePathsFromList(const RTCList<RTCString> &lstNativePaths, DNDURILISTFLAGS fFlags);
288 int AppendURIPath(const char *pszURI, DNDURILISTFLAGS fFlags);
289 int AppendURIPathsFromList(const char *pszURIPaths, size_t cbURIPaths, DNDURILISTFLAGS fFlags);
290 int AppendURIPathsFromList(const RTCList<RTCString> &lstURI, DNDURILISTFLAGS fFlags);
291
292 void Clear(void);
293 DnDURIObject *First(void) { return m_lstTree.first(); }
294 bool IsEmpty(void) const { return m_lstTree.isEmpty(); }
295 void RemoveFirst(void);
296 int SetFromURIData(const void *pvData, size_t cbData, DNDURILISTFLAGS fFlags);
297
298 RTCString GetRootEntries(const RTCString &strPathBase = "", const RTCString &strSeparator = "\r\n") const;
299 uint64_t GetRootCount(void) const { return m_lstRoot.size(); }
300 uint64_t GetTotalCount(void) const { return m_cTotal; }
301 uint64_t GetTotalBytes(void) const { return m_cbTotal; }
302
303protected:
304
305 int addEntry(const char *pcszSource, const char *pcszTarget, DNDURILISTFLAGS fFlags);
306 int appendPathRecursive(const char *pcszSrcPath, const char *pcszDstPath, const char *pcszDstBase, size_t cchDstBase, DNDURILISTFLAGS fFlags);
307
308protected:
309
310 /** List of all top-level file/directory entries.
311 * Note: All paths are kept internally as UNIX paths for
312 * easier conversion/handling! */
313 RTCList<RTCString> m_lstRoot;
314 /** List of all URI objects added. The list's content
315 * might vary depending on how the objects are being
316 * added (lazy or not). */
317 RTCList<DnDURIObject *> m_lstTree;
318 /** Total number of all URI objects. */
319 uint64_t m_cTotal;
320 /** Total size of all URI objects, that is, the file
321 * size of all objects (in bytes).
322 * Note: Do *not* size_t here, as we also want to support large files
323 * on 32-bit guests. */
324 uint64_t m_cbTotal;
325};
326
327#endif /* !VBOX_INCLUDED_GuestHost_DragAndDrop_h */
328
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