VirtualBox

source: vbox/trunk/src/VBox/Main/src-client/AdditionsFacilityImpl.cpp@ 68272

Last change on this file since 68272 was 67914, checked in by vboxsync, 7 years ago

src-client: Define LOG_GROUP according to interface or similar.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.9 KB
Line 
1/* $Id: AdditionsFacilityImpl.cpp 67914 2017-07-11 20:46:37Z vboxsync $ */
2/** @file
3 *
4 * VirtualBox COM class implementation
5 */
6
7/*
8 * Copyright (C) 2014-2016 Oracle Corporation
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
19#define LOG_GROUP LOG_GROUP_MAIN_ADDITIONSFACILITY
20#include "LoggingNew.h"
21
22#include "AdditionsFacilityImpl.h"
23#include "Global.h"
24
25#include "AutoCaller.h"
26
27
28/* static */
29const AdditionsFacility::FacilityInfo AdditionsFacility::s_aFacilityInfo[8] =
30{
31 /* NOTE: We assume that unknown is always the first entry! */
32 { "Unknown", AdditionsFacilityType_None, AdditionsFacilityClass_None },
33 { "VirtualBox Base Driver", AdditionsFacilityType_VBoxGuestDriver, AdditionsFacilityClass_Driver },
34 { "Auto Logon", AdditionsFacilityType_AutoLogon, AdditionsFacilityClass_Feature },
35 { "VirtualBox System Service", AdditionsFacilityType_VBoxService, AdditionsFacilityClass_Service },
36 { "VirtualBox Desktop Integration", AdditionsFacilityType_VBoxTrayClient, AdditionsFacilityClass_Program },
37 { "Seamless Mode", AdditionsFacilityType_Seamless, AdditionsFacilityClass_Feature },
38 { "Graphics Mode", AdditionsFacilityType_Graphics, AdditionsFacilityClass_Feature },
39};
40
41// constructor / destructor
42/////////////////////////////////////////////////////////////////////////////
43
44DEFINE_EMPTY_CTOR_DTOR(AdditionsFacility)
45
46HRESULT AdditionsFacility::FinalConstruct()
47{
48 LogFlowThisFunc(("\n"));
49 return BaseFinalConstruct();
50}
51
52void AdditionsFacility::FinalRelease()
53{
54 LogFlowThisFuncEnter();
55 uninit();
56 BaseFinalRelease();
57 LogFlowThisFuncLeave();
58}
59
60// public initializer/uninitializer for internal purposes only
61/////////////////////////////////////////////////////////////////////////////
62
63HRESULT AdditionsFacility::init(Guest *a_pParent, AdditionsFacilityType_T a_enmFacility, AdditionsFacilityStatus_T a_enmStatus,
64 uint32_t a_fFlags, PCRTTIMESPEC a_pTimeSpecTS)
65{
66 RT_NOREF(a_pParent);
67 LogFlowThisFunc(("a_pParent=%p\n", a_pParent));
68
69 /* Enclose the state transition NotReady->InInit->Ready. */
70 AutoInitSpan autoInitSpan(this);
71 AssertReturn(autoInitSpan.isOk(), E_FAIL);
72
73 FacilityState state;
74 state.mStatus = a_enmStatus;
75 state.mTimestamp = *a_pTimeSpecTS;
76 NOREF(a_fFlags);
77
78 Assert(mData.mStates.size() == 0);
79 mData.mStates.push_back(state);
80 mData.mType = a_enmFacility;
81 /** @todo mClass is not initialized here. */
82 NOREF(a_fFlags);
83
84 /* Confirm a successful initialization when it's the case. */
85 autoInitSpan.setSucceeded();
86
87 return S_OK;
88}
89
90/**
91 * Uninitializes the instance.
92 * Called from FinalRelease().
93 */
94void AdditionsFacility::uninit()
95{
96 LogFlowThisFunc(("\n"));
97
98 /* Enclose the state transition Ready->InUninit->NotReady. */
99 AutoUninitSpan autoUninitSpan(this);
100 if (autoUninitSpan.uninitDone())
101 return;
102
103 mData.mStates.clear();
104}
105
106HRESULT AdditionsFacility::getClassType(AdditionsFacilityClass_T *aClassType)
107{
108 LogFlowThisFuncEnter();
109
110 AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
111
112 *aClassType = i_getClass();
113
114 return S_OK;
115}
116
117HRESULT AdditionsFacility::getName(com::Utf8Str &aName)
118{
119 LogFlowThisFuncEnter();
120
121 AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
122
123 aName = i_getName();
124
125 return S_OK;
126}
127
128HRESULT AdditionsFacility::getLastUpdated(LONG64 *aLastUpdated)
129{
130 LogFlowThisFuncEnter();
131
132 AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
133
134 *aLastUpdated = i_getLastUpdated();
135
136 return S_OK;
137}
138
139HRESULT AdditionsFacility::getStatus(AdditionsFacilityStatus_T *aStatus)
140{
141 LogFlowThisFuncEnter();
142
143 AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
144
145 *aStatus = i_getStatus();
146
147 return S_OK;
148}
149
150HRESULT AdditionsFacility::getType(AdditionsFacilityType_T *aType)
151{
152 LogFlowThisFuncEnter();
153
154 AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
155
156 *aType = i_getType();
157
158 return S_OK;
159}
160
161const AdditionsFacility::FacilityInfo &AdditionsFacility::i_typeToInfo(AdditionsFacilityType_T aType)
162{
163 for (size_t i = 0; i < RT_ELEMENTS(s_aFacilityInfo); ++i)
164 {
165 if (s_aFacilityInfo[i].mType == aType)
166 return s_aFacilityInfo[i];
167 }
168 return s_aFacilityInfo[0]; /* Return unknown type. */
169}
170
171AdditionsFacilityClass_T AdditionsFacility::i_getClass() const
172{
173 return AdditionsFacility::i_typeToInfo(mData.mType).mClass;
174}
175
176com::Utf8Str AdditionsFacility::i_getName() const
177{
178 return AdditionsFacility::i_typeToInfo(mData.mType).mName;
179}
180
181LONG64 AdditionsFacility::i_getLastUpdated() const
182{
183 if (mData.mStates.size())
184 return RTTimeSpecGetMilli(&mData.mStates.front().mTimestamp);
185
186 AssertMsgFailed(("Unknown timestamp of facility!\n"));
187 return 0; /* Should never happen! */
188}
189
190AdditionsFacilityStatus_T AdditionsFacility::i_getStatus() const
191{
192 if (mData.mStates.size())
193 return mData.mStates.back().mStatus;
194
195 AssertMsgFailed(("Unknown status of facility!\n"));
196 return AdditionsFacilityStatus_Unknown; /* Should never happen! */
197}
198
199AdditionsFacilityType_T AdditionsFacility::i_getType() const
200{
201 return mData.mType;
202}
203
204/**
205 * Method used by IGuest::facilityUpdate to make updates.
206 */
207void AdditionsFacility::i_update(AdditionsFacilityStatus_T a_enmStatus, uint32_t a_fFlags, PCRTTIMESPEC a_pTimeSpecTS)
208{
209 FacilityState state;
210 state.mStatus = a_enmStatus;
211 state.mTimestamp = *a_pTimeSpecTS;
212 NOREF(a_fFlags);
213
214 mData.mStates.push_back(state);
215 if (mData.mStates.size() > 10) /* Only keep the last 10 states. */
216 mData.mStates.erase(mData.mStates.begin());
217}
218
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