VirtualBox

source: vbox/trunk/src/VBox/Main/include/ProgressImpl.h@ 51202

Last change on this file since 51202 was 50874, checked in by vboxsync, 11 years ago

6813 src-all/ProgressImp.cpp + some formatting/line length sorting

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 8.3 KB
Line 
1/* $Id: ProgressImpl.h 50874 2014-03-25 18:29:02Z vboxsync $ */
2/** @file
3 *
4 * VirtualBox COM class implementation
5 */
6
7/*
8 * Copyright (C) 2006-2013 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#ifndef ____H_PROGRESSIMPL
20#define ____H_PROGRESSIMPL
21
22#include "ProgressWrap.h"
23#include "VirtualBoxBase.h"
24
25#include <iprt/semaphore.h>
26
27////////////////////////////////////////////////////////////////////////////////
28
29/**
30 * Class for progress objects.
31 */
32class ATL_NO_VTABLE Progress :
33 public ProgressWrap
34{
35protected:
36
37 DECLARE_EMPTY_CTOR_DTOR (Progress)
38
39 void i_checkForAutomaticTimeout(void);
40
41#if !defined (VBOX_COM_INPROC)
42 /** Weak parent. */
43 VirtualBox * const mParent;
44#endif
45
46 const ComPtr<IUnknown> mInitiator;
47
48 const Guid mId;
49 const com::Utf8Str mDescription;
50
51 uint64_t m_ullTimestamp; // progress object creation timestamp, for ETA computation
52
53 void (*m_pfnCancelCallback)(void *);
54 void *m_pvCancelUserArg;
55
56 /* The fields below are to be properly initialized by subclasses */
57
58 BOOL mCompleted;
59 BOOL mCancelable;
60 BOOL mCanceled;
61 HRESULT mResultCode;
62 ComPtr<IVirtualBoxErrorInfo> mErrorInfo;
63
64 ULONG m_cOperations; // number of operations (so that progress dialog can
65 // display something like 1/3)
66 ULONG m_ulTotalOperationsWeight; // sum of weights of all operations, given to constructor
67
68 ULONG m_ulOperationsCompletedWeight; // summed-up weight of operations that have been completed; initially 0
69
70 ULONG m_ulCurrentOperation; // operations counter, incremented with
71 // each setNextOperation()
72 com::Utf8Str m_operationDescription; // name of current operation; initially
73 // from constructor, changed with setNextOperation()
74 ULONG m_ulCurrentOperationWeight; // weight of current operation, given to setNextOperation()
75 ULONG m_ulOperationPercent; // percentage of current operation, set with setCurrentOperationProgress()
76 ULONG m_cMsTimeout; /**< Automatic timeout value. 0 means none. */
77
78public:
79 DECLARE_NOT_AGGREGATABLE (Progress)
80
81 HRESULT FinalConstruct();
82 void FinalRelease();
83
84 // public initializer/uninitializer for internal purposes only
85
86 /**
87 * Simplified constructor for progress objects that have only one
88 * operation as a task.
89 * @param aParent
90 * @param aInitiator
91 * @param aDescription
92 * @param aCancelable
93 * @param aId
94 * @return
95 */
96 HRESULT init(
97#if !defined (VBOX_COM_INPROC)
98 VirtualBox *aParent,
99#endif
100 IUnknown *aInitiator,
101 Utf8Str aDescription,
102 BOOL aCancelable,
103 OUT_GUID aId = NULL)
104 {
105 return init(
106#if !defined (VBOX_COM_INPROC)
107 aParent,
108#endif
109 aInitiator,
110 aDescription,
111 aCancelable,
112 1, // cOperations
113 1, // ulTotalOperationsWeight
114 aDescription, // aFirstOperationDescription
115 1, // ulFirstOperationWeight
116 aId);
117 }
118
119 /**
120 * Not quite so simplified constructor for progress objects that have
121 * more than one operation, but all sub-operations are weighed the same.
122 * @param aParent
123 * @param aInitiator
124 * @param aDescription
125 * @param aCancelable
126 * @param cOperations
127 * @param bstrFirstOperationDescription
128 * @param aId
129 * @return
130 */
131 HRESULT init(
132#if !defined (VBOX_COM_INPROC)
133 VirtualBox *aParent,
134#endif
135 IUnknown *aInitiator,
136 Utf8Str aDescription, BOOL aCancelable,
137 ULONG cOperations,
138 Utf8Str aFirstOperationDescription,
139 OUT_GUID aId = NULL)
140 {
141 return init(
142#if !defined (VBOX_COM_INPROC)
143 aParent,
144#endif
145 aInitiator,
146 aDescription,
147 aCancelable,
148 cOperations, // cOperations
149 cOperations, // ulTotalOperationsWeight = cOperations
150 aFirstOperationDescription, // aFirstOperationDescription
151 1, // ulFirstOperationWeight: weigh them all the same
152 aId);
153 }
154
155 HRESULT init(
156#if !defined (VBOX_COM_INPROC)
157 VirtualBox *aParent,
158#endif
159 IUnknown *aInitiator,
160 Utf8Str aDescription,
161 BOOL aCancelable,
162 ULONG cOperations,
163 ULONG ulTotalOperationsWeight,
164 Utf8Str aFirstOperationDescription,
165 ULONG ulFirstOperationWeight,
166 OUT_GUID aId = NULL);
167
168 HRESULT init(BOOL aCancelable,
169 ULONG aOperationCount,
170 Utf8Str aOperationDescription);
171
172// initializer/uninitializer for internal purposes only
173 HRESULT init(AutoInitSpan &aAutoInitSpan,
174#if !defined (VBOX_COM_INPROC)
175 VirtualBox *aParent,
176#endif
177 IUnknown *aInitiator,
178 Utf8Str aDescription, OUT_GUID aId = NULL);
179 HRESULT init(AutoInitSpan &aAutoInitSpan);
180 void init(AutoUninitSpan &aAutoUninitSpan);
181 void uninit();
182 void uninit(AutoUninitSpan &aAutoUninitSpan);
183
184
185 // public methods only for internal purposes
186 HRESULT i_setResultCode(HRESULT aResultCode);
187
188 HRESULT i_notifyComplete(HRESULT aResultCode);
189 HRESULT i_notifyComplete(HRESULT aResultCode,
190 const GUID &aIID,
191 const char *pcszComponent,
192 const char *aText,
193 ...);
194 HRESULT i_notifyCompleteV(HRESULT aResultCode,
195 const GUID &aIID,
196 const char *pcszComponent,
197 const char *aText,
198 va_list va);
199 bool i_notifyPointOfNoReturn(void);
200
201 // public methods only for internal purposes
202 bool i_setCancelCallback(void (*pfnCallback)(void *), void *pvUser);
203
204 // unsafe inline public methods for internal purposes only (ensure there is
205 // a caller and a read lock before calling them!)
206 BOOL i_getCompleted() const { return mCompleted; }
207 HRESULT i_getResultCode() const { return mResultCode; }
208 double i_calcTotalPercent();
209
210private:
211
212 // Wrapped IProgress Data
213 HRESULT getId(com::Guid &aId);
214 HRESULT getDescription(com::Utf8Str &aDescription);
215 HRESULT getInitiator(ComPtr<IUnknown> &aInitiator);
216 HRESULT getCancelable(BOOL *aCancelable);
217 HRESULT getPercent(ULONG *aPercent);
218 HRESULT getTimeRemaining(LONG *aTimeRemaining);
219 HRESULT getCompleted(BOOL *aCompleted);
220 HRESULT getCanceled(BOOL *aCanceled);
221 HRESULT getResultCode(LONG *aResultCode);
222 HRESULT getErrorInfo(ComPtr<IVirtualBoxErrorInfo> &aErrorInfo);
223 HRESULT getOperationCount(ULONG *aOperationCount);
224 HRESULT getOperation(ULONG *aOperation);
225 HRESULT getOperationDescription(com::Utf8Str &aOperationDescription);
226 HRESULT getOperationPercent(ULONG *aOperationPercent);
227 HRESULT getOperationWeight(ULONG *aOperationWeight);
228 HRESULT getTimeout(ULONG *aTimeout);
229 HRESULT setTimeout(ULONG aTimeout);
230 HRESULT setCurrentOperationProgress(ULONG aPercent);
231 HRESULT setNextOperation(const com::Utf8Str &aNextOperationDescription,
232 ULONG aNextOperationsWeight);
233
234 // Wrapped Iprogress methods
235 HRESULT waitForCompletion(LONG aTimeout);
236 HRESULT waitForOperationCompletion(ULONG aOperation,
237 LONG aTimeout);
238 HRESULT waitForAsyncProgressCompletion(const ComPtr<IProgress> &aPProgressAsync);
239 HRESULT cancel();
240
241
242 RTSEMEVENTMULTI mCompletedSem;
243 ULONG mWaitersCount;
244};
245
246#endif /* ____H_PROGRESSIMPL */
247
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