Source code of Windows XP (NT5)
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.
 
 
 
 
 
 

710 lines
13 KiB

/*++
Copyright (c) 1994-1998 Microsoft Corporation
Module Name :
strfrn.h
Abstract:
String Functions
Author:
Ronald Meijer (ronaldm)
Munged for setup by BoydM
Project:
Internet Services Manager
Revision History:
--*/
#ifndef _STRFN_H
#define _STRFN_H
//
// Memory Allocation Macros
//
#define AllocMem(cbSize)\
::LocalAlloc(LPTR, cbSize)
#define FreeMem(lp)\
::LocalFree(lp)
#define AllocMemByType(citems, type)\
(type *)AllocMem(citems * sizeof(type))
//
// Debug Formatting Macros
//
#define TRACEOUT(x) { ; }
#define TRACEEOL(x) { ; }
#define TRACEEOLID(x) { ; }
#define TRACEEOLERR(err,x) { ; }
//
// Helper Macros
//
//
// Get number of array elements
//
#define ARRAY_SIZE(a) (sizeof(a)/sizeof(a[0]))
//
// Compute size of string array in characters. That is, don't count
// the terminal null.
//
#define STRSIZE(str) (ARRAY_SIZE(str)-1)
//
// Get byte count of array
//
#define ARRAY_BYTES(a) (sizeof(a) * sizeof(a[0]))
//
// Get byte count of character elements of a string -- again
// by not including the terminating NULL.
//
#define STRBYTES(str) (ARRAY_BYTES(str) - sizeof(str[0]))
#define AllocTString(cch)\
(LPTSTR)AllocMem((cch) * sizeof(TCHAR))
#define AllocWString(cch)\
(LPWSTR)AllocMem((cch) * sizeof(WCHAR))
#define IS_NETBIOS_NAME(lpstr) (*lpstr == _T('\\'))
//
// Return the portion of a computer name without the backslashes
//
#define PURE_COMPUTER_NAME(lpstr) (IS_NETBIOS_NAME(lpstr) ? lpstr + 2 : lpstr)
//
// Convert CR/LF to LF
//
BOOL
PCToUnixText(
OUT LPWSTR & lpstrDestination,
IN const CString strSource
);
//
// Expand LF to CR/LF (no allocation necessary)
//
BOOL
UnixToPCText(
OUT CString & strDestination,
IN LPCWSTR lpstrSource
);
//
// Straight copy
//
BOOL
TextToText(
OUT LPWSTR & lpstrDestination,
IN const CString & strSource
);
LPWSTR
AllocWideString(
IN LPCTSTR lpString
);
LPSTR AllocAnsiString(
IN LPCTSTR lpString
);
LPTSTR AllocString(
IN LPCTSTR lpString
);
#ifdef UNICODE
//
// Copy W string to T string
//
#define WTSTRCPY(dst, src, cch) \
lstrcpy(dst, src)
//
// Copy T string to W string
//
#define TWSTRCPY(dst, src, cch) \
lstrcpy(dst, src)
//
// Reference a T String as a W String (a nop in Unicode)
//
#define TWSTRREF(str) ((LPWSTR)str)
#else
//
// Convert a T String to a temporary W Buffer, and
// return a pointer to this internal buffer
//
LPWSTR ReferenceAsWideString(LPCTSTR str);
//
// Copy W string to T string
//
#define WTSTRCPY(dst, src, cch) \
WideCharToMultiByte(CP_ACP, 0, src, -1, dst, cch, NULL, NULL)
//
// Copy T string to W string
//
#define TWSTRCPY(dst, src, cch) \
MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, src, -1, dst, cch)
//
// Reference a T String as a W String
//
#define TWSTRREF(str) ReferenceAsWideString(str)
#endif // UNICODE
//
// Determine if the given string is a UNC name
//
BOOL IsUNCName(
IN const CString & strDirPath
);
//
// Determine if the path is a fully qualified path in the context
// of the local machine
//
BOOL IsFullyQualifiedPath(
IN const CString & strDirPath
);
//
// Determine if the given string is an URL path
//
BOOL IsURLName(
IN const CString & strDirPath
);
//
// Determine if the given string describes a relative URL path
//
inline BOOL IsRelURLPath(
IN LPCTSTR lpPath
)
{
ASSERT(lpPath != NULL);
return *lpPath == _T('/');
}
//
// Determine if the given path describes a wild-carded redirection
// path (starts with *;)
//
inline BOOL IsWildcardedRedirectPath(
IN LPCTSTR lpPath
)
{
ASSERT(lpPath != NULL);
return lpPath[0] == '*' && lpPath[1] == ';';
}
//
// Determine if the account is local (doesn't have a computer name)
//
inline BOOL MyIsLocalAccount(
IN CString & strAccount
)
{
return strAccount.Find(_T('\\')) == -1;
}
//
// Convert local path to UNC path
//
LPCTSTR MakeUNCPath(
IN OUT CString & strDir,
IN LPCTSTR lpszOwner,
IN LPCTSTR lpszDirectory
);
//
// Given domain\username, split into user name and domain
//
BOOL SplitUserNameAndDomain(
IN OUT CString & strUserName,
IN CString & strDomainName
);
//
// Convert double-null terminated string to a CStringList
//
DWORD
ConvertDoubleNullListToStringList(
IN LPCTSTR lpstrSrc,
OUT CStringList & strlDest,
IN int cChars = -1
);
DWORD
ConvertWDoubleNullListToStringList(
IN PWCHAR lpstrSrc,
OUT CStringList & strlDest,
IN int cChars = -1
);
//
// Go from a CStringList to a WIDE double null terminated list
//
DWORD
ConvertStringListToWDoubleNullList(
IN CStringList & strlSrc,
OUT DWORD & cchDest,
OUT PWCHAR & lpstrDest
);
//
// Go from a CStringList to a double null terminated list
//
DWORD
ConvertStringListToDoubleNullList(
IN CStringList & strlSrc,
OUT DWORD & cchDest,
OUT LPTSTR & lpstrDest
);
//
// Convert separated list of strings to CStringList
//
int
ConvertSepLineToStringList(
IN LPCTSTR lpstrIn,
OUT CStringList & strlOut,
IN LPCTSTR lpstrSep
);
//
// Reverse function of the above
//
LPCTSTR
ConvertStringListToSepLine(
IN CStringList & strlIn,
OUT CString & strOut,
IN LPCTSTR lpstrSep
);
//
// Private strtok
//
LPTSTR
StringTok(
IN LPTSTR string,
IN LPCTSTR control
);
//
// CString.Find() that's not case-sensitive
//
int
CStringFindNoCase(
IN const CString & strSrc,
IN LPCTSTR lpszSub
);
//
// Replace the first occurrance of one string
// inside another one. Return error code
//
DWORD
ReplaceStringInString(
OUT IN CString & strBuffer,
IN CString & strTarget,
IN CString & strReplacement,
IN BOOL fCaseSensitive
);
class CStringListEx : public CStringList
/*++
Class Description:
Superclass of CStringList with comparison and assignment
operators.
Public Interface:
operator == Comparison operator
operator != Comparison operator
operator = Assignment operator
--*/
{
//
// ctor
//
public:
CStringListEx(int nBlockSize = 10) : CStringList(nBlockSize) {};
//
// Operators
//
public:
BOOL operator == (const CStringList & strl);
BOOL operator != (const CStringList & strl) { return !operator ==(strl); }
CStringListEx & operator =(const CStringList & strl);
};
#ifdef _DOS
typedef struct tagINTLFORMAT
{
WORD wDateFormat;
CHAR szCurrencySymbol[5];
CHAR szThousandSep[2];
CHAR szDecimalPoint[2];
CHAR szDateSep[2];
CHAR szTimeSep[2];
BYTE bCurrencyFormat;
BYTE bCurrencyDecimals;
BYTE bTimeFormat;
DWORD dwMapCall;
CHAR szDataSep[2];
BYTE bReserved[5];
} INTLFORMAT;
BOOL _dos_getintlsettings(INTLFORMAT * pStruct);
#endif // _DOS
class CINumber
/*++
Class Description:
Base class for international-friendly number formatting
Public Interface:
NOTES: Consider making this class a template
--*/
{
public:
static BOOL Initialize(BOOL fUserSetting = TRUE);
static CString * s_pstrBadNumber;
static BOOL UseSystemDefault();
static BOOL UseUserDefault();
static BOOL IsInitialized();
static LPCTSTR QueryThousandSeperator();
static LPCTSTR QueryDecimalPoint();
static LPCTSTR QueryCurrency();
static double BuildFloat(const LONG lInteger, const LONG lFraction);
static LPCTSTR ConvertLongToString(const LONG lSrc, CString & str);
static LPCTSTR ConvertFloatToString(
IN const double flSrc,
IN int nPrecision,
OUT CString & str
);
static BOOL ConvertStringToLong(LPCTSTR lpsrc, LONG & lValue);
static BOOL ConvertStringToFloat(LPCTSTR lpsrc, double & flValue);
protected:
CINumber();
~CINumber();
protected:
friend BOOL InitIntlSettings();
friend void TerminateIntlSettings();
static BOOL Allocate();
static void DeAllocate();
static BOOL IsAllocated();
protected:
static CString * s_pstr;
private:
static CString * s_pstrThousandSeperator;
static CString * s_pstrDecimalPoint;
static CString * s_pstrCurrency;
static BOOL s_fCurrencyPrefix;
static BOOL s_fInitialized;
static BOOL s_fAllocated;
};
class CILong : public CINumber
/*++
Class Description:
International-friendly LONG number
Public Interface:
--*/
{
public:
//
// Constructors
//
CILong();
CILong(LONG lValue);
CILong(LPCTSTR lpszValue);
public:
//
// Assignment Operators
//
CILong & operator =(LONG lValue);
CILong & operator =(LPCTSTR lpszValue);
//
// Shorthand Operators
//
CILong & operator +=(const LONG lValue);
CILong & operator +=(const LPCTSTR lpszValue);
CILong & operator +=(const CILong& value);
CILong & operator -=(const LONG lValue);
CILong & operator -=(const LPCTSTR lpszValue);
CILong & operator -=(const CILong& value);
CILong & operator *=(const LONG lValue);
CILong & operator *=(const LPCTSTR lpszValue);
CILong & operator *=(const CILong& value);
CILong & operator /=(const LONG lValue);
CILong & operator /=(const LPCTSTR lpszValue);
CILong & operator /=(const CILong& value);
//
// Comparison operators
//
BOOL operator ==(LONG value);
BOOL operator !=(CILong& value);
//
// Conversion operators
//
operator const LONG() const;
operator LPCTSTR() const;
inline friend CArchive & AFXAPI operator<<(CArchive & ar, CILong & value)
{
return (ar << value.m_lValue);
}
inline friend CArchive & AFXAPI operator>>(CArchive & ar, CILong & value)
{
return (ar >> value.m_lValue);
}
#ifdef _DEBUG
//
// CDumpContext stream operator
//
inline friend CDumpContext & AFXAPI operator<<(
CDumpContext& dc,
const CILong& value
)
{
return (dc << value.m_lValue);
}
#endif // _DEBUG
protected:
LONG m_lValue;
};
class CIFloat : public CINumber
/*++
Class Description:
International-friendly floating point number
Public Interface:
--*/
{
public:
//
// Constructors
//
CIFloat(int nPrecision = 2);
CIFloat(double flValue, int nPrecision = 2);
CIFloat(LONG lInteger, LONG lFraction, int nPrecision = 2);
CIFloat(LPCTSTR lpszValue, int nPrecision = 2);
public:
//
// Precision functions
//
int QueryPrecision() const;
void SetPrecision(int nPrecision);
//
// Assignment Operators
//
CIFloat & operator =(double flValue);
CIFloat & operator =(LPCTSTR lpszValue);
//
// Shorthand Operators
//
CIFloat & operator +=(const double flValue);
CIFloat & operator +=(const LPCTSTR lpszValue);
CIFloat & operator +=(const CIFloat& value);
CIFloat & operator -=(const double flValue);
CIFloat & operator -=(const LPCTSTR lpszValue);
CIFloat & operator -=(const CIFloat& value);
CIFloat & operator *=(const double flValue);
CIFloat & operator *=(const LPCTSTR lpszValue);
CIFloat & operator *=(const CIFloat& value);
CIFloat & operator /=(const double flValue);
CIFloat & operator /=(const LPCTSTR lpszValue);
CIFloat & operator /=(const CIFloat& value);
//
// Conversion operators
//
operator const double() const;
operator LPCTSTR() const;
//
// Persistence Operators
//
inline friend CArchive& AFXAPI operator<<(CArchive& ar, CIFloat& value)
{
return (ar << value.m_flValue);
}
inline friend CArchive& AFXAPI operator>>(CArchive& ar, CIFloat& value)
{
return (ar >> value.m_flValue);
}
#ifdef _DEBUG
//
// CDumpContext stream operator
//
inline friend CDumpContext& AFXAPI operator<<(
CDumpContext& dc,
const CIFloat& value
)
{
return (dc << value.m_flValue);
}
#endif // _DEBUG
protected:
double m_flValue;
int m_nPrecision;
};
//
// Inline Expansion
//
// <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
inline /* static */ BOOL CINumber::UseSystemDefault()
{
return Initialize(FALSE);
}
inline /* static */ BOOL CINumber::UseUserDefault()
{
return Initialize(TRUE);
}
inline /* static */ BOOL CINumber::IsInitialized()
{
return s_fInitialized;
}
inline /* static */ LPCTSTR CINumber::QueryThousandSeperator()
{
return (LPCTSTR)*s_pstrThousandSeperator;
}
inline /* static */ LPCTSTR CINumber::QueryDecimalPoint()
{
return (LPCTSTR)*s_pstrDecimalPoint;
}
inline /* static */ LPCTSTR CINumber::QueryCurrency()
{
return (LPCTSTR)*s_pstrCurrency;
}
inline /* static */ BOOL CINumber::IsAllocated()
{
return s_fAllocated;
}
inline BOOL CILong::operator ==(LONG value)
{
return m_lValue == value;
}
inline BOOL CILong::operator !=(CILong& value)
{
return m_lValue != value.m_lValue;
}
inline CILong::operator const LONG() const
{
return m_lValue;
}
inline CILong::operator LPCTSTR() const
{
return CINumber::ConvertLongToString(m_lValue, *CINumber::s_pstr);
}
inline int CIFloat::QueryPrecision() const
{
return m_nPrecision;
}
inline void CIFloat::SetPrecision(int nPrecision)
{
m_nPrecision = nPrecision;
}
inline CIFloat::operator const double() const
{
return m_flValue;
}
inline CIFloat::operator LPCTSTR() const
{
return CINumber::ConvertFloatToString(
m_flValue,
m_nPrecision,
*CINumber::s_pstr
);
}
#endif // _STRFN_H