You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
706 lines
20 KiB
706 lines
20 KiB
/*++
|
|
|
|
Copyright (c) 1999 Microsoft Corporation
|
|
|
|
Abstract:
|
|
|
|
@doc
|
|
@module Pointer.cxx | Implementation of VSS_OBJECT_PROP_Ptr class
|
|
@end
|
|
|
|
Author:
|
|
|
|
Adi Oltean [aoltean] 09/21/1999
|
|
|
|
Revision History:
|
|
|
|
Name Date Comments
|
|
|
|
aoltean 09/21/1999 VSS_OBJECT_PROP_Ptr as a pointer to the properties structure.
|
|
This pointer will serve as element in CSimpleArray constructs.
|
|
aoltean 09/22/1999 Adding InitializeAsEmpty and Print
|
|
aoltean 09/24/1999 Moving into modules/prop
|
|
aoltean 03/27/2000 Adding Writers
|
|
aoltean 03/01/2001 Adding mgmt objects
|
|
|
|
--*/
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
// Needed includes
|
|
|
|
|
|
#include "stdafx.hxx"
|
|
|
|
#include "vs_idl.hxx"
|
|
#include "vs_inc.hxx"
|
|
|
|
#include "copy.hxx"
|
|
#include "pointer.hxx"
|
|
|
|
////////////////////////////////////////////////////////////////////////
|
|
// Standard foo for file name aliasing. This code block must be after
|
|
// all includes of VSS header files.
|
|
//
|
|
#ifdef VSS_FILE_ALIAS
|
|
#undef VSS_FILE_ALIAS
|
|
#endif
|
|
#define VSS_FILE_ALIAS "PRPPNTRC"
|
|
//
|
|
////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
// VSS_OBJECT_PROP_Ptr class
|
|
|
|
|
|
void VSS_OBJECT_PROP_Ptr::InitializeAsSnapshot(
|
|
IN CVssFunctionTracer& ft,
|
|
IN VSS_ID SnapshotId,
|
|
IN VSS_ID SnapshotSetId,
|
|
IN LONG lSnapshotsCount,
|
|
IN VSS_PWSZ pwszSnapshotDeviceObject,
|
|
IN VSS_PWSZ pwszOriginalVolumeName,
|
|
IN VSS_PWSZ pwszOriginatingMachine,
|
|
IN VSS_PWSZ pwszServiceMachine,
|
|
IN VSS_PWSZ pwszExposedName,
|
|
IN VSS_PWSZ pwszExposedPath,
|
|
IN VSS_ID ProviderId,
|
|
IN LONG lSnapshotAttributes,
|
|
IN VSS_TIMESTAMP tsCreationTimestamp,
|
|
IN VSS_SNAPSHOT_STATE eStatus
|
|
) throw (HRESULT)
|
|
/*++
|
|
|
|
Routine description:
|
|
|
|
Initialize a VSS_OBJECT_PROP_Ptr in order to keep a VSS_OBJECT_SNAPSHOT structure.
|
|
|
|
Throws:
|
|
|
|
E_OUTOFMEMORY
|
|
|
|
--*/
|
|
{
|
|
WCHAR wszFunctionName[] = L"VSS_OBJECT_PROP_Ptr::InitializeAsSnapshot";
|
|
VSS_OBJECT_PROP* pProp = NULL;
|
|
|
|
try
|
|
{
|
|
// Assert the structure pointer to be set
|
|
BS_ASSERT(m_pStruct == NULL);
|
|
|
|
// Allocate the VSS_OBJECT_UNION structure
|
|
pProp = static_cast<VSS_OBJECT_PROP*>(::CoTaskMemAlloc(sizeof(VSS_OBJECT_PROP)));
|
|
if (pProp == NULL)
|
|
ft.Throw( VSSDBG_GEN, E_OUTOFMEMORY,
|
|
L"%s: Error on allocating the Properties structure",
|
|
wszFunctionName );
|
|
|
|
// Initialize the structure
|
|
VSS_OBJECT_PROP_Copy::init(pProp);
|
|
pProp->Type = VSS_OBJECT_SNAPSHOT;
|
|
|
|
// Getting the equivalent VSS_SNAPSHOT_PROP structure
|
|
BS_ASSERT(pProp);
|
|
VSS_SNAPSHOT_PROP& SnapshotProp = pProp->Obj.Snap;
|
|
|
|
// Setting the internal members
|
|
SnapshotProp.m_SnapshotId = SnapshotId;
|
|
SnapshotProp.m_SnapshotSetId = SnapshotSetId;
|
|
SnapshotProp.m_lSnapshotsCount = lSnapshotsCount;
|
|
::VssSafeDuplicateStr(ft, SnapshotProp.m_pwszSnapshotDeviceObject, pwszSnapshotDeviceObject);
|
|
::VssSafeDuplicateStr(ft, SnapshotProp.m_pwszOriginalVolumeName, pwszOriginalVolumeName);
|
|
::VssSafeDuplicateStr(ft, SnapshotProp.m_pwszOriginatingMachine, pwszOriginatingMachine);
|
|
::VssSafeDuplicateStr(ft, SnapshotProp.m_pwszServiceMachine, pwszServiceMachine);
|
|
::VssSafeDuplicateStr(ft, SnapshotProp.m_pwszExposedName, pwszExposedName);
|
|
::VssSafeDuplicateStr(ft, SnapshotProp.m_pwszExposedPath, pwszExposedPath);
|
|
SnapshotProp.m_ProviderId = ProviderId;
|
|
SnapshotProp.m_lSnapshotAttributes = lSnapshotAttributes;
|
|
SnapshotProp.m_tsCreationTimestamp = tsCreationTimestamp;
|
|
SnapshotProp.m_eStatus = eStatus;
|
|
|
|
// Setting the pointer field
|
|
m_pStruct = pProp;
|
|
}
|
|
VSS_STANDARD_CATCH(ft)
|
|
|
|
if (ft.HrFailed())
|
|
{
|
|
BS_ASSERT(ft.hr == E_OUTOFMEMORY);
|
|
BS_ASSERT(m_pStruct == NULL);
|
|
if (pProp)
|
|
{
|
|
VSS_OBJECT_PROP_Copy::destroy(pProp); // destroy its contents.
|
|
::CoTaskMemFree(static_cast<LPVOID>(pProp));
|
|
}
|
|
ft.Throw( VSSDBG_GEN, E_OUTOFMEMORY,
|
|
L"%s: Error catched 0x%08lx", wszFunctionName, ft.hr );
|
|
}
|
|
}
|
|
|
|
|
|
void VSS_OBJECT_PROP_Ptr::InitializeAsProvider(
|
|
IN CVssFunctionTracer& ft,
|
|
IN VSS_ID ProviderId,
|
|
IN VSS_PWSZ pwszProviderName,
|
|
IN VSS_PROVIDER_TYPE eProviderType,
|
|
IN VSS_PWSZ pwszProviderVersion,
|
|
IN VSS_ID ProviderVersionId,
|
|
IN CLSID ClassId
|
|
) throw (HRESULT)
|
|
/*++
|
|
|
|
Routine description:
|
|
|
|
Initialize a VSS_OBJECT_PROP_Ptr in order to keep a VSS_OBJECT_PROVIDER structure.
|
|
|
|
Throws:
|
|
|
|
E_OUTOFMEMORY
|
|
|
|
--*/
|
|
{
|
|
WCHAR wszFunctionName[] = L"VSS_OBJECT_PROP_Ptr::InitializeAsProvider";
|
|
VSS_OBJECT_PROP* pProp = NULL;
|
|
|
|
// Reset the error code
|
|
ft.hr = S_OK;
|
|
|
|
try
|
|
{
|
|
// Assert parameters
|
|
BS_ASSERT(pwszProviderName == NULL || pwszProviderName[0] != L'\0');
|
|
BS_ASSERT(eProviderType == VSS_PROV_SYSTEM ||
|
|
eProviderType == VSS_PROV_SOFTWARE ||
|
|
eProviderType == VSS_PROV_HARDWARE
|
|
);
|
|
|
|
// Assert the structure pointer to be set
|
|
BS_ASSERT(m_pStruct == NULL);
|
|
|
|
// Allocate the VSS_OBJECT_UNION structure
|
|
pProp = static_cast<VSS_OBJECT_PROP*>(::CoTaskMemAlloc(sizeof(VSS_OBJECT_PROP)));
|
|
if (pProp == NULL)
|
|
ft.Throw( VSSDBG_GEN, E_OUTOFMEMORY,
|
|
L"%s: Error on allocating the Properties structure",
|
|
wszFunctionName );
|
|
|
|
// Initialize the structure
|
|
VSS_OBJECT_PROP_Copy::init(pProp);
|
|
pProp->Type = VSS_OBJECT_PROVIDER;
|
|
|
|
// Getting the equivalent VSS_SNAPSHOT_PROP structure
|
|
BS_ASSERT(pProp);
|
|
VSS_PROVIDER_PROP& ProviderProp = pProp->Obj.Prov;
|
|
|
|
// Setting the internal members
|
|
ProviderProp.m_ProviderId = ProviderId;
|
|
::VssSafeDuplicateStr(ft, ProviderProp.m_pwszProviderName, pwszProviderName);
|
|
ProviderProp.m_eProviderType = eProviderType;
|
|
::VssSafeDuplicateStr(ft, ProviderProp.m_pwszProviderVersion, pwszProviderVersion);
|
|
ProviderProp.m_ProviderVersionId = ProviderVersionId;
|
|
ProviderProp.m_ClassId = ClassId;
|
|
|
|
// Setting the pointer field
|
|
m_pStruct = pProp;
|
|
}
|
|
VSS_STANDARD_CATCH(ft)
|
|
|
|
if (ft.HrFailed())
|
|
{
|
|
BS_ASSERT(ft.hr == E_OUTOFMEMORY);
|
|
BS_ASSERT(m_pStruct == NULL);
|
|
if (pProp)
|
|
{
|
|
VSS_OBJECT_PROP_Copy::destroy(pProp); // destroy its contents.
|
|
::CoTaskMemFree(static_cast<LPVOID>(pProp));
|
|
}
|
|
ft.Throw( VSSDBG_GEN, E_OUTOFMEMORY,
|
|
L"%s: Error catched 0x%08lx", wszFunctionName, ft.hr );
|
|
}
|
|
}
|
|
|
|
|
|
void VSS_OBJECT_PROP_Ptr::InitializeAsEmpty(
|
|
IN CVssFunctionTracer& ft
|
|
)
|
|
/*++
|
|
|
|
Routine description:
|
|
|
|
Initialize a VSS_OBJECT_PROP_Ptr in order to appear as an empty structure (to be filled later).
|
|
|
|
Throws:
|
|
|
|
E_OUTOFMEMORY
|
|
|
|
--*/
|
|
{
|
|
WCHAR wszFunctionName[] = L"VSS_OBJECT_PROP_Ptr::InitializeEmpty";
|
|
VSS_OBJECT_PROP* pProp = NULL;
|
|
|
|
// Reset the error code
|
|
ft.hr = S_OK;
|
|
|
|
try
|
|
{
|
|
// Assert the structure pointer to be set
|
|
BS_ASSERT(m_pStruct == NULL);
|
|
|
|
// Allocate the VSS_OBJECT_UNION structure
|
|
pProp = static_cast<VSS_OBJECT_PROP*>(::CoTaskMemAlloc(sizeof(VSS_OBJECT_PROP)));
|
|
if (pProp == NULL)
|
|
ft.Throw( VSSDBG_GEN, E_OUTOFMEMORY,
|
|
L"%s: Error on allocating the Properties structure",
|
|
wszFunctionName );
|
|
|
|
// Initialize the structure
|
|
VSS_OBJECT_PROP_Copy::init(pProp);
|
|
|
|
// Setting the pointer field
|
|
m_pStruct = pProp;
|
|
}
|
|
VSS_STANDARD_CATCH(ft)
|
|
|
|
if (ft.HrFailed())
|
|
{
|
|
BS_ASSERT(ft.hr == E_OUTOFMEMORY);
|
|
BS_ASSERT(m_pStruct == NULL);
|
|
BS_ASSERT(pProp == NULL);
|
|
ft.Throw( VSSDBG_GEN, E_OUTOFMEMORY,
|
|
L"%s: Error catched 0x%08lx", wszFunctionName, ft.hr );
|
|
}
|
|
}
|
|
|
|
|
|
void VSS_OBJECT_PROP_Ptr::Print(
|
|
IN CVssFunctionTracer& ft,
|
|
IN LPWSTR wszOutputBuffer,
|
|
IN LONG lBufferSize
|
|
)
|
|
{
|
|
WCHAR wszFunctionName[] = L"VSS_OBJECT_PROP_Ptr::Print";
|
|
|
|
// Reset the error code
|
|
ft.hr = S_OK;
|
|
|
|
try
|
|
{
|
|
if (m_pStruct == NULL)
|
|
::StringCchPrintfW(wszOutputBuffer, lBufferSize, L"NULL object\n\n");
|
|
|
|
// Effective copy
|
|
switch(m_pStruct->Type)
|
|
{
|
|
case VSS_OBJECT_SNAPSHOT:
|
|
|
|
::StringCchPrintfW(wszOutputBuffer, lBufferSize,
|
|
L"Id = " WSTR_GUID_FMT L", "
|
|
L"SnapshotSetId = " WSTR_GUID_FMT L"\n"
|
|
L"SnapCount = %ld "
|
|
L"DevObj = %s\n"
|
|
L"OriginalVolumeName = %s\n"
|
|
L"OriginatingMachine = %s\n"
|
|
L"ServiceMachine = %s\n"
|
|
L"Exposed name = %s\n"
|
|
L"Exposed path = %s\n"
|
|
L"ProviderId = " WSTR_GUID_FMT L"\n"
|
|
L"Attributes = 0x%08lx\n"
|
|
L"Timestamp = " WSTR_LONGLONG_FMT L"\n"
|
|
L"Status = %d\n ",
|
|
GUID_PRINTF_ARG( m_pStruct->Obj.Snap.m_SnapshotId ),
|
|
GUID_PRINTF_ARG( m_pStruct->Obj.Snap.m_SnapshotSetId ),
|
|
m_pStruct->Obj.Snap.m_lSnapshotsCount,
|
|
m_pStruct->Obj.Snap.m_pwszSnapshotDeviceObject,
|
|
m_pStruct->Obj.Snap.m_pwszOriginalVolumeName,
|
|
m_pStruct->Obj.Snap.m_pwszOriginatingMachine,
|
|
m_pStruct->Obj.Snap.m_pwszServiceMachine,
|
|
m_pStruct->Obj.Snap.m_pwszExposedName,
|
|
m_pStruct->Obj.Snap.m_pwszExposedPath,
|
|
GUID_PRINTF_ARG( m_pStruct->Obj.Snap.m_ProviderId ),
|
|
m_pStruct->Obj.Snap.m_lSnapshotAttributes,
|
|
LONGLONG_PRINTF_ARG( m_pStruct->Obj.Snap.m_tsCreationTimestamp ),
|
|
m_pStruct->Obj.Snap.m_eStatus);
|
|
break;
|
|
|
|
case VSS_OBJECT_PROVIDER:
|
|
::StringCchPrintfW(wszOutputBuffer, lBufferSize,
|
|
L"m_ProviderId = " WSTR_GUID_FMT L"\n"
|
|
L"m_pwszProviderName = %s\n"
|
|
L"m_ProviderType = %d\n"
|
|
L"m_pwszProviderVersion = %s\n"
|
|
L"m_ProviderVersionId = " WSTR_GUID_FMT L"\n"
|
|
L"m_ClassID: " WSTR_GUID_FMT L"\n\n",
|
|
GUID_PRINTF_ARG( m_pStruct->Obj.Prov.m_ProviderId ),
|
|
m_pStruct->Obj.Prov.m_pwszProviderName? m_pStruct->Obj.Prov.m_pwszProviderName: L"NULL",
|
|
m_pStruct->Obj.Prov.m_eProviderType,
|
|
m_pStruct->Obj.Prov.m_pwszProviderVersion? m_pStruct->Obj.Prov.m_pwszProviderVersion: L"NULL",
|
|
GUID_PRINTF_ARG( m_pStruct->Obj.Prov.m_ProviderVersionId ),
|
|
GUID_PRINTF_ARG( m_pStruct->Obj.Prov.m_ClassId )
|
|
);
|
|
break;
|
|
|
|
default:
|
|
ft.ErrBox( VSSDBG_GEN, E_UNEXPECTED,
|
|
L"%s: Wrong object type %d", wszFunctionName, m_pStruct->Type );
|
|
break;
|
|
}
|
|
}
|
|
VSS_STANDARD_CATCH(ft)
|
|
|
|
if (ft.HrFailed())
|
|
{
|
|
BS_ASSERT(m_pStruct == NULL);
|
|
ft.Throw( VSSDBG_GEN, E_UNEXPECTED,
|
|
L"%s: Error catched 0x%08lx", wszFunctionName, ft.hr );
|
|
}
|
|
}
|
|
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
// VSS_MGMT_OBJECT_PROP_Ptr class
|
|
|
|
|
|
void VSS_MGMT_OBJECT_PROP_Ptr::InitializeAsVolume(
|
|
IN CVssFunctionTracer& ft,
|
|
IN VSS_PWSZ pwszVolumeName,
|
|
IN VSS_PWSZ pwszVolumeDisplayName
|
|
) throw (HRESULT)
|
|
/*++
|
|
|
|
Routine description:
|
|
|
|
Initialize a VSS_MGMT_OBJECT_PROP_Ptr in order to keep a VSS_MGMT_OBJECT_SNAPSHOT structure.
|
|
|
|
Throws:
|
|
|
|
E_OUTOFMEMORY
|
|
|
|
--*/
|
|
{
|
|
WCHAR wszFunctionName[] = L"VSS_MGMT_OBJECT_PROP_Ptr::InitializeAsVolume";
|
|
VSS_MGMT_OBJECT_PROP* pProp = NULL;
|
|
|
|
try
|
|
{
|
|
// Assert the structure pointer to be set
|
|
BS_ASSERT(m_pStruct == NULL);
|
|
|
|
// Allocate the VSS_MGMT_OBJECT_UNION structure
|
|
pProp = static_cast<VSS_MGMT_OBJECT_PROP*>(::CoTaskMemAlloc(sizeof(VSS_MGMT_OBJECT_PROP)));
|
|
if (pProp == NULL)
|
|
ft.Throw( VSSDBG_GEN, E_OUTOFMEMORY,
|
|
L"%s: Error on allocating the Properties structure",
|
|
wszFunctionName );
|
|
|
|
// Initialize the structure
|
|
VSS_MGMT_OBJECT_PROP_Copy::init(pProp);
|
|
pProp->Type = VSS_MGMT_OBJECT_VOLUME;
|
|
|
|
// Getting the equivalent VSS_SNAPSHOT_PROP structure
|
|
BS_ASSERT(pProp);
|
|
VSS_VOLUME_PROP& VolumeProp = pProp->Obj.Vol;
|
|
|
|
// Setting the internal members
|
|
::VssSafeDuplicateStr(ft, VolumeProp.m_pwszVolumeName, pwszVolumeName);
|
|
::VssSafeDuplicateStr(ft, VolumeProp.m_pwszVolumeDisplayName, pwszVolumeDisplayName);
|
|
|
|
// Setting the pointer field
|
|
m_pStruct = pProp;
|
|
}
|
|
VSS_STANDARD_CATCH(ft)
|
|
|
|
if (ft.HrFailed())
|
|
{
|
|
BS_ASSERT(ft.hr == E_OUTOFMEMORY);
|
|
BS_ASSERT(m_pStruct == NULL);
|
|
if (pProp)
|
|
{
|
|
VSS_MGMT_OBJECT_PROP_Copy::destroy(pProp); // destroy its contents.
|
|
::CoTaskMemFree(static_cast<LPVOID>(pProp));
|
|
}
|
|
ft.Throw( VSSDBG_GEN, E_OUTOFMEMORY,
|
|
L"%s: Error catched 0x%08lx", wszFunctionName, ft.hr );
|
|
}
|
|
}
|
|
|
|
|
|
void VSS_MGMT_OBJECT_PROP_Ptr::InitializeAsDiffVolume(
|
|
IN CVssFunctionTracer& ft,
|
|
IN VSS_PWSZ pwszVolumeName,
|
|
IN VSS_PWSZ pwszVolumeDisplayName,
|
|
IN LONGLONG llVolumeFreeSpace,
|
|
IN LONGLONG llVolumeTotalSpace
|
|
) throw (HRESULT)
|
|
/*++
|
|
|
|
Routine description:
|
|
|
|
Initialize a VSS_MGMT_OBJECT_PROP_Ptr in order to keep a VSS_MGMT_OBJECT_PROVIDER structure.
|
|
|
|
Throws:
|
|
|
|
E_OUTOFMEMORY
|
|
|
|
--*/
|
|
{
|
|
WCHAR wszFunctionName[] = L"VSS_MGMT_OBJECT_PROP_Ptr::InitializeAsDiffVolume";
|
|
VSS_MGMT_OBJECT_PROP* pProp = NULL;
|
|
|
|
// Reset the error code
|
|
ft.hr = S_OK;
|
|
|
|
try
|
|
{
|
|
// Assert parameters
|
|
BS_ASSERT(llVolumeFreeSpace >= 0);
|
|
BS_ASSERT(llVolumeTotalSpace >= 0);
|
|
|
|
// Assert the structure pointer to be set
|
|
BS_ASSERT(m_pStruct == NULL);
|
|
|
|
// Allocate the VSS_MGMT_OBJECT_UNION structure
|
|
pProp = static_cast<VSS_MGMT_OBJECT_PROP*>(::CoTaskMemAlloc(sizeof(VSS_MGMT_OBJECT_PROP)));
|
|
if (pProp == NULL)
|
|
ft.Throw( VSSDBG_GEN, E_OUTOFMEMORY,
|
|
L"%s: Error on allocating the Properties structure",
|
|
wszFunctionName );
|
|
|
|
// Initialize the structure
|
|
VSS_MGMT_OBJECT_PROP_Copy::init(pProp);
|
|
pProp->Type = VSS_MGMT_OBJECT_DIFF_VOLUME;
|
|
|
|
// Getting the equivalent VSS_SNAPSHOT_PROP structure
|
|
BS_ASSERT(pProp);
|
|
VSS_DIFF_VOLUME_PROP& DiffVolumeProp = pProp->Obj.DiffVol;
|
|
|
|
// Setting the internal members
|
|
::VssSafeDuplicateStr(ft, DiffVolumeProp.m_pwszVolumeName, pwszVolumeName);
|
|
::VssSafeDuplicateStr(ft, DiffVolumeProp.m_pwszVolumeDisplayName, pwszVolumeDisplayName);
|
|
DiffVolumeProp.m_llVolumeFreeSpace = llVolumeFreeSpace;
|
|
DiffVolumeProp.m_llVolumeTotalSpace = llVolumeTotalSpace;
|
|
|
|
// Setting the pointer field
|
|
m_pStruct = pProp;
|
|
}
|
|
VSS_STANDARD_CATCH(ft)
|
|
|
|
if (ft.HrFailed())
|
|
{
|
|
BS_ASSERT(ft.hr == E_OUTOFMEMORY);
|
|
BS_ASSERT(m_pStruct == NULL);
|
|
if (pProp)
|
|
{
|
|
VSS_MGMT_OBJECT_PROP_Copy::destroy(pProp); // destroy its contents.
|
|
::CoTaskMemFree(static_cast<LPVOID>(pProp));
|
|
}
|
|
ft.Throw( VSSDBG_GEN, E_OUTOFMEMORY,
|
|
L"%s: Error catched 0x%08lx", wszFunctionName, ft.hr );
|
|
}
|
|
}
|
|
|
|
|
|
void VSS_MGMT_OBJECT_PROP_Ptr::InitializeAsDiffArea(
|
|
IN CVssFunctionTracer& ft,
|
|
IN VSS_PWSZ pwszVolumeName,
|
|
IN VSS_PWSZ pwszDiffAreaVolumeName,
|
|
IN LONGLONG llUsedDiffSpace,
|
|
IN LONGLONG llAllocatedDiffSpace,
|
|
IN LONGLONG llMaximumDiffSpace
|
|
) throw (HRESULT)
|
|
/*++
|
|
|
|
Routine description:
|
|
|
|
Initialize a VSS_MGMT_OBJECT_PROP_Ptr in order to keep a VSS_MGMT_OBJECT_PROVIDER structure.
|
|
|
|
Throws:
|
|
|
|
E_OUTOFMEMORY
|
|
|
|
--*/
|
|
{
|
|
WCHAR wszFunctionName[] = L"VSS_MGMT_OBJECT_PROP_Ptr::InitializeAsProvider";
|
|
VSS_MGMT_OBJECT_PROP* pProp = NULL;
|
|
|
|
// Reset the error code
|
|
ft.hr = S_OK;
|
|
|
|
try
|
|
{
|
|
// Assert parameters
|
|
BS_ASSERT(llUsedDiffSpace >= 0);
|
|
BS_ASSERT(llAllocatedDiffSpace >= 0);
|
|
BS_ASSERT((llMaximumDiffSpace >= 0) || (llMaximumDiffSpace == -1));
|
|
|
|
// Assert the structure pointer to be set
|
|
BS_ASSERT(m_pStruct == NULL);
|
|
|
|
// Allocate the VSS_MGMT_OBJECT_UNION structure
|
|
pProp = static_cast<VSS_MGMT_OBJECT_PROP*>(::CoTaskMemAlloc(sizeof(VSS_MGMT_OBJECT_PROP)));
|
|
if (pProp == NULL)
|
|
ft.Throw( VSSDBG_GEN, E_OUTOFMEMORY,
|
|
L"%s: Error on allocating the Properties structure",
|
|
wszFunctionName );
|
|
|
|
// Initialize the structure
|
|
VSS_MGMT_OBJECT_PROP_Copy::init(pProp);
|
|
pProp->Type = VSS_MGMT_OBJECT_DIFF_AREA;
|
|
|
|
// Getting the equivalent VSS_SNAPSHOT_PROP structure
|
|
BS_ASSERT(pProp);
|
|
VSS_DIFF_AREA_PROP& DiffAreaProp = pProp->Obj.DiffArea;
|
|
|
|
// Setting the internal members
|
|
::VssSafeDuplicateStr(ft, DiffAreaProp.m_pwszVolumeName, pwszVolumeName);
|
|
::VssSafeDuplicateStr(ft, DiffAreaProp.m_pwszDiffAreaVolumeName, pwszDiffAreaVolumeName);
|
|
DiffAreaProp.m_llMaximumDiffSpace = llMaximumDiffSpace;
|
|
DiffAreaProp.m_llAllocatedDiffSpace = llAllocatedDiffSpace;
|
|
DiffAreaProp.m_llUsedDiffSpace = llUsedDiffSpace;
|
|
|
|
// Setting the pointer field
|
|
m_pStruct = pProp;
|
|
}
|
|
VSS_STANDARD_CATCH(ft)
|
|
|
|
if (ft.HrFailed())
|
|
{
|
|
BS_ASSERT(ft.hr == E_OUTOFMEMORY);
|
|
BS_ASSERT(m_pStruct == NULL);
|
|
if (pProp)
|
|
{
|
|
VSS_MGMT_OBJECT_PROP_Copy::destroy(pProp); // destroy its contents.
|
|
::CoTaskMemFree(static_cast<LPVOID>(pProp));
|
|
}
|
|
ft.Throw( VSSDBG_GEN, E_OUTOFMEMORY,
|
|
L"%s: Error catched 0x%08lx", wszFunctionName, ft.hr );
|
|
}
|
|
}
|
|
|
|
|
|
void VSS_MGMT_OBJECT_PROP_Ptr::InitializeAsEmpty(
|
|
IN CVssFunctionTracer& ft
|
|
)
|
|
/*++
|
|
|
|
Routine description:
|
|
|
|
Initialize a VSS_MGMT_OBJECT_PROP_Ptr in order to appear as an empty structure (to be filled later).
|
|
|
|
Throws:
|
|
|
|
E_OUTOFMEMORY
|
|
|
|
--*/
|
|
{
|
|
WCHAR wszFunctionName[] = L"VSS_MGMT_OBJECT_PROP_Ptr::InitializeEmpty";
|
|
VSS_MGMT_OBJECT_PROP* pProp = NULL;
|
|
|
|
// Reset the error code
|
|
ft.hr = S_OK;
|
|
|
|
try
|
|
{
|
|
// Assert the structure pointer to be set
|
|
BS_ASSERT(m_pStruct == NULL);
|
|
|
|
// Allocate the VSS_MGMT_OBJECT_UNION structure
|
|
pProp = static_cast<VSS_MGMT_OBJECT_PROP*>(::CoTaskMemAlloc(sizeof(VSS_MGMT_OBJECT_PROP)));
|
|
if (pProp == NULL)
|
|
ft.Throw( VSSDBG_GEN, E_OUTOFMEMORY,
|
|
L"%s: Error on allocating the Properties structure",
|
|
wszFunctionName );
|
|
|
|
// Initialize the structure
|
|
VSS_MGMT_OBJECT_PROP_Copy::init(pProp);
|
|
|
|
// Setting the pointer field
|
|
m_pStruct = pProp;
|
|
}
|
|
VSS_STANDARD_CATCH(ft)
|
|
|
|
if (ft.HrFailed())
|
|
{
|
|
BS_ASSERT(ft.hr == E_OUTOFMEMORY);
|
|
BS_ASSERT(m_pStruct == NULL);
|
|
BS_ASSERT(pProp == NULL);
|
|
ft.Throw( VSSDBG_GEN, E_OUTOFMEMORY,
|
|
L"%s: Error catched 0x%08lx", wszFunctionName, ft.hr );
|
|
}
|
|
}
|
|
|
|
|
|
void VSS_MGMT_OBJECT_PROP_Ptr::Print(
|
|
IN CVssFunctionTracer& ft,
|
|
IN LPWSTR wszOutputBuffer,
|
|
IN LONG lBufferSize
|
|
)
|
|
{
|
|
WCHAR wszFunctionName[] = L"VSS_MGMT_OBJECT_PROP_Ptr::Print";
|
|
|
|
// Reset the error code
|
|
ft.hr = S_OK;
|
|
|
|
try
|
|
{
|
|
if (m_pStruct == NULL)
|
|
::StringCchPrintfW(wszOutputBuffer, lBufferSize, L"NULL object\n\n");
|
|
|
|
switch(m_pStruct->Type)
|
|
{
|
|
case VSS_MGMT_OBJECT_VOLUME:
|
|
|
|
::StringCchPrintfW(wszOutputBuffer, lBufferSize,
|
|
L"VolumeName = %s\n"
|
|
L"VolumeDisplayName = %s\n"
|
|
L"lCurrentSnapshotCount = %ld \n",
|
|
m_pStruct->Obj.Vol.m_pwszVolumeName,
|
|
m_pStruct->Obj.Vol.m_pwszVolumeDisplayName);
|
|
break;
|
|
|
|
case VSS_MGMT_OBJECT_DIFF_VOLUME:
|
|
::StringCchPrintfW(wszOutputBuffer, lBufferSize,
|
|
L"VolumeName = %s\n"
|
|
L"VolumeDisplayName = %s\n"
|
|
L"llFreeSpace = " WSTR_LONGLONG_FMT L"\n"
|
|
L"llTotalSpace = " WSTR_LONGLONG_FMT L"\n",
|
|
m_pStruct->Obj.DiffVol.m_pwszVolumeName,
|
|
m_pStruct->Obj.DiffVol.m_pwszVolumeDisplayName,
|
|
m_pStruct->Obj.DiffVol.m_llVolumeFreeSpace,
|
|
m_pStruct->Obj.DiffVol.m_llVolumeTotalSpace);
|
|
break;
|
|
|
|
case VSS_MGMT_OBJECT_DIFF_AREA:
|
|
::StringCchPrintfW(wszOutputBuffer, lBufferSize,
|
|
L"VolumeName = %s\n"
|
|
L"VolumeDiffAreaName = %s\n"
|
|
L"MaxSpace = " WSTR_LONGLONG_FMT L"\n"
|
|
L"AllocatedSpace = " WSTR_LONGLONG_FMT L"\n"
|
|
L"UsedSpace = " WSTR_LONGLONG_FMT L"\n",
|
|
m_pStruct->Obj.DiffArea.m_pwszVolumeName,
|
|
m_pStruct->Obj.DiffArea.m_pwszDiffAreaVolumeName,
|
|
m_pStruct->Obj.DiffArea.m_llMaximumDiffSpace,
|
|
m_pStruct->Obj.DiffArea.m_llAllocatedDiffSpace,
|
|
m_pStruct->Obj.DiffArea.m_llUsedDiffSpace);
|
|
break;
|
|
|
|
|
|
default:
|
|
ft.ErrBox( VSSDBG_GEN, E_UNEXPECTED,
|
|
L"%s: Wrong object type %d", wszFunctionName, m_pStruct->Type );
|
|
break;
|
|
}
|
|
}
|
|
VSS_STANDARD_CATCH(ft)
|
|
|
|
if (ft.HrFailed())
|
|
{
|
|
BS_ASSERT(m_pStruct == NULL);
|
|
ft.Throw( VSSDBG_GEN, E_UNEXPECTED,
|
|
L"%s: Error catched 0x%08lx", wszFunctionName, ft.hr );
|
|
}
|
|
}
|
|
|
|
|