Gray C++ Libraries  0.0.2
A set of C++ libraries for MSVC, GNU on Windows, WinCE, Linux
Gray::cArraySortFacadeHash< TYPE, TYPE_PTR, _TYPE_HASH > Class Template Reference

#include <cArraySort.h>

Inheritance diagram for Gray::cArraySortFacadeHash< TYPE, TYPE_PTR, _TYPE_HASH >:
Gray::cArraySortFacade< TYPE, TYPE_PTR, HASHCODE_t > Gray::cArraySorted< TYPE, TYPE_ARG, TYPE_KEY > Gray::cArrayTyped< TYPE, TYPE_ARG > Gray::CArray< TYPE, ARG_TYPE > Gray::CObject Gray::cArraySortPtrHash< const GrayLib::cKeyTypeDef, SSL_Key_TYPE > Gray::cArraySortPtrHash< const GrayLib::cHashTypeDef, SSL_Hash_TYPE > Gray::cArraySortPtrHash< const GrayLib::cScriptableProp, ATOMCODE_t > Gray::cArraySortPtrHash< const GrayLib::cCipherAlgDef, CipherAlgorithm_TYPE >

Public Types

typedef cArraySortFacade< TYPE, TYPE_PTR, _TYPE_HASH > SUPER_t
 
typedef SUPER_t::REF_t REF_t
 
typedef SUPER_t::KEY_t KEY_t
 
- Public Types inherited from Gray::cArraySortFacade< TYPE, TYPE_PTR, HASHCODE_t >
typedef cArraySorted< TYPE, TYPE_PTR, HASHCODE_tSUPER_t
 
typedef SUPER_t::REF_t REF_t
 
typedef SUPER_t::ELEM_t ELEM_t
 
- Public Types inherited from Gray::cArraySorted< TYPE, TYPE_ARG, TYPE_KEY >
typedef cArrayTyped< TYPE, TYPE_ARG > SUPER_t
 
typedef TYPE_KEY KEY_t
 
typedef SUPER_t::REF_t REF_t
 
- Public Types inherited from Gray::cArrayTyped< TYPE, TYPE_ARG >
typedef CArray< TYPE, TYPE_ARG > SUPER_t
 
typedef cArrayTyped< TYPE, TYPE_ARG > THIS_t
 
typedef ITERATE_t iterator
 
typedef ITERATE_t const_iterator
 
typedef TYPE ELEM_t
 What type is stored. More...
 
typedef TYPE_ARG REF_t
 How to refer to this? value or ref or pointer? More...
 

Public Member Functions

virtual ~cArraySortFacadeHash ()
 
virtual COMPARE_t CompareData (REF_t pData1, REF_t pData2) const noexcept override
 
virtual COMPARE_t CompareKey (KEY_t key1, REF_t pData2) const override
 
- Public Member Functions inherited from Gray::cArraySortFacade< TYPE, TYPE_PTR, HASHCODE_t >
virtual ~cArraySortFacade ()
 
bool IsValidIndex (ITERATE_t i) const noexcept
 
REF_t GetAt (ITERATE_t index) const noexcept
 
REF_t GetAtCheck (ITERATE_t nIndex) const
 
TYPE_PTR FindArgForKey (HASHCODE_t key1) const noexcept
 
ITERATE_t FindIForAC_BRUTEFORCE (const TYPE_PTR pData) const
 
ELEM_t PopHead ()
 
ELEM_t PopTail ()
 
void DeleteAll ()
 
- Public Member Functions inherited from Gray::cArraySorted< TYPE, TYPE_ARG, TYPE_KEY >
virtual ~cArraySorted ()
 
ITERATE_t FindINear (REF_t pNew, COMPARE_t &iCompareRes) const
 
ITERATE_t FindINearKey (KEY_t key, COMPARE_t &iCompareRes) const
 
ITERATE_t FindIForKey (KEY_t key) const
 
ITERATE_t FindIFirstForKey (TYPE_KEY nKey) const
 
ITERATE_t FindILastForKey (TYPE_KEY nKey) const
 
