関連付けられたプロパティの文字列内の文字数を返します。
構文
パラメーター
パラメーター | 説明 |
---|---|
pLen |
[out] プロパティの文字列内の文字数を返します。 |
戻り値
成功した場合は、S_OK
を返します。それ以外の場合は、エラー コードを返します。
解説
通常、このメソッドは、GetStringChars メソッドの呼び出し用のバッファーを割り当てるための prelude として使用されます。
例
次の例は、IDebugProperty3 インターフェイスを公開する CProperty オブジェクトに対してこのメソッドを実装する方法を示しています。
STDMETHODIMP CProperty::GetStringCharLength(ULONG *pLen)
{
HRESULT hr = E_INVALIDARG;
EVALFLAGS oldEVALFLAGS = m_EVALFLAGS;
m_EVALFLAGS &= ~EVAL_NOFUNCEVAL;
if (pLen)
{
DEBUG_PROPERTY_INFO dpInfo;
dpInfo.bstrValue = NULL;
ULONG ulen = 0;
hr = GetPropertyInfo(DEBUGPROP_INFO_VALUE,10,DEFAULT_TIMEOUT,NULL,0,&dpInfo);
if (hr == S_OK && dpInfo.bstrValue)
{
if (wcscmp(dpInfo.bstrValue,L"Nothing") == 0)
{
ulen = 0; //VSWhidbey#64815
}
else
{
ulen = ::SysStringLen(dpInfo.bstrValue);
if( ulen > 2 &&
dpInfo.bstrValue[0] == L'"' &&
dpInfo.bstrValue[ulen-1] == L'"')
{
ulen = ulen > 2 ? ulen - 2 : ulen; //remove two double quotes
}
}
}
::SysFreeString(dpInfo.bstrValue);
*pLen = ulen;
}
m_EVALFLAGS = oldEVALFLAGS;
return hr;
}