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.
 
 
 
 
 
 

102 lines
1.6 KiB

/*++
Copyright (c) 1997 Microsoft Corporation
hashimp.h
Abstract :
This file contains the inline functions required to implement
the hash tables defined in hashmap.h
--*/
#ifndef _HASHIMP_H_
#define _HASHIMP_H_
inline
IStringKey::IStringKey(
LPBYTE pbKey,
DWORD cbKey ) :
m_lpbKey( pbKey ),
m_cbKey( cbKey ) {
}
inline LPBYTE
IStringKey::Serialize(
LPBYTE pbPtr
) const {
PDATA pData = (PDATA)pbPtr ;
pData->cb = (WORD)m_cbKey ;
CopyMemory( pData->Data, m_lpbKey, m_cbKey ) ;
return pData->Data + m_cbKey ;
}
inline LPBYTE
IStringKey::Restore(
LPBYTE pbPtr,
DWORD &cbOut
) {
PDATA pData = (PDATA)pbPtr ;
if( m_cbKey < pData->cb ) {
cbOut = pData->cb ;
SetLastError( ERROR_INSUFFICIENT_BUFFER ) ;
return 0 ;
}
cbOut = m_cbKey = pData->cb ;
CopyMemory( m_lpbKey, pData->Data, m_cbKey ) ;
return pData->Data + m_cbKey ;
}
inline DWORD
IStringKey::Size() const {
return sizeof( SerializedString ) - sizeof( BYTE ) + m_cbKey ;
}
inline BOOL
IStringKey::Verify(
LPBYTE pbContainer,
LPBYTE pbPtr,
DWORD cb
) const {
PDATA pData = (PDATA)pbPtr ;
if( pData->cb > cb ) {
return FALSE ;
}
return TRUE ;
}
inline DWORD
IStringKey::Hash( ) const {
return CHashMap::CRCHash( m_lpbKey, m_cbKey ) ;
}
inline BOOL
IStringKey::CompareKeys(
LPBYTE pbPtr
) const {
PDATA pData = PDATA( pbPtr ) ;
return pData->cb == m_cbKey && !memcmp( pData->Data, m_lpbKey, m_cbKey ) ;
}
inline LPBYTE
IStringKey::EntryData(
LPBYTE pbPtr,
DWORD &cbOut
) const {
PDATA pData = PDATA( pbPtr ) ;
return pData->Data + pData->cb ;
}
#endif // _HASHIMP_H_