ITERATE_t AddPresorted (ITERATE_t index, COMPARE_t iCompareRes, TYPE_ARG pNew)
 
bool RemoveKey (TYPE_KEY key)
 
ITERATE_t Add (TYPE_ARG pNew)
 
void AddArray (const SUPER_t &a)
 
- Public Member Functions inherited from Gray::cArrayTyped< TYPE, TYPE_ARG >
void QSort ()
 
 cArrayTyped () noexcept
 
 cArrayTyped (const THIS_t &rArray)
 
 cArrayTyped (ITERATE_t iSize)
 
virtual ~cArrayTyped ()
 
bool isValidCheck () const noexcept
 < memory allocation and structure definitions are valid. More...
 
bool IsValidIndex (ITERATE_t i) const noexcept
 
ITERATE_t ClampValidIndex (ITERATE_t i) const noexcept
 
size_t GetHeapStats (OUT ITERATE_t &iAllocCount) const noexcept
 
void AssertValidIndex (ITERATE_t nIndex) const
 
const TYPEGetAtSecure (ITERATE_t nIndex) const
 
TYPEElementAtSecure (ITERATE_t nIndex)
 
REF_t ConstElementAt (ITERATE_t nIndex) const
 
TYPEoperator[] (ITERATE_t nIndex)
 
const TYPEoperator[] (ITERATE_t nIndex) const
 
TYPEHead ()
 
TYPETail ()
 
TYPEElementAtHead ()
 
TYPEElementAtTail ()
 
REF_t ConstHead () const
 
REF_t ConstTail () const
 
REF_t GetAtTail ()
 
void UnLinkIndex (ITERATE_t nIndex)
 
void Swap (ITERATE_t i, ITERATE_t j)
 
void SetCopy (const cArrayTyped< TYPE, TYPE_ARG > &aValues)
 
const cArrayTyped< TYPE, TYPE_ARG > & operator= (const cArrayTyped< TYPE, TYPE_ARG > &aValues)
 
ITERATE_t FindIFor (TYPE_ARG arg) const
 
bool HasArg (TYPE_ARG arg) const
 
void RemoveLast ()
 
ELEM_t PopHead ()
 
ELEM_t PopTail ()
 
bool RemoveArg (TYPE_ARG arg)
 
void UnLinkArg (TYPE_ARG arg)
 
ITERATE_t AddTail (TYPE_ARG newElement)
 
ITERATE_t PushTail (TYPE_ARG newElement)
 
void AddHead (TYPE_ARG newElement)
 
TYPEget_DataWork () const
 
void AddArray (const SUPER_t &src)
 
bool IsEqualArray (const SUPER_t &aValues) const
 
bool isArraySorted () const
 
bool isArraySortedND () const
 
- Public Member Functions inherited from Gray::CArray< TYPE, ARG_TYPE >
 CArray () noexcept
 
 CArray (THIS_t &&ref) noexcept
 
virtual ~CArray ()
 
bool IsValidMallocSize () const noexcept
 
ITERATE_t GetSize () const noexcept
 
ITERATE_t GetUpperBound () const noexcept
 
bool IsEmpty () const noexcept
 
void SetSize (ITERATE_t nNewSize)
 
ITERATE_t GetMallocSize () const noexcept
 
void RemoveAll ()
 Clean up. More...
 
const TYPEGetAt (ITERATE_t nIndex) const
 
TYPEElementAt (ITERATE_t nIndex)
 
void SetAt (ITERATE_t nIndex, ARG_TYPE newElement)
 
const TYPEGetData () const
 
TYPEGetData ()
 
void SetDataArrayPtr (TYPE *pData, ITERATE_t nSize)
 
void SetAtGrow (ITERATE_t nIndex, ARG_TYPE newElement)
 
ITERATE_t Add (ARG_TYPE newElement)
 
void Copy (const CArray &src)
 
TYPEoperator[] (ITERATE_t nIndex)
 
const TYPEoperator[] (ITERATE_t nIndex) const
 
void InsertAt (ITERATE_t nIndex, ARG_TYPE newElement)
 
