다음을 통해 공유


IDebugCustomAttributeQuery::GetCustomAttributeByName

이름이 지정된 사용자 지정 특성을 검색합니다.

구문

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

매개 변수

pszCustomAttributeName
[in] 사용자 지정 특성의 이름입니다.

ppBlob
[in,out] 사용자 지정 특성 데이터를 포함하는 바이트 배열입니다.

pdwLen
[out] ppBlob 매개 변수의 길이(바이트)입니다.

Return Value

성공하면 S_OK를 반환합니다. 사용자 지정 특성이 없으면 S_FALSE를 반환합니다. 그렇지 않으면 오류 코드를 반환합니다.

예시

다음 예제에서는 IDebugCustomAttributeQuery 인터페이스를 노출하는 CDebugClassFieldSymbol 개체에 대해 이 메서드를 구현하는 방법을 보여 줍니다.

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

참고 항목