Not
Bu sayfaya erişim yetkilendirme gerektiriyor. Oturum açmayı veya dizinleri değiştirmeyi deneyebilirsiniz.
Bu sayfaya erişim yetkilendirme gerektiriyor. Dizinleri değiştirmeyi deneyebilirsiniz.
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
}