void RemoveAt (ITERATE_t nIndex)
 
void RemoveAt (ITERATE_t nIndex, ITERATE_t iQty)
 
void MoveElement (ITERATE_t iFrom, ITERATE_t iTo)
 
- Public Member Functions inherited from Gray::CObject
virtual ~CObject ()
 
virtual void AssertValid () const
 < memory allocation and structure definitions are valid. More...
 
virtual void Serialize (cArchive &a)
 

Additional Inherited Members

- Protected Member Functions inherited from Gray::cArraySorted< TYPE, TYPE_ARG, TYPE_KEY >
virtual COMPARE_t CompareKey (KEY_t key1, REF_t Data2) const
 
bool RemoveArgKey (REF_t pObj, KEY_t key)
 
- Protected Member Functions inherited from Gray::cArrayTyped< TYPE, TYPE_ARG >
ITERATE_t QSortPartition (ITERATE_t iLeft, ITERATE_t iRight)
 
void QSort (ITERATE_t iLeft, ITERATE_t iRight)
 
- Protected Member Functions inherited from Gray::CArray< TYPE, ARG_TYPE >
bool IsValidIndex (ITERATE_t i) const noexcept
 
- Protected Attributes inherited from Gray::CArray< TYPE, ARG_TYPE >
TYPEm_pData
 the actual array of data More...
 
ITERATE_t m_nSize
 Number of elements (upperBound - 1) More...
 

Detailed Description

template<class TYPE, class TYPE_PTR, typename _TYPE_HASH = HASHCODE_t>
class Gray::cArraySortFacadeHash< TYPE, TYPE_PTR, _TYPE_HASH >

a _TYPE_HASH get_HashCode() sorted array of TYPE* pointers does NOT allow dupe hash codes !

Member Typedef Documentation

◆ KEY_t

template<class TYPE , class TYPE_PTR , typename _TYPE_HASH = HASHCODE_t>
typedef SUPER_t::KEY_t Gray::cArraySortFacadeHash< TYPE, TYPE_PTR, _TYPE_HASH >::KEY_t

◆ REF_t

template<class TYPE , class TYPE_PTR , typename _TYPE_HASH = HASHCODE_t>
typedef SUPER_t::REF_t Gray::cArraySortFacadeHash< TYPE, TYPE_PTR, _TYPE_HASH >::REF_t

◆ SUPER_t

template<class TYPE , class TYPE_PTR , typename _TYPE_HASH = HASHCODE_t>
typedef cArraySortFacade<TYPE, TYPE_PTR, _TYPE_HASH> Gray::cArraySortFacadeHash< TYPE, TYPE_PTR, _TYPE_HASH >::SUPER_t

Constructor & Destructor Documentation

◆ ~cArraySortFacadeHash()

template<class TYPE , class TYPE_PTR , typename _TYPE_HASH = HASHCODE_t>
virtual Gray::cArraySortFacadeHash< TYPE, TYPE_PTR, _TYPE_HASH >::~cArraySortFacadeHash ( )
inlinevirtual

Member Function Documentation

◆ CompareData()

template<class TYPE , class TYPE_PTR , typename _TYPE_HASH = HASHCODE_t>
virtual COMPARE_t Gray::cArraySortFacadeHash< TYPE, TYPE_PTR, _TYPE_HASH >::CompareData ( REF_t  pData1,
REF_t  pData2 
) const
inlineoverridevirtualnoexcept

Compare a data record to another data record.

Reimplemented from Gray::cArraySortFacade< TYPE, TYPE_PTR, HASHCODE_t >.

◆ CompareKey()

template<class TYPE , class TYPE_PTR , typename _TYPE_HASH = HASHCODE_t>
virtual COMPARE_t Gray::cArraySortFacadeHash< TYPE, TYPE_PTR, _TYPE_HASH >::CompareKey ( KEY_t  key1,
REF_t  pData2 
) const
inlineoverridevirtual
Note
x-y will not work for extreme values so we use cValT::Compare INT_MAX - INT_MIN must be positive !

The documentation for this class was generated from the following file: