IDebugComPlusSymbolProvider::IsHiddenCode
Bestimmt, ob der Code an der angegebenen Debuggeradresse ausgeblendet ist.
Syntax
Parameter
pAddress
[in] Die Debugadresse, die durch eine IDebugAddress-Schnittstelle dargestellt wird.
Rückgabewert
Wenn der Code ausgeblendet ist, wird zurückgegeben S_OK
; andernfalls wird zurückgegeben S_FALSE
.
Beispiel
Das folgende Beispiel zeigt, wie Sie diese Methode für ein CDebugSymbolProvider -Objekt implementieren, das die IDebugComPlusSymbolProvider-Schnittstelle verfügbar macht.
HRESULT CDebugSymbolProvider::IsHiddenCode(
IDebugAddress* pAddress
)
{
HRESULT hr = S_OK;
CDEBUG_ADDRESS address;
CComPtr<CModule> pModule;
ASSERT(IsValidObjectPtr(this, CDebugSymbolProvider));
ASSERT(IsValidInterfacePtr(pAddress, IDebugAddress));
METHOD_ENTRY( CDebugSymbolProvider::IsHiddenCode );
IfFalseGo( pAddress, S_FALSE );
IfFailGo( pAddress->GetAddress( &address ) );
ASSERT(address.addr.dwKind == ADDRESS_KIND_METADATA_METHOD);
IfFalseGo( address.addr.dwKind == ADDRESS_KIND_METADATA_METHOD, S_FALSE );
IfFailGo( GetModule( address.GetModule(), &pModule) );
if (!pModule->IsHiddenCode( address.addr.addr.addrMethod.tokMethod,
address.addr.addr.addrMethod.dwVersion,
address.addr.addr.addrMethod.dwOffset ))
{
// S_FALSE indicates this sequence point is not hidden
hr = S_FALSE;
}
Error:
METHOD_EXIT( CDebugSymbolProvider::IsHiddenCode, hr );
if (!SUCCEEDED(hr))
{
hr = S_FALSE;
}
return hr;
}