VirtualBox

source: vbox/trunk/src/VBox/Main/HostDVDDriveImpl.cpp@ 14658

Last change on this file since 14658 was 14579, checked in by vboxsync, 16 years ago

Main: VirtualBoxBase::addCaller() now returns E_ACCESSDENIED. Also replaced E_UNEXPECTED with E_FAIL in all Assert* statements (for consistency).

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 3.4 KB
Line 
1/** @file
2 *
3 * VirtualBox COM class implementation
4 */
5
6/*
7 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
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 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
18 * Clara, CA 95054 USA or visit http://www.sun.com if you need
19 * additional information or have any questions.
20 */
21
22#include "HostDVDDriveImpl.h"
23#include <iprt/cpputils.h>
24
25// constructor / destructor
26/////////////////////////////////////////////////////////////////////////////
27
28DEFINE_EMPTY_CTOR_DTOR (HostDVDDrive)
29
30HRESULT HostDVDDrive::FinalConstruct()
31{
32 return S_OK;
33}
34
35void HostDVDDrive::FinalRelease()
36{
37 uninit();
38}
39
40// public initializer/uninitializer for internal purposes only
41/////////////////////////////////////////////////////////////////////////////
42
43/**
44 * Initializes the host DVD drive object.
45 *
46 * @param aName Name of the drive.
47 * @param aUdi Universal device identifier (currently may be NULL).
48 * @param aDescription Human-readable drive description (may be NULL).
49 *
50 * @return COM result indicator.
51 */
52HRESULT HostDVDDrive::init (INPTR BSTR aName,
53 INPTR BSTR aUdi /* = NULL */,
54 INPTR BSTR aDescription /* = NULL */)
55{
56 ComAssertRet (aName, E_INVALIDARG);
57
58 /* Enclose the state transition NotReady->InInit->Ready */
59 AutoInitSpan autoInitSpan (this);
60 AssertReturn (autoInitSpan.isOk(), E_FAIL);
61
62 unconst (mName) = aName;
63 unconst (mUdi) = aUdi;
64 unconst (mDescription) = aDescription;
65
66 /* Confirm the successful initialization */
67 autoInitSpan.setSucceeded();
68
69 return S_OK;
70}
71
72/**
73 * Uninitializes the instance and sets the ready flag to FALSE.
74 * Called either from FinalRelease() or by the parent when it gets destroyed.
75 */
76void HostDVDDrive::uninit()
77{
78 /* Enclose the state transition Ready->InUninit->NotReady */
79 AutoUninitSpan autoUninitSpan (this);
80 if (autoUninitSpan.uninitDone())
81 return;
82
83 unconst (mDescription).setNull();
84 unconst (mName).setNull();
85}
86
87// IHostDVDDrive properties
88/////////////////////////////////////////////////////////////////////////////
89
90STDMETHODIMP HostDVDDrive::COMGETTER(Name) (BSTR *aName)
91{
92 if (!aName)
93 return E_POINTER;
94
95 AutoCaller autoCaller (this);
96 CheckComRCReturnRC (autoCaller.rc());
97
98 /* mName is constant during life time, no need to lock */
99
100 mName.cloneTo (aName);
101
102 return S_OK;
103}
104
105STDMETHODIMP HostDVDDrive::COMGETTER(Description) (BSTR *aDescription)
106{
107 if (!aDescription)
108 return E_POINTER;
109
110 AutoCaller autoCaller (this);
111 CheckComRCReturnRC (autoCaller.rc());
112
113 /* mDescription is constant during life time, no need to lock */
114
115 mDescription.cloneTo (aDescription);
116
117 return S_OK;
118}
119
120STDMETHODIMP HostDVDDrive::COMGETTER(Udi) (BSTR *aUdi)
121{
122 if (!aUdi)
123 return E_POINTER;
124
125 AutoCaller autoCaller (this);
126 CheckComRCReturnRC (autoCaller.rc());
127
128 /* mUdi is constant during life time, no need to lock */
129
130 mUdi.cloneTo (aUdi);
131
132 return S_OK;
133}
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