Nuta
Dostęp do tej strony wymaga autoryzacji. Możesz spróbować się zalogować lub zmienić katalog.
Dostęp do tej strony wymaga autoryzacji. Możesz spróbować zmienić katalogi.
Pobiera do typu symbolu, biorąc pod uwagę jego adres debugowania.
Składnia
Parametry
pAddress
[in] Adres debugowania reprezentowany przez interfejs IDebugAddress .
ppField
[out] Zwraca typ tablicy, ponieważ jest reprezentowany przez interfejs IDebugClassField .
Wartość zwracana
Jeśli operacja powiedzie się, zwraca wartość S_OK; w przeciwnym razie zwraca kod błędu.
Przykład
W poniższym przykładzie pokazano, jak zaimplementować tę metodę dla obiektu CDebugSymbolProvider, który uwidacznia interfejs IDebugComPlusSymbolProvider.
HRESULT CDebugSymbolProvider::GetTypeFromAddress(
IDebugAddress *pAddress,
IDebugField **ppField)
{
HRESULT hr = E_FAIL;
CDEBUG_ADDRESS da;
CDebugGenericParamScope* pGenScope = NULL;
METHOD_ENTRY( CDebugDynamicFieldSymbol::GetTypeFromPrimitive );
ASSERT(IsValidObjectPtr(this, CDebugSymbolProvider));
ASSERT(IsValidWritePtr(ppField, IDebugField*));
IfFailGo( pAddress->GetAddress(&da) );
switch ( da.addr.dwKind )
{
case ADDRESS_KIND_METADATA_LOCAL:
case ADDRESS_KIND_METADATA_PARAM:
case ADDRESS_KIND_METADATA_FIELD:
case ADDRESS_KIND_METADATA_ARRAYELEM:
case ADDRESS_KIND_METADATA_METHOD:
{
IfFailGo( this->CreateClassType(da.GetModule(), da.tokClass, ppField) );
break;
}
case ADDRESS_KIND_METADATA_RETVAL:
{
if ( da.addr.addr.addrRetVal.dwCorType )
{
IfNullGo( pGenScope = new CDebugGenericParamScope(da.GetModule(), da.tokClass, da.GetMethod()), E_OUTOFMEMORY );
IfFailGo( this->CreateType((const COR_SIGNATURE*)(&da.addr.addr.addrRetVal.rgSig),
da.addr.addr.addrRetVal.dwSigSize,
da.GetModule(),
mdMethodDefNil,
pGenScope,
ppField) );
}
else
{
IfFailGo( this->CreateClassType(da.GetModule(), da.tokClass, ppField) );
}
break;
}
default:
{
ASSERT(!"Address type not supported.");
}
}
Error:
METHOD_EXIT( CDebugDynamicFieldSymbol::GetTypeFromPrimitive, hr );
RELEASE( pGenScope );
return hr;
}