![]() |
GM6000 Digital Heater Controller Branch: main
SDX-1330
|
This partially concrete provides a wrapper class that allows a String object to be stored directly in one the CPL Containers. More...
This partially concrete provides a wrapper class that allows a String object to be stored directly in one the CPL Containers.
A StringItem can be stored in a SList, DList, Dictionary, and Map.
Notes:
o The allocation of the actual String is deferred to child classes. o When storing a StringItem in a 'keyed' container (i.e. Dictionary and Map) the application MUST NOT change the value of the internal string since it is the 'key' value that is used to determine its placement in the Dictionary/Map. Modifying the internal String while the StringItem is in a Dictionary/Map will CORRUPT the Container. o StringItem instances CANNOT be copied. This is to avoid potential Container corruption since the individual Items contain the memory for the Containers' linkage, i.e. a copied container Item is analogous to storing a single Item in more than one Container at the same time.
#include <StringItem.h>
Public Member Functions | |
String & | get () const |
Returns a reference to the actual String. | |
const char * | getString () const |
Returns a pointer to the internal C string. | |
operator String & () const | |
Cast to a String reference. | |
operator const char * () const | |
Cast to read-only character string pointer. | |
const char * | operator() () const |
Returns a Read-only pointer to the "raw" (short-hand for getString()) | |
const Cpl::Container::Key & | getKey () const noexcept |
Return Cpl::Container::DictItem (used with Maps and Dictionaries) | |
![]() | |
bool | insert_ (void *newContainerPtr) |
Helper method to trap when inserting an item in multiple containers. | |
bool | isInContainer_ (const void *containerPtr) const noexcept |
Returns 'true' if the instance is in the specified container. | |
Protected Member Functions | |
StringItem (String &string) | |
Constructor. | |
![]() | |
MapItem () | |
Constructor. | |
MapItem (const char *ignoreThisParameter_usedToCreateAUniqueConstructor) | |
Constructor -->special constructor to allow a Map to be statically allocated. | |
void | initialize (MapItem *parent) |
Initialize the node when being inserted in the tree. | |
MapItem * | getParent () const |
Get tree connection/pointer. | |
void | setParent (MapItem *n) |
Set tree connection/pointer. | |
MapItem * | getLeft () const |
Get tree connection/pointer. | |
void | setLeft (MapItem *n) |
Set tree connection/pointer. | |
MapItem * | getRight () const |
Get tree connection/pointer. | |
void | setRight (MapItem *n) |
Set tree connection/pointer. | |
![]() | |
DictItem () | |
Constructor. | |
DictItem (const char *ignoreThisParameter_usedToCreateAUniqueConstructor) | |
Constructor used ONLY with the child class MapItem: -->special constructor to allow a Map to be statically allocated. | |
![]() | |
ExtendedItem () | |
Constructor. | |
ExtendedItem (const char *ignoreThisParameter_usedToCreateAUniqueConstructor) | |
Constructor used ONLY with the child class MapItem: -->special constructor to allow a Map to be statically allocated. | |
![]() | |
Item () | |
Constructor. | |
Item (const char *) | |
Constructor used ONLY with the child class MapItem: -->special constructor to allow a Map to be statically allocated. | |
Protected Attributes | |
String & | m_myString |
Reference to the actual String/storage. | |
![]() | |
void * | m_parentPtr_ |
Link field to the parent node. | |
bool | m_is_NOT_root_ |
I am the root node. | |
Balance_T | m_balance_ |
Balance status. | |
![]() | |
unsigned int | m_hashCode_ |
Remember which hash bucket I am stored in. | |
Additional Inherited Members | |
![]() | |
static void | remove_ (Item *itemPtr) noexcept |
Helper method to do the proper 'clean-up' for the multiple-containers-error-trap when removing an item from a container. | |
![]() | |
void * | m_prevPtr_ |
The previous link field. | |
![]() | |
void * | m_nextPtr_ |
The link field. | |
void * | m_inListPtr_ |
Debug field. | |
![]() | |
enum | Balance_T { eLEFT_ =-1 , eEVEN_ =0 , eRIGHT_ =1 } |
Magic values for balance status. More... | |
|
inlineprotected |
Constructor.
|
inlinevirtualnoexcept |
Return Cpl::Container::DictItem (used with Maps and Dictionaries)
Implements Cpl::Container::DictItem.
|
inline |
Returns a pointer to the internal C string.
|
inline |
Cast to read-only character string pointer.
|
inline |
Returns a Read-only pointer to the "raw" (short-hand for getString())
|
protected |
Reference to the actual String/storage.