NDF-Hilfsklassenerweiterung mit Handoff
Diese Hilfsklasse weist eine Integritätsabhängigkeit von der im ersten Beispiel codierten SimpleFileHelperClass auf.
Die zweite Handoff-Hilfsklasse ist eine einfache Passthrough-Hilfsklasse, die selbst keine Diagnose durchführt. Stattdessen wird immer eine niedrigere Integritätshypothese für die SimpleFileHelperClass generiert. Dies ist nützlich, um als Platzhalter für das zukünftige Hinzufügen von Diagnose-Funktion in dieser Hilfsklasse zu dienen. Die Handoff-Hilfsklasse implementiert zwei Methoden.
Die LowHealth-Methode wird verwendet, um den Diagnosestatus auf DS_INDETERMINATE festzulegen. Dadurch ruft NDF GetLowerHypotheses auf.
#include <windows.h>
HRESULT HandOffTestHelperClass::LowHealth(
/* [unique][string][in] */ LPCWSTR pwszInstanceDescription,
/* [string][out] */ LPWSTR *ppwszDescription,
/* [out] */ long *pDeferredTime,
/* [out] */ DIAGNOSIS_STATUS *pStatus)
{
*pStatus = DS_INDETERMINATE;
return S_OK;
}
Als Nächstes wird GetLowerHypotheses implementiert, um NDF mitzuteilen, welche Hilfsklasse zu diagnostizieren ist.
#include <windows.h>
HRESULT HandOffTestHelperClass::GetLowerHypotheses(
ULONG *Count,
HYPOTHESIS **Hypotheses)
{
HRESULT hr = S_OK;
HYPOTHESIS *pHypothesis=NULL;
HELPER_ATTRIBUTE *pAttr=NULL;
pHypothesis = (PHYPOTHESIS)CoTaskMemAlloc(sizeof(HYPOTHESIS));
if (pHypothesis == NULL)
{
return E_OUTOFMEMORY;
}
SecureZeroMemory(pHypothesis, sizeof(HYPOTHESIS));
pAttr = (PHELPER_ATTRIBUTE)CoTaskMemAlloc(sizeof(HELPER_ATTRIBUTE));
if (pAttr == NULL)
{
hr = E_OUTOFMEMORY;
goto Error;
}
SecureZeroMemory(pAttr, sizeof(HELPER_ATTRIBUTE));
//set the helper class name to hand off to
hr = StringCchCopyWithAlloc(&pHypothesis->pwszClassName, MAX_PATH,
L"SimpleFileHelperClass");
if (FAILED(hr))
{
goto Error;
}
//populate the attribute
//set the attribute name
hr = StringCchCopyWithAlloc(&pAttr->pwszName, MAX_PATH, L"filename");
if (FAILED(hr))
{
goto Error;
}
//set attribute data
pAttr->type = AT_STRING;
hr = StringCchCopyWithAlloc(&pAttr->PWStr, MAX_PATH, m_pwszTestFile);
if (FAILED(hr))
{
goto Error;
}
//set the attributes to the hypothesis
pHypothesis->celt = 1; //number of attributes
pHypothesis->rgAttributes=pAttr;
//pass data back
*pcelt = 1; //one hypothesis
*pprgHypotheses = pHypothesis;
return S_OK;
Error:
if (pAttr)
{
if (pAttr->PWStr)
CoTaskMemFree(pAttr->PWStr);
if (pAttr->pwszName)
CoTaskMemFree(pAttr->pwszName);
}
if (pHypothesis)
{
if (pHypothesis->pwszClassName)
CoTaskMemFree(pHypothesis->pwszClassName);
CoTaskMemFree(pHypothesis);
}
return hr;
}