Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

232 lines
5.5 KiB

/*++
© 1998 Seagate Software, Inc. All rights reserved.
Module Name:
wsbpstrg.h
Abstract:
This component is C++ object representations a smart string pointer. It
is similar to the CComPtr, in that it takes care of allocating and
freeing the memory needed to represent the string automatically. This
simplifies cleanup of functions in error handling cases and it limits
the need for FinalConstruct() and FinalRelease() calls in objects that
derive from CComObjectRoot.
Author:
Chuck Bardeen [cbardeen] 11-Dec-1996
Revision History:
--*/
#ifndef _WSBPSTRG_
#define _WSBPSTRG_
/*++
Class Name:
CWsbStringPtr
Class Description:
This component is C++ object representations a smart string pointer. It
is similar to the CComPtr, in that it takes care of allocating and
freeing the memory needed to represent the string automatically. This
simplifies cleanup of functions in error handling cases and it limits
the need for FinalConstruct() and FinalRelease() calls in objects that
derive from CComObjectRoot.
--*/
class WSB_EXPORT CWsbStringPtr
{
// Constructors
public:
CWsbStringPtr();
CWsbStringPtr(const CHAR* pChar);
CWsbStringPtr(const WCHAR* pWchar);
CWsbStringPtr(const CWsbStringPtr& pString);
CWsbStringPtr(REFGUID rguid);
// Destructor
public:
~CWsbStringPtr();
// Operator Overloading
public:
operator WCHAR*();
WCHAR& operator *();
WCHAR** operator &();
WCHAR& operator [](const int i);
CWsbStringPtr& operator =(const CHAR* pChar);
CWsbStringPtr& operator =(const WCHAR* pWchar);
CWsbStringPtr& operator =(REFGUID rguid);
CWsbStringPtr& operator =(const CWsbStringPtr& pString);
BOOL operator !();
#if 0
BOOL operator==(LPCWSTR s2);
BOOL operator!=(LPCWSTR s2);
BOOL operator==(const CWsbStringPtr& s2);
BOOL operator!=(const CWsbStringPtr& s2);
#else
int Compare( LPCWSTR s2 );
int CompareIgnoreCase( LPCWSTR s2 );
BOOL IsEqual( LPCWSTR s2 );
BOOL IsNotEqual( LPCWSTR s2 );
#endif
// Memory Allocation
public:
HRESULT Alloc(ULONG size);
HRESULT Free(void);
HRESULT GetSize(ULONG* size); // Size of allocated buffer
HRESULT Realloc(ULONG size);
// String Manipulation
public:
HRESULT Append(const CHAR* pChar);
HRESULT Append(const WCHAR* pWchar);
HRESULT Append(const CWsbStringPtr& pString);
HRESULT CopyTo(CHAR** pChar);
HRESULT CopyTo(WCHAR** pWchar);
HRESULT CopyTo(GUID * pguid);
HRESULT CopyToBstr(BSTR* pBstr);
HRESULT CopyTo(CHAR** pChar, ULONG bufferSize);
HRESULT CopyTo(WCHAR** pWchar,ULONG bufferSize);
HRESULT CopyToBstr(BSTR* pBstr,ULONG bufferSize);
HRESULT FindInRsc(ULONG startId, ULONG idsToCheck, ULONG* pMatchId);
HRESULT GetLen(ULONG* size); // Length, in chars, of string
HRESULT GiveTo(WCHAR** ppWchar);
HRESULT LoadFromRsc(HINSTANCE instance, ULONG id);
HRESULT Prepend(const CHAR* pChar);
HRESULT Prepend(const WCHAR* pWchar);
HRESULT Prepend(const CWsbStringPtr& pString);
HRESULT Printf(const WCHAR* fmtString, ...);
HRESULT TakeFrom(WCHAR* pWchar, ULONG bufferSize);
HRESULT VPrintf(const WCHAR* fmtString, va_list vaList);
// Member Data
protected:
WCHAR* m_pString;
ULONG m_givenSize;
static CComPtr<IMalloc> m_pMalloc;
};
inline
HRESULT CWsbStringPtr::GetLen(ULONG* size)
{
HRESULT hr = S_OK;
if (0 == size) {
hr = E_POINTER;
} else if (0 == m_pString) {
*size = 0;
} else {
*size = wcslen(m_pString);
}
return(hr);
}
inline
HRESULT CWsbStringPtr::Printf(const WCHAR* fmtString, ...)
{
HRESULT hr;
va_list vaList;
va_start(vaList, fmtString);
hr = VPrintf(fmtString, vaList);
va_end(vaList);
return(hr);
}
#if 0
// Compare Operators (allow to be compared when on the right)
BOOL operator==(LPCWSTR s1, const CWsbStringPtr& s2);
BOOL operator!=(LPCWSTR s1, const CWsbStringPtr& s2);
inline
BOOL CWsbStringPtr::operator==(LPCWSTR s2)
{
return( wcscmp( m_pString, s2 ) == 0 );
}
inline
BOOL CWsbStringPtr::operator!=(LPCWSTR s2)
{
return( wcscmp( m_pString, s2 ) != 0 );
}
inline
BOOL CWsbStringPtr::operator==(const CWsbStringPtr& s2)
{
return( wcscmp( m_pString, s2.m_pString ) == 0 );
}
inline
BOOL CWsbStringPtr::operator!=(const CWsbStringPtr& s2)
{
return( wcscmp( m_pString, s2.m_pString ) != 0 );
}
inline
BOOL operator==(LPCWSTR s1, const CWsbStringPtr& s2)
{
return( wcscmp( s1, (CWsbStringPtr)s2 ) == 0 );
}
inline
BOOL operator!=(LPCWSTR s1, const CWsbStringPtr& s2)
{
return( wcscmp( s1, (CWsbStringPtr)s2 ) != 0 );
}
#else
inline
int CWsbStringPtr::Compare( LPCWSTR s2 )
{
if( m_pString && s2 ) return( wcscmp( m_pString, s2 ) );
if( !m_pString && s2 ) return( -1 );
if( m_pString && !s2 ) return( 1 );
return( 0 );
}
inline
int CWsbStringPtr::CompareIgnoreCase( LPCWSTR s2 )
{
if( m_pString && s2 ) return( _wcsicmp( m_pString, s2 ) );
if( !m_pString && s2 ) return( -1 );
if( m_pString && !s2 ) return( 1 );
return( 0 );
}
inline
BOOL CWsbStringPtr::IsEqual( LPCWSTR s2 )
{
return( Compare( s2 ) == 0 );
}
inline
BOOL CWsbStringPtr::IsNotEqual( LPCWSTR s2 )
{
return( Compare( s2 ) != 0 );
}
#endif
#endif // _WSBPSTRG