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.
|
|
/*++
Copyright (C) 1996-1999 Microsoft Corporation
Module Name:
LOCID.INL
History:
--*/
// In line definitions for the CLocID class. This fgile should ONLY be // included by locid.h //
//----------------------------------------------------------------------------- // // Implementation. Clears the contents of the ID. Both parts are marked // invalid. // //----------------------------------------------------------------------------- inline void CLocId::ClearId(void) { m_fHasNumericId = FALSE; m_fHasStringId = FALSE;
m_ulNumericId = 0; m_pstrStringId.ClearString(); }
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // Constuctor for a localization ID. Sets it to have no valid ID. // //----------------------------------------------------------------------------- inline CLocId::CLocId() { ClearId();
DEBUGONLY(++m_UsageCounter); }
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // Tests if the numeric ID is valid. // //----------------------------------------------------------------------------- inline BOOL // TRUE means the numeric ID is valid CLocId::HasNumericId(void) const { return m_fHasNumericId; }
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // Tests if the string ID is valid. // //----------------------------------------------------------------------------- inline BOOL // TRUE means the string ID is valid CLocId::HasStringId(void) const { return m_fHasStringId; }
inline BOOL CLocId::IsNull(void) const { return !HasStringId() && !HasNumericId(); }
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // Returns the current numeric ID. If the ID is invalid, the ID will be // zero. // //----------------------------------------------------------------------------- inline BOOL // TRUE indicates the ID is valid CLocId::GetId( ULONG &ulNumericId) // Location to put ID const { ulNumericId = m_ulNumericId; return m_fHasNumericId; }
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // Returns the current string ID. If the ID is invalid, it will be a NULL // string. // //----------------------------------------------------------------------------- inline BOOL // TRUE indicates the ID is valid CLocId::GetId( CPascalString &pstrStringId) // Location to put the ID. const { pstrStringId = m_pstrStringId; return m_fHasStringId; }
//----------------------------------------------------------------------------- // // Checks if the ID has been assigned to before. If it has, throw an // exception. // //----------------------------------------------------------------------------- inline void CLocId::CheckPreviousAssignment(void) const { if (m_fHasStringId || m_fHasNumericId) { AfxThrowNotSupportedException(); } }
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // Compares two ID's to see if they are the same. // //----------------------------------------------------------------------------- inline int CLocId::operator==( const CLocId &lidOther) // ID to compare to const { return IsIdenticalTo(lidOther); }
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // // Checks for in-equality between two ID's // //----------------------------------------------------------------------------- inline int CLocId::operator!=( const CLocId &lidOther) const { return !IsIdenticalTo(lidOther); }
|