Remarque
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de vous connecter ou de modifier des répertoires.
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de modifier des répertoires.
Récupère le document case activée sum pour une demande de point d’arrêt en fonction de l’identificateur unique de l’algorithme case activée sum à utiliser.
Syntaxe
Paramètres
guidAlgorithm
[in] Identificateur unique de l’algorithme case activée sum.
pChecksumData
[out] Document case activée um pour la demande de point d’arrêt.
Valeur de retour
En cas de réussite, retourne S_OK , sinon, retourne un code d'erreur.
Exemple
L’exemple suivant montre une fonction qui case activée si l’case activée um d’un document, qui est sur le point d’être lié, correspond à l’une de l’interface utilisateur.
bool CDebugProgram::DoChecksumsMatch(CDebugPendingBreakpoint *pPending, CDebugCodeContext *pContext)
{
bool fRet = false;
HRESULT hRes;
// Get the checksum for the document we are about to bind to from the pdb side
GUID guidAlgorithmId;
BYTE *pChecksum = NULL;
ULONG cNumBytes = 0;
hRes = pContext->GetDocumentChecksumAndAlgorithmId(&guidAlgorithmId, &pChecksum, &cNumBytes);
if ( S_OK == hRes )
{
// Get checksum data for the document from the UI (request) side
CComPtr<IDebugBreakpointChecksumRequest2> pChecksumRequest;
hRes = pPending->GetChecksumRequest(&pChecksumRequest);
if ( S_OK == hRes )
{
CHECKSUM_DATA data;
hRes = pChecksumRequest->GetChecksum(guidAlgorithmId, &data);
if ( S_OK == hRes )
{
if ( data.ByteCount == cNumBytes && memcmp(data.pBytes, pChecksum, cNumBytes) == 0 )
fRet = true;
else
fRet = false;
// Free up data allocated for checksum data
CoTaskMemFree(data.pBytes);
}
else
fRet = true; // checksums not available - user disabled checksums
}
else
fRet = true; // we couldn't get checksum from UI - default to past behavior
// free up space allocated for checksum from pdb
CoTaskMemFree(pChecksum);
}
else
fRet = true; // we don't have a checksum to compare with.
return ( fRet );
}