VirtualBox

source: vbox/trunk/src/VBox/Main/include/MediumImpl.h@ 22624

Last change on this file since 22624 was 22183, checked in by vboxsync, 15 years ago

Main: fix more windows warnings + burns

  • Property svn:eol-style set to native
  • Property svn:keywords set to Date Revision Author Id
File size: 10.2 KB
Line 
1/* $Id: MediumImpl.h 22183 2009-08-11 17:00:33Z vboxsync $ */
2/** @file
3 *
4 * VirtualBox COM class implementation
5 */
6
7/*
8 * Copyright (C) 2008 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 ____H_MEDIUMIMPL
24#define ____H_MEDIUMIMPL
25
26#include "VirtualBoxBase.h"
27
28#include <VBox/com/SupportErrorInfo.h>
29
30#include <list>
31#include <algorithm>
32
33class VirtualBox;
34namespace settings
35{
36 struct Medium;
37}
38
39////////////////////////////////////////////////////////////////////////////////
40
41/**
42 * Base component class for all media types.
43 *
44 * Provides the basic implementation of the IMedium interface.
45 *
46 * @note Subclasses must initialize the mVirtualBox data member in their init()
47 * implementations with the valid VirtualBox instance because some
48 * MediaBase methods call its methods.
49 */
50class ATL_NO_VTABLE MediumBase :
51 virtual public VirtualBoxBaseProto,
52 public com::SupportErrorInfoBase,
53 public VirtualBoxSupportTranslation<MediumBase>,
54 VBOX_SCRIPTABLE_IMPL(IMedium)
55{
56public:
57
58 VIRTUALBOXBASE_ADD_ERRORINFO_SUPPORT (MediumBase)
59
60 DECLARE_EMPTY_CTOR_DTOR (MediumBase)
61
62 /** Describes how a machine refers to this image. */
63 struct BackRef
64 {
65 /** Equality predicate for stdc++. */
66 struct EqualsTo : public std::unary_function <BackRef, bool>
67 {
68 explicit EqualsTo (const Guid &aMachineId) : machineId (aMachineId) {}
69
70 bool operator() (const argument_type &aThat) const
71 {
72 return aThat.machineId == machineId;
73 }
74
75 const Guid machineId;
76 };
77
78 typedef std::list <Guid> GuidList;
79
80 BackRef() : inCurState (false) {}
81
82 BackRef (const Guid &aMachineId, const Guid &aSnapshotId = Guid::Empty)
83 : machineId (aMachineId)
84 , inCurState (aSnapshotId.isEmpty())
85 {
86 if (!aSnapshotId.isEmpty())
87 snapshotIds.push_back (aSnapshotId);
88 }
89
90 Guid machineId;
91 bool inCurState : 1;
92 GuidList snapshotIds;
93 };
94
95 typedef std::list <BackRef> BackRefList;
96
97 // IMedium properties
98 STDMETHOD(COMGETTER(Id)) (BSTR *aId);
99 STDMETHOD(COMGETTER(Description)) (BSTR *aDescription);
100 STDMETHOD(COMSETTER(Description)) (IN_BSTR aDescription);
101 STDMETHOD(COMGETTER(State)) (MediaState_T *aState);
102 STDMETHOD(COMGETTER(Location)) (BSTR *aLocation);
103 STDMETHOD(COMSETTER(Location)) (IN_BSTR aLocation);
104 STDMETHOD(COMGETTER(Name)) (BSTR *aName);
105 STDMETHOD(COMGETTER(Size)) (ULONG64 *aSize);
106 STDMETHOD(COMGETTER(LastAccessError)) (BSTR *aLastAccessError);
107 STDMETHOD(COMGETTER(MachineIds)) (ComSafeArrayOut (BSTR, aMachineIds));
108
109 // IMedium methods
110 STDMETHOD(GetSnapshotIds) (IN_BSTR aMachineId,
111 ComSafeArrayOut (BSTR, aSnapshotIds));
112 STDMETHOD(LockRead) (MediaState_T *aState);
113 STDMETHOD(UnlockRead) (MediaState_T *aState);
114 STDMETHOD(LockWrite) (MediaState_T *aState);
115 STDMETHOD(UnlockWrite) (MediaState_T *aState);
116 STDMETHOD(Close)();
117
118 // public methods for internal purposes only
119
120 HRESULT updatePath (const char *aOldPath, const char *aNewPath);
121
122 HRESULT attachTo (const Guid &aMachineId,
123 const Guid &aSnapshotId = Guid::Empty);
124 HRESULT detachFrom (const Guid &aMachineId,
125 const Guid &aSnapshotId = Guid::Empty);
126
127 // unsafe inline public methods for internal purposes only (ensure there is
128 // a caller and a read lock before calling them!)
129
130 const Guid &id() const { return m.id; }
131 MediaState_T state() const { return m.state; }
132 const Bstr &location() const { return m.location; }
133 const Bstr &locationFull() const { return m.locationFull; }
134 const BackRefList &backRefs() const { return m.backRefs; }
135
136 bool isAttachedTo (const Guid &aMachineId)
137 {
138 BackRefList::iterator it =
139 std::find_if (m.backRefs.begin(), m.backRefs.end(),
140 BackRef::EqualsTo (aMachineId));
141 return it != m.backRefs.end() && it->inCurState;
142 }
143
144protected:
145
146 virtual Utf8Str name();
147
148 virtual HRESULT setLocation(const Utf8Str &aLocation);
149 virtual HRESULT queryInfo();
150
151 /**
152 * Performs extra checks if the medium can be closed and returns S_OK in
153 * this case. Otherwise, returns a respective error message. Called by
154 * Close() from within this object's AutoMayUninitSpan and from under
155 * mVirtualBox write lock.
156 */
157 virtual HRESULT canClose() { return S_OK; }
158
159 /**
160 * Performs extra checks if the medium can be attached to the specified
161 * VM and shapshot at the given time and returns S_OK in this case.
162 * Otherwise, returns a respective error message. Called by attachTo() from
163 * within this object's AutoWriteLock.
164 */
165 virtual HRESULT canAttach (const Guid & /* aMachineId */,
166 const Guid & /* aSnapshotId */)
167 { return S_OK; }
168
169 /**
170 * Unregisters this medium with mVirtualBox. Called by Close() from within
171 * this object's AutoMayUninitSpan and from under mVirtualBox write lock.
172 */
173 virtual HRESULT unregisterWithVirtualBox() = 0;
174
175 HRESULT setStateError();
176
177 /** weak VirtualBox parent */
178 const ComObjPtr<VirtualBox, ComWeakRef> mVirtualBox;
179
180 struct Data
181 {
182 Data() : state (MediaState_NotCreated), size (0), readers (0)
183 , queryInfoSem (NIL_RTSEMEVENTMULTI)
184 , queryInfoCallers (0), accessibleInLock (false) {}
185
186 const Guid id;
187 Bstr description;
188 MediaState_T state;
189 Bstr location;
190 Bstr locationFull;
191 uint64_t size;
192 Bstr lastAccessError;
193
194 BackRefList backRefs;
195
196 size_t readers;
197
198 RTSEMEVENTMULTI queryInfoSem;
199 size_t queryInfoCallers;
200
201 bool accessibleInLock : 1;
202 };
203
204 Data m;
205};
206
207////////////////////////////////////////////////////////////////////////////////
208
209/**
210 * Base component class for simple image file based media such as CD/DVD ISO
211 * images or Floppy images.
212 *
213 * Adds specific protectedInit() and saveSettings() methods that can load image
214 * data from the settings files.
215 */
216class ATL_NO_VTABLE ImageMediumBase
217 : public MediumBase
218 , public VirtualBoxBase
219{
220public:
221
222 HRESULT FinalConstruct() { return S_OK; }
223 void FinalRelease() { uninit(); }
224
225protected:
226
227 // protected initializer/uninitializer for internal purposes only
228 HRESULT protectedInit(VirtualBox *aVirtualBox,
229 CBSTR aLocation,
230 const Guid &aId);
231 HRESULT protectedInit(VirtualBox *aVirtualBox,
232 const settings::Medium &data);
233 void protectedUninit();
234
235public:
236
237 // public methods for internal purposes only
238 HRESULT saveSettings(settings::Medium &data);
239};
240
241////////////////////////////////////////////////////////////////////////////////
242
243/**
244 * The DVDImage component class implements the IDVDImage interface.
245 */
246class ATL_NO_VTABLE DVDImage
247 : public com::SupportErrorInfoDerived<ImageMediumBase, DVDImage, IDVDImage>
248 , public VirtualBoxSupportTranslation<DVDImage>
249 , VBOX_SCRIPTABLE_IMPL(IDVDImage)
250{
251public:
252
253 COM_FORWARD_IMedium_TO_BASE (ImageMediumBase)
254
255 VIRTUALBOXSUPPORTTRANSLATION_OVERRIDE (DVDImage)
256
257 DECLARE_NOT_AGGREGATABLE (DVDImage)
258
259 DECLARE_PROTECT_FINAL_CONSTRUCT()
260
261 BEGIN_COM_MAP (DVDImage)
262 COM_INTERFACE_ENTRY (ISupportErrorInfo)
263 COM_INTERFACE_ENTRY2 (IMedium, ImageMediumBase)
264 COM_INTERFACE_ENTRY (IDVDImage)
265 COM_INTERFACE_ENTRY2 (IDispatch, IDVDImage)
266 END_COM_MAP()
267
268 NS_DECL_ISUPPORTS
269
270 DECLARE_EMPTY_CTOR_DTOR (DVDImage)
271
272 // public initializer/uninitializer for internal purposes only
273
274 HRESULT init(VirtualBox *aParent,
275 CBSTR aFilePath,
276 const Guid &aId)
277 {
278 return protectedInit(aParent, aFilePath, aId);
279 }
280
281 HRESULT init(VirtualBox *aParent,
282 const settings::Medium &data)
283 {
284 return protectedInit(aParent, data);
285 }
286
287 void uninit() { protectedUninit(); }
288
289 /** For com::SupportErrorInfoImpl. */
290 static const char *ComponentName() { return "DVDImage"; }
291
292private:
293
294 HRESULT unregisterWithVirtualBox();
295};
296
297////////////////////////////////////////////////////////////////////////////////
298
299/**
300 * The FloppyImage component class implements the IFloppyImage interface.
301 */
302class ATL_NO_VTABLE FloppyImage
303 : public com::SupportErrorInfoDerived<ImageMediumBase, FloppyImage, IFloppyImage>
304 , public VirtualBoxSupportTranslation<FloppyImage>
305 , VBOX_SCRIPTABLE_IMPL(IFloppyImage)
306{
307public:
308
309 COM_FORWARD_IMedium_TO_BASE (ImageMediumBase)
310
311 VIRTUALBOXSUPPORTTRANSLATION_OVERRIDE (FloppyImage)
312
313 DECLARE_NOT_AGGREGATABLE (FloppyImage)
314
315 DECLARE_PROTECT_FINAL_CONSTRUCT()
316
317 BEGIN_COM_MAP (FloppyImage)
318 COM_INTERFACE_ENTRY (ISupportErrorInfo)
319 COM_INTERFACE_ENTRY2 (IMedium, ImageMediumBase)
320 COM_INTERFACE_ENTRY (IFloppyImage)
321 COM_INTERFACE_ENTRY2 (IDispatch, IFloppyImage)
322 END_COM_MAP()
323
324 NS_DECL_ISUPPORTS
325
326 DECLARE_EMPTY_CTOR_DTOR (FloppyImage)
327
328 // public initializer/uninitializer for internal purposes only
329
330 HRESULT init(VirtualBox *aParent,
331 CBSTR aFilePath,
332 const Guid &aId)
333 {
334 return protectedInit(aParent, aFilePath, aId);
335 }
336
337 HRESULT init(VirtualBox *aParent,
338 const settings::Medium &data)
339 {
340 return protectedInit(aParent, data);
341 }
342
343 void uninit() { protectedUninit(); }
344
345 /** For com::SupportErrorInfoImpl. */
346 static const char *ComponentName() { return "FloppyImage"; }
347
348private:
349
350 HRESULT unregisterWithVirtualBox();
351};
352
353#endif /* ____H_MEDIUMIMPL */
354
355/* vi: set tabstop=4 shiftwidth=4 expandtab: */
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