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.
 
 
 
 
 
 

180 lines
3.8 KiB

/*++
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);
}