Freigeben über


IDebugCustomAttributeQuery::GetCustomAttributeByName

Ruft ein benutzerdefiniertes Attribut mit dem Namen ab.

Syntax

int GetCustomAttributeByName(
    string    pszCustomAttributeName,
    ref int[] ppBlob,
    out uint  pdwLen
);

Parameter

pszCustomAttributeName
[in] Name des benutzerdefinierten Attributs.

ppBlob
[in,out] Array von Bytes, die die benutzerdefinierten Attributdaten enthalten.

pdwLen
[out] Länge in Byte des ppBlob Parameters.

Rückgabewert

Gibt bei Erfolg S_OK zurück. Wenn kein benutzerdefiniertes Attribut vorhanden ist, wird zurückgegeben S_FALSE. Andernfalls wird ein Fehlercode zurückgegeben.

Beispiel

Das folgende Beispiel zeigt, wie Sie diese Methode für ein CDebugClassFieldSymbol -Objekt implementieren, das die IDebugCustomAttributeQuery-Schnittstelle verfügbar macht.

HRESULT CDebugClassFieldSymbol::GetCustomAttributeByName(
    LPCOLESTR pszCustomAttributeName,
    BYTE *pBlob,
    DWORD *pdwLen
)
{
    HRESULT hr = S_FALSE;
    CComPtr<IMetaDataImport> pMetadata;
    mdToken token = mdTokenNil;
    CComPtr<IDebugField> pField;
    CComPtr<IDebugCustomAttributeQuery> pCA;

    ASSERT(IsValidWideStringPtr(pszCustomAttributeName));
    ASSERT(IsValidWritePtr(pdwLen, ULONG*));

    METHOD_ENTRY( CDebugClassFieldSymbol::GetCustomAttributeByName );

    IfFalseGo( pszCustomAttributeName && pdwLen, E_INVALIDARG );

    IfFailGo( m_spSH->GetMetadata( m_spAddress->GetModule(), &pMetadata ) );

    IfFailGo( CDebugCustomAttribute::GetTokenFromAddress( m_spAddress, &token) );
    IfFailGo( CDebugCustomAttribute::GetCustomAttributeByName( pMetadata,
              token,
              pszCustomAttributeName,
              pBlob,
              pdwLen ) );
Error:

    METHOD_EXIT( CDebugClassFieldSymbol::GetCustomAttributeByName, hr );
    return hr;
}

Siehe auch