/*++ Copyright (c) 1994-1999 Microsoft Corporation Module Name : strfrn.h Abstract: String Functions Author: Ronald Meijer (ronaldm) Project: Internet Services Manager (Cluster Edition) Revision History: --*/ #ifndef _STRFN_H #define _STRFN_H // // 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])) // // Size in bits // #define SIZE_IN_BITS(u) (sizeof(u) * 8) #define AllocTString(cch)\ (LPTSTR)AllocMem((cch) * sizeof(TCHAR)) #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) CString COMDLL AppendToDevicePath(CString szPath, LPCTSTR szName ); // // Convert CR/LF to LF // BOOL COMDLL PCToUnixText( OUT LPWSTR & lpstrDestination, IN const CString strSource ); // // Expand LF to CR/LF (no allocation necessary) // BOOL COMDLL UnixToPCText( OUT CString & strDestination, IN LPCWSTR lpstrSource ); /* // // Straight copy // BOOL COMDLL TextToText( OUT LPWSTR & lpstrDestination, IN const CString & strSource ); */ LPSTR COMDLL AllocAnsiString( IN LPCTSTR lpString ); LPTSTR COMDLL AllocString( IN LPCTSTR lpString, IN int nLen = -1 // -1 to autodetermine ); /* #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 COMDLL IsUNCName( IN const CString & strDirPath ); // // Determine if the path is e.g. an IFS path // BOOL COMDLL IsDevicePath( IN const CString & strDirPath ); // // Determine if the path is a "special" path // BOOL COMDLL IsSpecialPath( IN const CString & strDirPath, IN BOOL bCheckIfValid, IN BOOL bDevicePath ); BOOL COMDLL GetSpecialPathRealPath( IN INT iUsageFlag, IN const CString & strDirPath, OUT CString & strDestination ); BOOL COMDLL IsRestrictedFilename( IN const CString & strDirPath ); // // Determine if the path is a fully qualified path in the context // of the local machine // BOOL COMDLL IsFullyQualifiedPath( IN const CString & strDirPath ); // // Determine if the path exists on a network directory in the context // of the local machine // BOOL COMDLL IsNetworkPath( IN const CString & strDirPath, OUT CString * pstrDrive = NULL, OUT CString * pstrUNC = NULL ); // // Determine if the given string is an URL path // BOOL COMDLL IsURLName( IN const CString & strDirPath ); // // Determine if the given string describes a relative URL path // inline BOOL IsRelURLPath( IN LPCTSTR lpPath ) { ASSERT_READ_PTR(lpPath); return *lpPath == _T('/'); } // // Determine if the given path describes a wild-carded redirection // path (starts with *;) // inline BOOL IsWildcardedRedirectPath( IN LPCTSTR lpPath ) { ASSERT_READ_PTR(lpPath); return lpPath[0] == '*' && lpPath[1] == ';'; } // // Determine if the account is local (doesn't have a computer name) // inline BOOL IsLocalAccount( IN CString & strAccount ) { return strAccount.Find(_T('\\')) == -1; } // // Convert local path to UNC path // LPCTSTR COMDLL MakeUNCPath( IN OUT CString & strDir, IN LPCTSTR lpszOwner, IN LPCTSTR lpszDirectory ); // // Convert GUID to a CString // LPCTSTR COMDLL GUIDToCString( IN REFGUID guid, OUT CString & str ); // // Convert double-null terminated string to a CStringList // DWORD COMDLL ConvertDoubleNullListToStringList( IN LPCTSTR lpstrSrc, OUT CStringList & strlDest, IN int cChars = -1 ); // // Go from a CStringList to a double null terminated list // DWORD COMDLL ConvertStringListToDoubleNullList( IN CStringList & strlSrc, OUT DWORD & cchDest, OUT LPTSTR & lpstrDest ); // // Convert separated list of strings to CStringList // int COMDLL ConvertSepLineToStringList( IN LPCTSTR lpstrIn, OUT CStringList & strlOut, IN LPCTSTR lpstrSep ); // // Reverse function of the above // LPCTSTR COMDLL ConvertStringListToSepLine( IN CStringList & strlIn, OUT CString & strOut, IN LPCTSTR lpstrSep ); // // Advanced atol which recognises hex strings // BOOL COMDLL CvtStringToLong( IN LPCTSTR lpNumber, OUT DWORD * pdwValue ); // // GMT string to time_t // BOOL COMDLL CvtGMTStringToInternal( IN LPCTSTR lpTime, OUT time_t * ptValue ); // // time_t to GMT string // void COMDLL CvtInternalToGMTString( IN time_t tm, OUT CString & str ); // // CString.Find() that's not case-sensitive // int COMDLL CStringFindNoCase( IN const CString & strSrc, IN LPCTSTR lpszSub ); // // Replace the first occurrance of one string // inside another one. Return error code // DWORD COMDLL ReplaceStringInString( OUT IN CString & strBuffer, IN CString & strTarget, IN CString & strReplacement, IN BOOL fCaseSensitive ); // // Replace a path in strTarget with the // environment variable lpszEnvVar if that // strTarget path is a superset of the path // pointed to by lpszEnvVar // DWORD COMDLL DeflateEnvironmentVariablePath( IN LPCTSTR lpszEnvVar, IN OUT CString & strTarget ); class COMDLL 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); }; class COMDLL 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 * _pstrBadNumber; static BOOL UseSystemDefault(); static BOOL UseUserDefault(); static BOOL IsInitialized(); static LPCTSTR QueryThousandSeparator(); 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 * _pstr; private: static CString * _pstrThousandSeparator; static CString * _pstrDecimalPoint; static CString * _pstrCurrency; static BOOL _fCurrencyPrefix; static BOOL _fInitialized; static BOOL _fAllocated; }; class COMDLL 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); } #if defined(_DEBUG) || DBG // // CDumpContext stream operator // inline friend CDumpContext & AFXAPI operator<<( CDumpContext & dc, const CILong & value ) { return (dc << value.m_lValue); } #endif // _DEBUG protected: LONG m_lValue; }; // // Inline Expansion // // <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< inline /* static */ BOOL CINumber::UseSystemDefault() { return Initialize(FALSE); } inline /* static */ BOOL CINumber::UseUserDefault() { return Initialize(TRUE); } inline /* static */ BOOL CINumber::IsInitialized() { return _fInitialized; } inline /* static */ LPCTSTR CINumber::QueryThousandSeparator() { return (LPCTSTR)*_pstrThousandSeparator; } inline /* static */ LPCTSTR CINumber::QueryDecimalPoint() { return (LPCTSTR)*_pstrDecimalPoint; } inline /* static */ LPCTSTR CINumber::QueryCurrency() { return (LPCTSTR)*_pstrCurrency; } inline /* static */ BOOL CINumber::IsAllocated() { return _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::_pstr); } #endif // _STRFN_H