Aracılığıyla paylaş


IDiaDataSourceEx::ValidatePdbEx

Program veritabanı (.pdb) dosyasının sağlanan imza bilgileriyle eşleşdiğini doğrular.

Sözdizimi

HRESULT ValidatePdb ( 
   LPCOLESTR    pdbPath,
   const GUID*  pcsig70,
   DWORD        sig,
   DWORD        age,
   BOOL*        pfStripped
);

Parametreler

pdbPath

[in] .pdb dosyasının yolu.

pcsig70

[in] .pdb dosya imzasını doğrulamak için genel benzersiz tanımlayıcı (GUID) imzası. Yalnızca Visual C++ ve sonraki sürümlerdeki .pdb dosyalarının GUID imzaları vardır.

sig

[in] .pdb dosya imzasını doğrulamak için 32 bit imza.

age

[in] Doğrulanması gereken yaş değeri. Yaş bilinen bir saat değerine karşılık gelmez; .pdb dosyasının ilgili .exe dosyasıyla eşitlenmemiş olup olmadığını belirlemek için kullanılır.

pfStripped

[out] PDB diğer bilgilerle eşleşiyorsa, bu parametre PDB'nin özel simgelerden kaldırılıp kaldırılmadığını gösterecek şekilde ayarlanır. Bu, IDiaSymbol::get_isStripped tarafından döndürülen değerle aynıdır. PDB diğer değerlerle eşleşmezse veya bu yöntem başarısız olursa, bu parametre belirtilmez.

Dönüş Değeri

Başarılı olursa döndürür S_OK; aksi takdirde bir hata kodu döndürür. Aşağıdaki tabloda bu yöntem için olası dönüş değerleri gösterilmektedir.

Value Açıklama
E_PDB_NOT_FOUND Dosya açılamadı veya dosya geçersiz bir biçime sahip.
E_PDB_FORMAT Eski bir biçime sahip bir dosyaya erişmeye çalışıldı.
E_PDB_INVALID_SIG İmza eşleşmiyor.
E_PDB_INVALID_AGE Yaş eşleşmiyor.
E_INVALIDARG Geçersiz parametre.
E_UNEXPECTED Veri kaynağı zaten hazırlanmıştır.

Açıklamalar

.pdb dosyası hem imza hem de yaş değerlerini içerir. Bu değerler .pdb dosyasıyla eşleşen .exe veya .dll dosyasında çoğaltılır. Bu yöntem, adlandırılmış .pdb dosyasının imzasının ve yaşının PDB'yi yüklemeden veya kullanıma hazırlamadan sağlanan değerlerle eşleşip eşleşmediğini doğrular.

Doğrulama olmadan bir .pdb dosyası yüklemek için yöntemini kullanın IDiaDataSourceEx::loadDataFromPdbEx .

.pdb dosyasını belirli ölçütlere göre yüklemek ve doğrulamak için yöntemini kullanın IDiaDataSourceEx::loadAndValidateDataFromPdbEx .

Örnek

IDiaDataSource* pSource;  // Previously created data source.
DEFINE_GUID(expectedGUIDSignature,0x1234,0x5678,0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08);
DWORD expectedFileSignature = 0x12345678;
DWORD expectedAge           = 128;
BOOL fStripped              = FALSE;

HRESULT hr;
hr = pSource->lValidatePdb( L"myprog.pdb",
                            &expectedGUIDSignature,
                            expectedFileSignature,
                            expectedAge,
                            &fStripped);
if (FAILED(hr))
{
    // Report an error
}

Ayrıca bkz.