Partilhar via


IDebugCustomAttributeQuery::GetCustomAttributeByName

Recupera um atributo personalizado fornecido seu nome.

HRESULT GetCustomAttributeByName(
   LPCOLESTR pszCustomAttributeName,
   BYTE*     ppBlob,
   DWORD*    pdwLen
);
int GetCustomAttributeByName(
   string    pszCustomAttributeName,
   ref int[] ppBlob,
   out uint  pdwLen
);

Parâmetros

  • pszCustomAttributeName
    [in] Nome do atributo personalizado.

  • ppBlob
    [in, out] Matriz de bytes que contêm os dados de atributo personalizado.

  • pdwLen
    [out] Comprimento em bytes da ppBlob parâmetro.

Valor de retorno

Se bem-sucedida, retorna S_OK. Se não existir um atributo personalizado, retornará S_FALSE. Caso contrário, retorna um código de erro.

Exemplo

O exemplo a seguir mostra como implementar este método para um CDebugClassFieldSymbol objeto que expõe a IDebugCustomAttributeQuery interface.

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;
}

Consulte também

Referência

IDebugCustomAttributeQuery