IDebugComPlusSymbolProvider::IsFunctionStale
Détermine si la fonction à l’adresse de débogage spécifiée est considérée comme obsolète.
Syntaxe
Paramètres
pAddress
[in] Adresse de débogage représentée par une interface IDebugAddress . Cette adresse doit être une METHOD_ADDRESS.
Valeur de retour
Si la fonction est considérée comme obsolète, retourne S_OK
. Si la fonction n’est pas obsolète, retourne S_FALSE
.
Exemple
L’exemple suivant montre comment implémenter cette méthode pour un objet CDebugSymbolProvider qui expose l’interface IDebugComPlusSymbolProvider .
HRESULT CDebugSymbolProvider::IsFunctionStale(
IDebugAddress* pAddress
)
{
HRESULT hr = S_OK;
CDEBUG_ADDRESS address;
CComPtr<CModule> pModule;
ASSERT(IsValidObjectPtr(this, CDebugSymbolProvider));
ASSERT(IsValidInterfacePtr(pAddress, IDebugAddress));
METHOD_ENTRY( CDebugSymbolProvider::IsFunctionStale );
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->IsFunctionStale( address.addr.addr.addrMethod.tokMethod,
address.addr.addr.addrMethod.dwVersion ))
{
// S_FALSE indicates the function is not stale
hr = S_FALSE;
}
Error:
METHOD_EXIT( CDebugSymbolProvider::IsFunctionStale, hr );
if (!SUCCEEDED(hr))
{
hr = S_FALSE;
}
return hr;
}