Pobieranie właściwości lokalnych
Ważne
W programie Visual Studio 2015 ten sposób implementowania ewaluatorów wyrażeń jest przestarzały. Aby uzyskać informacje na temat implementowania ewaluatorów wyrażeń CLR, zobacz clR expression evaluators and Managed expression evaluator sample (Przykład ewaluatora wyrażeń zarządzanych).
Program Visual Studio wywołuje funkcję EnumChildren w celu uzyskania obiektu IEnumDebugPropertyInfo2, który zapewnia dostęp do wszystkich ustawień lokalnych, które mają być wyświetlane w oknie Ustawienia lokalne. Następnie program Visual Studio wywołuje metodę Next (Dalej ), aby uzyskać informacje, które mają być wyświetlane dla każdego lokalnego. W tym przykładzie klasa CEnumPropertyInfo
implementuje IEnumDebugPropertyInfo2
interfejs.
Ta implementacja wykonuje IEnumDebugPropertyInfo2::Next
następujące zadania:
Czyści tablicę, w której mają być przechowywane informacje.
Wywołuje metodę Next dla każdego lokalnego, przechowując zwróconą DEBUG_PROPERTY_INFO w tablicy, która ma zostać zwrócona. Obiekt IEnumDebugFields został dostarczony podczas tworzenia wystąpienia tej
CEnumPropertyInfo
klasy.
Kod zarządzany
W tym przykładzie pokazano implementację IEnumDebugPropertyInfo2::EnumChildren
ustawień lokalnych metody w kodzie zarządzanym.
namespace EEMC
{
public class CEnumMethodField : IEnumDebugFields
{
public HRESULT Next(
uint count,
DEBUG_PROPERTY_INFO[] properties,
out uint fetched)
{
if (count > properties.Length)
throw new COMException();
// Zero out the array.
for (int i= 0; i < count; i++)
{
properties[i].bstrFullName = "";
properties[i].bstrName = "";
properties[i].bstrType = "";
properties[i].bstrValue = "";
properties[i].dwAttrib = 0;
properties[i].dwFields = 0;
properties[i].pProperty = null;
}
fetched = 0;
// COM interop.
HRESULT hr;
uint innerFetched;
IDebugField[] field = new IDebugField[1];
while (fetched < count)
{
field[0] = null;
innerFetched = 0;
// Get next field.
if (fetched < fieldCount)
hr = fields.Next(1, field, ref innerFetched);
// No more fields.
else return COM.S_FALSE;
if (hr != COM.S_OK || innerFetched != 1 || field[0] == null)
throw new COMException("CEnumPropertyInfo.Next");
// Get property from field.
CFieldProperty fieldProperty =
new CFieldProperty(provider, address, binder, field[0]);
DEBUG_PROPERTY_INFO[] property =
new DEBUG_PROPERTY_INFO[1];
fieldProperty.GetPropertyInfo((uint) infoFlags, radix, 0, null, 0, property);
properties[fetched++] = property[0];
}
return COM.S_OK;
}
}
}
Niezarządzany kod
W tym przykładzie pokazano implementację IEnumDebugPropertyInfo2::EnumChildren
ustawień lokalnych metody w kodzie niezarządzanym.
STDMETHODIMP CEnumPropertyInfo::Next(
in ULONG count,
out DEBUG_PROPERTY_INFO* pelements,
out ULONG* pfetched )
{
if (pfetched)
*pfetched = 0;
if (!pelements)
return E_INVALIDARG;
else
memset( pelements, 0, count * sizeof(DEBUG_PROPERTY_INFO));
HRESULT hr = S_OK;
ULONG idx = 0;
while (idx < count)
{
ULONG fetchedFields;
IDebugField* pfield;
//get the next field
hr = m_fields->Next( 1, &pfield, &fetchedFields );
if (FAILED(hr))
return hr;
if (fetchedFields != 1)
return E_FAIL;
idx++;
//create a CFieldProperty to retrieve the DEBUG_PROPERTY_INFO
CFieldProperty* pproperty =
new CFieldProperty( m_provider, m_address, m_binder, pfield );
pfield->Release();
if (!pproperty)
return E_OUTOFMEMORY;
hr = pproperty->Init();
if (FAILED(hr))
{
pproperty->Release();
return hr;
}
hr = pproperty->GetPropertyInfo( m_infoFlags,
m_radix,
0,
NULL,
0,
pelements + idx - 1);
pproperty->Release();
if (FAILED(hr))
return hr;
}
if (pfetched)
*pfetched = idx;
return hr;
}