371 lines
9 KiB
C++
371 lines
9 KiB
C++
//+-------------------------------------------------------------------------
|
|
//
|
|
// Microsoft Windows
|
|
// Copyright (C) Microsoft Corporation, 1992 - 1992.
|
|
//
|
|
// File: wcbuffer.hxx
|
|
//
|
|
// Contents: WIDE CHAR buffer definitions
|
|
//
|
|
// History: 02-16-93 SethuR -- Implemented
|
|
// 07-28-94 AlokS -- Added more methods
|
|
|
|
// Notes:
|
|
//
|
|
//--------------------------------------------------------------------------
|
|
|
|
#ifndef __WCBUFFER_HXX__
|
|
#define __WCBUFFER_HXX__
|
|
|
|
//+---------------------------------------------------------------------
|
|
//
|
|
// Class: CWCHARBuffer
|
|
//
|
|
// Purpose: A WCHAR buffer
|
|
//
|
|
// History:
|
|
//
|
|
// Notes: Very often we encounter the case in string manipulation wherein
|
|
// the length of the string is less than some value most of the time
|
|
// (99%). However, in order to reliably with the very rare case we
|
|
// are forced to either allocate the string on the heap or alternatively
|
|
// go through some bizarre code that avoids the heap allocation in the
|
|
// common case. This class is an abstraction of a WCHAR buffer and its
|
|
// implementation is an attempt at hiding the detail from all clients.
|
|
//
|
|
// As it is designed it is an ideal candidate for a temporary buffer
|
|
// for string manipulation.
|
|
//
|
|
//----------------------------------------------------------------------
|
|
|
|
#define MAX_CHAR_BUFFER_SIZE 260 // long enough to cover all path names
|
|
|
|
class CWCHARBuffer
|
|
{
|
|
public:
|
|
|
|
inline CWCHARBuffer(ULONG cwBuffer = 0);
|
|
inline ~CWCHARBuffer();
|
|
|
|
inline DWORD Size();
|
|
inline PWCHAR ReAlloc(DWORD cwBuffer = MAX_CHAR_BUFFER_SIZE);
|
|
inline void Set(PWCHAR pwszFrom);
|
|
inline void Set(PCHAR pszFrom);
|
|
inline void Cat(PWCHAR pwszPlus);
|
|
|
|
inline operator PWCHAR ();
|
|
inline operator PWCHAR () const;
|
|
|
|
inline void operator =(PWCHAR pwszFrom)
|
|
{
|
|
Set(pwszFrom);
|
|
};
|
|
|
|
inline void operator =(PCHAR pszFrom)
|
|
{
|
|
Set(pszFrom);
|
|
};
|
|
|
|
inline void operator +=(PWCHAR pwszPlus)
|
|
{
|
|
Cat(pwszPlus);
|
|
};
|
|
|
|
private:
|
|
|
|
DWORD _cwBuffer;
|
|
PWCHAR _pwchBuffer; // buffer ptr;
|
|
WCHAR _awchBuffer[MAX_CHAR_BUFFER_SIZE];
|
|
};
|
|
|
|
//+---------------------------------------------------------------------------
|
|
//
|
|
// Member: CWCHARBuffer::CWCHARBuffer, inline public
|
|
//
|
|
// Synopsis: Constructor
|
|
//
|
|
// Arguments: [cwBuffer] -- desired buffer length.
|
|
//
|
|
// History: 02-17-93 SethuR Created
|
|
//
|
|
// Notes:
|
|
//
|
|
//----------------------------------------------------------------------------
|
|
|
|
inline CWCHARBuffer::CWCHARBuffer(ULONG cwBuffer) :
|
|
_pwchBuffer(NULL),
|
|
_cwBuffer(cwBuffer)
|
|
{
|
|
IDfsVolInlineDebOut((
|
|
DEB_TRACE, "CWCHARBuffer::+CWCHARBuffer(0x%x)\n",
|
|
this));
|
|
if (_cwBuffer > MAX_CHAR_BUFFER_SIZE)
|
|
{
|
|
_pwchBuffer = new WCHAR[_cwBuffer];
|
|
}
|
|
else if (_cwBuffer > 0)
|
|
{
|
|
_pwchBuffer = _awchBuffer;
|
|
}
|
|
}
|
|
|
|
//+---------------------------------------------------------------------------
|
|
//
|
|
// Member: CWCHARBuffer::~CWCHARBuffer, inline public
|
|
//
|
|
// Synopsis: Destructor
|
|
//
|
|
// History: 02-17-93 SethuR Created
|
|
//
|
|
// Notes:
|
|
//
|
|
//----------------------------------------------------------------------------
|
|
|
|
inline CWCHARBuffer::~CWCHARBuffer()
|
|
{
|
|
IDfsVolInlineDebOut((
|
|
DEB_TRACE, "CWCHARBuffer::~CWCHARBuffer(0x%x)\n",
|
|
this));
|
|
if (_cwBuffer > MAX_CHAR_BUFFER_SIZE &&
|
|
_pwchBuffer != NULL &&
|
|
_pwchBuffer != _awchBuffer)
|
|
{
|
|
delete _pwchBuffer;
|
|
}
|
|
_cwBuffer=0;
|
|
_pwchBuffer = NULL;
|
|
}
|
|
|
|
//+---------------------------------------------------------------------------
|
|
//
|
|
// Member: CWCHARBuffer::Size, inline public
|
|
//
|
|
// Synopsis: Retrieve the size of the buffer
|
|
//
|
|
// Returns: the size of the buffer as a DWORD
|
|
//
|
|
// History: 02-17-93 SethuR Created
|
|
//
|
|
// Notes:
|
|
//
|
|
//----------------------------------------------------------------------------
|
|
|
|
inline DWORD CWCHARBuffer::Size()
|
|
{
|
|
return _cwBuffer;
|
|
}
|
|
|
|
//+---------------------------------------------------------------------------
|
|
//
|
|
// Member: CWCHARBuffer::ReAlloc, inline public
|
|
//
|
|
// Synopsis: Reallocates the buffer to accomdate the newly specified size
|
|
//
|
|
// Arguments: [cwBuffer] -- the desired buffer size
|
|
//
|
|
// Returns: the ptr to the buffer (PWCHAR)
|
|
//
|
|
// History: 02-17-93 SethuR Created
|
|
//
|
|
// Notes:
|
|
//
|
|
//----------------------------------------------------------------------------
|
|
|
|
inline PWCHAR CWCHARBuffer::ReAlloc(DWORD cwBuffer)
|
|
{
|
|
if (_cwBuffer > MAX_CHAR_BUFFER_SIZE &&
|
|
_pwchBuffer != NULL &&
|
|
_pwchBuffer != _awchBuffer)
|
|
{
|
|
delete _pwchBuffer;
|
|
}
|
|
_cwBuffer=0;
|
|
_pwchBuffer = NULL;
|
|
|
|
if ((_cwBuffer = cwBuffer) > MAX_CHAR_BUFFER_SIZE)
|
|
{
|
|
_pwchBuffer = new WCHAR[_cwBuffer];
|
|
}
|
|
else if (_cwBuffer > 0)
|
|
{
|
|
_pwchBuffer = _awchBuffer;
|
|
}
|
|
else if (_cwBuffer == 0)
|
|
{
|
|
_pwchBuffer = NULL;
|
|
}
|
|
|
|
return _pwchBuffer;
|
|
}
|
|
|
|
//+---------------------------------------------------------------------------
|
|
//
|
|
// Member: CWCHARBuffer::operator PWCHAR (), inline public
|
|
//
|
|
// Synopsis: casting operator to accomdate syntactic sugaring
|
|
//
|
|
// Returns: the ptr to the buffer (PWCHAR)
|
|
//
|
|
// History: 02-17-93 SethuR Created
|
|
//
|
|
// Notes:
|
|
//
|
|
//----------------------------------------------------------------------------
|
|
|
|
inline CWCHARBuffer::operator PWCHAR ()
|
|
{
|
|
return (PWCHAR)_pwchBuffer;
|
|
}
|
|
|
|
inline CWCHARBuffer::operator PWCHAR () const
|
|
{
|
|
return (PWCHAR)_pwchBuffer;
|
|
}
|
|
//+---------------------------------------------------------------------------
|
|
//
|
|
// Member: CWCHARBuffer::Set, inline public
|
|
//
|
|
// Synopsis: Copies the string to internal buffer. Reallocates
|
|
// in internal buffer, if necessary
|
|
//
|
|
// Arguments: [pwszFrom] -- Pointer to the string
|
|
//
|
|
// Returns: -none-
|
|
//
|
|
// History: 07-28-94 AlokS Created
|
|
//
|
|
// Notes:
|
|
//
|
|
//----------------------------------------------------------------------------
|
|
|
|
inline VOID CWCHARBuffer::Set(PWCHAR pwszFrom)
|
|
{
|
|
if (pwszFrom==NULL)
|
|
{
|
|
if (_cwBuffer > MAX_CHAR_BUFFER_SIZE &&
|
|
_pwchBuffer != NULL &&
|
|
_pwchBuffer != _awchBuffer)
|
|
{
|
|
delete _pwchBuffer;
|
|
}
|
|
_cwBuffer=0;
|
|
_pwchBuffer = NULL;
|
|
}
|
|
else if (*pwszFrom)
|
|
{
|
|
DWORD len = wcslen(pwszFrom)+1;
|
|
if (len > _cwBuffer)
|
|
{
|
|
(void)ReAlloc (len);
|
|
}
|
|
if (_pwchBuffer != NULL) {
|
|
// Now copy
|
|
memcpy(_pwchBuffer, pwszFrom, sizeof(WCHAR)*len);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (_pwchBuffer != NULL) {
|
|
*_pwchBuffer=L'\0';
|
|
}
|
|
}
|
|
return;
|
|
}
|
|
|
|
//+---------------------------------------------------------------------------
|
|
//
|
|
// Member: CWCHARBuffer::Set, inline public
|
|
//
|
|
// Synopsis: Copies the string to internal buffer. Reallocates
|
|
// in internal buffer, if necessary
|
|
//
|
|
// Arguments: [pszFrom] -- Pointer to the string
|
|
//
|
|
// Returns: -none-
|
|
//
|
|
// History: 07-28-94 AlokS Created
|
|
//
|
|
// Notes:
|
|
//
|
|
//----------------------------------------------------------------------------
|
|
|
|
inline VOID CWCHARBuffer::Set(PCHAR pszFrom)
|
|
{
|
|
if (pszFrom==NULL)
|
|
{
|
|
if (_cwBuffer > MAX_CHAR_BUFFER_SIZE &&
|
|
_pwchBuffer != NULL &&
|
|
_pwchBuffer != _awchBuffer)
|
|
{
|
|
delete _pwchBuffer;
|
|
}
|
|
_cwBuffer=0;
|
|
_pwchBuffer = NULL;
|
|
}
|
|
else if (*pszFrom)
|
|
{
|
|
DWORD len = strlen(pszFrom)+1;
|
|
if ( len > _cwBuffer)
|
|
{
|
|
(void)ReAlloc (len);
|
|
}
|
|
if (_pwchBuffer != NULL) {
|
|
// Now copy
|
|
mbstowcs(_pwchBuffer, pszFrom, len);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (_pwchBuffer != NULL) {
|
|
*_pwchBuffer=L'\0';
|
|
}
|
|
}
|
|
return;
|
|
}
|
|
|
|
//+---------------------------------------------------------------------------
|
|
//
|
|
// Member: CWCHARBuffer::Cat, inline public
|
|
//
|
|
// Synopsis: Concatnates the string to internal buffer. Reallocates
|
|
// in internal buffer, if necessary
|
|
//
|
|
// Arguments: [pwszPlus] -- Pointer to the string
|
|
//
|
|
// Returns: -none-
|
|
//
|
|
// History: 07-28-94 AlokS Created
|
|
//
|
|
// Notes:
|
|
//
|
|
//----------------------------------------------------------------------------
|
|
|
|
inline VOID CWCHARBuffer::Cat(PWCHAR pwszFrom)
|
|
{
|
|
DWORD len1 = wcslen(_pwchBuffer),
|
|
len2 = wcslen(pwszFrom),
|
|
len3 = len1+len2 + 1;
|
|
|
|
if ( len3 > MAX_CHAR_BUFFER_SIZE)
|
|
{
|
|
PWCHAR ptr = new WCHAR [len3];
|
|
|
|
if (ptr != NULL && _pwchBuffer != NULL) {
|
|
memcpy(ptr, _pwchBuffer, len1*sizeof(WCHAR));
|
|
}
|
|
|
|
if (_cwBuffer > MAX_CHAR_BUFFER_SIZE &&
|
|
_pwchBuffer != NULL &&
|
|
_pwchBuffer != _awchBuffer)
|
|
{
|
|
delete _pwchBuffer;
|
|
}
|
|
_cwBuffer = len3;
|
|
_pwchBuffer = ptr;
|
|
}
|
|
if (_pwchBuffer != NULL) {
|
|
memcpy( ((LPWSTR)(_pwchBuffer)+len1), pwszFrom, (len2+1) * sizeof(WCHAR));
|
|
}
|
|
}
|
|
#endif // __WCBUFFER_HXX__
|