ALib C++ Library
Library Version: 2402 R1
Documentation generated by doxygen
Loading...
Searching...
No Matches
TLocalString< TChar, TCapacity > Class Template Reference

Description:

template<typename TChar, integer TCapacity>
class alib::strings::TLocalString< TChar, TCapacity >

This type specializes class AString by adding a character array member of templated size which is used as the "external" string buffer. The single motivation for the use of this class is performance optimization.

Assembled character strings often have a rather short lifetime and are disposed quickly after their usage. If the maximum length of the assembled string is known, such strings may be created as local values of this type, with that maximum length given as template parameter TCapacity . With that, the allocation and de-allocation of heap memory for the string is omitted and allocation and destruction of the local string is performed in constant time O(1).

But even if an instance of this class is allocated on the heap (using keyword new), still some performance improvements apply, because besides the class object itself, no second memory allocation for the string buffer is performed.

If during the use of an instance of this class the buffer's fixed TCapacity is exceeded, a new buffer is allocated from the heap, just as it is always done with growing strings managed in AString objects. This means, the use of this class is safe and no restrictions apply. Of-course, if possible, for performance critical code sections, the predefined size TCapacity should be chosen large enough to allow the internal buffer to survive the use.
With debug builds of ALib , parent class AString optionally and by default raises a warning if an external buffer is replaced by a new (heap) allocation. (Note that from an AString perspective, this class's internal field buffer is an external character array). With use cases that do not allow to foresee a maximum buffer size, the warning has to be disabled by invoking DbgDisableBufferReplacementWarning .

For more information on warnings, see AString::SetBuffer .

Note
For commonly used sizes and character types, some convenient typedefs exists in namespace alib. Type definitions are:
Template Parameters
TCharThe character type.
Alias names for specializations of this class using character types character , nchar , wchar , xchar , complementChar and strangeChar are provided in namespace alib with type definitions LocalString<TCapacity>, NLocalString<TCapacity>, WLocalString<TCapacity>, XLocalString<TCapacity>, ComplementLocalString<TCapacity> and StrangeLocalString<TCapacity>.
TCapacityThe capacity of the string buffer allocated locally "inside" the class.

Definition at line 65 of file localstring.hpp.

#include <localstring.hpp>

Inheritance diagram for TLocalString< TChar, TCapacity >:
[legend]
Collaboration diagram for TLocalString< TChar, TCapacity >:
[legend]

Public Method Index:

constexpr TLocalString ()
 
template<class TAppendable >
 TLocalString (const TAppendable &src)
 
 TLocalString (const TLocalString &copy)
 
 TLocalString (TLocalString &&move) noexcept
 
TLocalStringoperator= (const TLocalString &copy)
 
TLocalStringoperator= (TLocalString &&move)
 
- Public Method Index: inherited from TAString< TChar >
constexpr TAString ()
 
 TAString (const TAString &copy)
 
 TAString (TAString &&move) noexcept
 
template<class TAppendable >
 TAString (const TAppendable &src)
 
 ~TAString () noexcept
 
template<typename TCharArray >
 operator TCharArray () const
 
template<typename TCharArray >
 operator TCharArray () const
 
TAStringoperator= (const TAString &copy)
 
ALIB_API void SetBuffer (integer newCapacity)
 
ALIB_API void SetBuffer (TChar *extBuffer, integer extBufferSize, integer extLength=0, lang::Responsibility responsibility=lang::Responsibility::KeepWithSender)
 
void EnsureRemainingCapacity (integer spaceNeeded)
 
void GrowBufferAtLeastBy (integer minimumGrowth)
 
integer Capacity () const
 
bool HasInternalBuffer () const
 
void SetNull ()
 
const TChar * Terminate () const
 
TChar * VBuffer () const
 
template<bool TCheck = true>
void SetCharAt (integer idx, TChar c)
 
TChar & operator[] (integer idx)
 
void SetLength (integer newLength)
 
void DetectLength ()
 
TAStringShortenTo (integer newLength)
 
template<bool TCheck = true, typename TCharSrc >
TAStringAppend (const TCharSrc *src, integer srcLength)
 
template<bool TCheck = true>
TAStringAppend (const TChar *src, integer srcLength)
 
template<bool TCheck = true>
TAStringAppend (const TString< TChar > &src, integer regionStart, integer regionLength=MAX_LEN)
 
template<bool TCheck = true>
TAString_ (const TString< TChar > &src, integer regionStart, integer regionLength=MAX_LEN)
 
TAStringNewLine ()
 
template<bool TCheck = true, typename TAppendable >
TAStringAppend (const TAppendable &src)
 
template<bool TCheck = true, class TAppendable >
TAString_ (const TAppendable &src)
 
template<class TAppendable >
TAStringoperator<< (const TAppendable &src)
 
TAStringReset ()
 
template<bool TCheck = true, typename TAppendable >
TAStringReset (const TAppendable &src)
 
TAString_ ()
 
template<bool TCheck = true>
TAStringInsertAt (const TString< TChar > &src, integer pos)
 
template<bool TCheck = true>
TAStringInsertChars (TChar c, integer qty)
 
template<bool TCheck = true>
TAStringInsertChars (TChar c, integer qty, integer pos)
 
template<bool TCheck = true>
TAStringDelete (integer regionStart, integer regionLength=MAX_LEN)
 
template<bool TCheck = true>
TAStringDeleteStart (integer regionLength)
 
template<bool TCheck = true>
TAStringDeleteEnd (integer regionLength)
 
ALIB_API TAStringTrim (const TCString< TChar > &trimChars=TT_StringConstants< TChar >::DefaultWhitespaces())
 
ALIB_API integer TrimAt (integer idx, const TCString< TChar > &trimChars=TT_StringConstants< TChar >::DefaultWhitespaces())
 
TAStringTrimStart (const TCString< TChar > &trimChars=TT_StringConstants< TChar >::DefaultWhitespaces())
 
TAStringTrimEnd (const TCString< TChar > &trimChars=TT_StringConstants< TChar >::DefaultWhitespaces())
 
template<bool TCheck = true>
TAStringReplaceSubstring (const TString< TChar > &src, integer regionStart, integer regionLength)
 
template<bool TCheck = true>
TAStringReplaceRegion (TChar c, integer regionStart, integer regionLength)
 
ALIB_API integer SearchAndReplace (TChar needle, TChar replacement, integer startIdx=0)
 
ALIB_API integer SearchAndReplace (const TString< TChar > &needle, const TString< TChar > &replacement, integer startIdx=0, integer maxReplacements=MAX_LEN, lang::Case sensitivity=lang::Case::Sensitive)
 
template<bool TCheck = true>
TAStringToUpper (integer regionStart=0, integer regionLength=MAX_LEN)
 
template<bool TCheck = true>
TAStringToLower (integer regionStart=0, integer regionLength=MAX_LEN)
 
template<bool TCheck = true>
TAStringReverse (integer regionStart=0, integer regionLength=MAX_LEN)
 
ALIB_WARNINGS_ALLOW_UNSAFE_BUFFER_USAGE Iterator begin ()
 
Iterator end ()
 
ALIB_WARNINGS_RESTORE ReverseIterator rbegin ()
 
ReverseIterator rend ()
 
void dbgCheck () const
 
void DbgDisableBufferReplacementWarning ()
 
- Public Method Index: inherited from TString< TChar >
constexpr TString () noexcept=default
 
constexpr TString (const TString &) noexcept=default
 
constexpr TString (TString &&) noexcept=default
 
TStringoperator= (const TString &) noexcept=default
 
TStringoperator= (TString &&) noexcept=default
 
constexpr TString (const TChar *pBuffer, integer pLength) noexcept
 
template<typename TCharArray >
constexpr TString (const TCharArray &src)
 
template<typename TCharArray >
 operator TCharArray () const
 
template<typename TCharArray >
 operator TCharArray () const
 
template<bool TCheck = true>
TString< TChar > Substring (integer regionStart, integer regionLength=MAX_LEN) const
 
constexpr const TChar * Buffer () const
 
constexpr integer Length () const
 
integer WStringLength () const
 
constexpr bool IsNull () const
 
constexpr bool IsNotNull () const
 
constexpr bool IsEmpty () const
 
constexpr bool IsNotEmpty () const
 
template<bool TCheck = true>
TChar CharAt (integer idx) const
 
template<bool TCheck = true>
TChar CharAtStart () const
 
template<bool TCheck = true>
TChar CharAtEnd () const
 
TChar operator[] (integer idx) const
 
std::size_t Hashcode () const
 
std::size_t HashcodeIgnoreCase () const
 
template<bool TCheck = true, lang::Case TSensitivity = lang::Case::Sensitive>
bool Equals (const TString< TChar > &rhs) const
 
template<bool TCheck = true, lang::Case TSensitivity = lang::Case::Sensitive>
int CompareTo (const TString< TChar > &rhs) const
 
template<bool TCheck = true, lang::Case TSensitivity = lang::Case::Sensitive>
int CompareTo (const TString &rhs, integer rhsRegionStart, integer rhsRegionLength=MAX_LEN) const
 
template<bool TCheck = true, lang::Case TSensitivity = lang::Case::Sensitive>
int CompareTo (const TString &rhs, integer rhsRegionStart, integer rhsRegionLength, integer regionStart, integer regionLength=MAX_LEN) const
 
template<bool TCheck = true, lang::Case TSensitivity = lang::Case::Sensitive>
bool ContainsAt (const TString &needle, integer pos) const
 
template<bool TCheck = true, lang::Case TSensitivity = lang::Case::Sensitive>
bool StartsWith (const TString &needle) const
 
template<bool TCheck = true, lang::Case TSensitivity = lang::Case::Sensitive>
bool EndsWith (const TString &needle) const
 
template<bool TCheck = true>
integer IndexOf (TChar needle, integer startIdx=0) const
 
template<bool TCheck = true>
integer IndexOf (TChar needle, integer regionStart, integer regionLength) const
 
integer IndexOfOrLength (TChar needle) const
 
template<bool TCheck = true>
ALIB_WARNINGS_ALLOW_UNSAFE_BUFFER_USAGE integer IndexOfOrLength (TChar needle, integer startIdx) const
 
template<bool TCheck = true>
ALIB_WARNINGS_RESTORE integer LastIndexOf (TChar needle, integer startIndex=MAX_LEN) const
 
template<lang::Inclusion TInclusion, bool TCheck = true>
integer IndexOfAny (const TString &needles, integer startIdx=0) const
 
template<lang::Inclusion TInclusion, bool TCheck = true>
integer LastIndexOfAny (const TString &needles, integer startIdx=MAX_LEN) const
 
template<bool TCheck = true, lang::Case TSensitivity = lang::Case::Sensitive>
integer IndexOf (const TString &needle, integer startIdx=0) const
 
template<bool TCheck = true>
integer IndexOfFirstDifference (const TString &needle, lang::Case sensitivity=lang::Case::Sensitive, integer idx=0) const
 
integer IndexOfSegmentEnd (TChar opener, TChar closer, integer idx) const
 
template<bool TCheck = true>
integer CountChar (TChar needle, integer startPos=0) const
 
template<bool TCheck = true>
integer CountChar (TChar needle, TChar omit, integer startPos) const
 
template<bool TCheck = true, lang::Case TSensitivity = lang::Case::Sensitive>
integer Count (const TString &needle, integer startPos=0) const
 
template<bool TCheck = true, lang::Case TSensitivity = lang::Case::Sensitive>
integer Count (const TString &needle, const TString &omit, integer startPos=0) const
 
ALIB_API uint64_t ParseDecDigits (integer startIdx=0, integer *newIdx=nullptr) const
 
ALIB_API int64_t ParseInt (integer startIdx=0, TNumberFormat< TChar > *numberFormat=nullptr, integer *newIdx=nullptr) const
 
int64_t ParseInt (TNumberFormat< TChar > *numberFormat, integer *newIdx=nullptr) const
 
int64_t ParseInt (integer *newIdx) const
 
int64_t ParseInt (integer startIdx, integer *newIdx) const
 
ALIB_API uint64_t ParseDec (integer startIdx=0, TNumberFormat< TChar > *numberFormat=nullptr, integer *newIdx=nullptr) const
 
uint64_t ParseDec (TNumberFormat< TChar > *numberFormat, integer *newIdx=nullptr) const
 
uint64_t ParseDec (integer *newIdx) const
 
uint64_t ParseDec (integer startIdx, integer *newIdx) const
 
ALIB_API uint64_t ParseBin (integer startIdx=0, TNumberFormat< TChar > *numberFormat=nullptr, integer *newIdx=nullptr) const
 
uint64_t ParseBin (TNumberFormat< TChar > *numberFormat, integer *newIdx=nullptr) const
 
uint64_t ParseBin (integer *newIdx) const
 
uint64_t ParseBin (integer startIdx, integer *newIdx) const
 
ALIB_API uint64_t ParseHex (integer startIdx=0, TNumberFormat< TChar > *numberFormat=nullptr, integer *newIdx=nullptr) const
 
uint64_t ParseHex (TNumberFormat< TChar > *numberFormat, integer *newIdx=nullptr) const
 
uint64_t ParseHex (integer *newIdx) const
 
uint64_t ParseHex (integer startIdx, integer *newIdx) const
 
ALIB_API uint64_t ParseOct (integer startIdx=0, TNumberFormat< TChar > *numberFormat=nullptr, integer *newIdx=nullptr) const
 
uint64_t ParseOct (TNumberFormat< TChar > *numberFormat, integer *newIdx=nullptr) const
 
uint64_t ParseOct (integer *newIdx) const
 
uint64_t ParseOct (integer startIdx, integer *newIdx) const
 
ALIB_API double ParseFloat (integer startIdx=0, TNumberFormat< TChar > *numberFormat=nullptr, integer *newIdx=nullptr) const
 
double ParseFloat (TNumberFormat< TChar > *numberFormat, integer *newIdx=nullptr) const
 
double ParseFloat (integer *newIdx) const
 
double ParseFloat (integer startIdx, integer *newIdx) const
 
integer CopyTo (TChar *dest) const
 
bool AdjustRegion (integer &regionStart, integer &regionLength) const
 
ConstIterator begin () const
 
ConstIterator cbegin () const
 
ALIB_WARNINGS_ALLOW_UNSAFE_BUFFER_USAGE ConstIterator end () const
 
ConstIterator cend () const
 
ALIB_WARNINGS_RESTORE ConstReverseIterator rbegin () const
 
ConstReverseIterator rend () const
 
ConstReverseIterator crbegin () const
 
ConstReverseIterator crend () const
 
 TString (ConstIterator &start, ConstIterator &end)
 

Additional Inherited Members

- Public Type Index: inherited from TAString< TChar >
using Iterator = typename TString<TChar>::template TRandomAccessIterator<TChar>
 
using ReverseIterator = std::reverse_iterator<Iterator>
 
- Public Type Index: inherited from TString< TChar >
using CharType = TChar
 
using ConstIterator = TRandomAccessIterator<const TChar>
 
using ConstReverseIterator = std::reverse_iterator<ConstIterator>
 

Field Details:

◆ localBuffer

template<typename TChar , integer TCapacity>
TChar localBuffer[TCapacity]
protected

The internal buffer with size specified by the template parameter TCapacity . Passed as an external buffer to parent class AString.

Definition at line 73 of file localstring.hpp.

Constructor(s) / Destructor Details::

◆ TLocalString() [1/4]

template<typename TChar , integer TCapacity>
constexpr TLocalString ( )
inlineconstexpr

Constructs an empty LocalString. Inherited field buffer will be set as an the external buffer of parent AString. Unlike all other ALib string classes, objects of this type are not nulled after default construction.

Definition at line 86 of file localstring.hpp.

◆ TLocalString() [2/4]

template<typename TChar , integer TCapacity>
TLocalString ( const TLocalString< TChar, TCapacity > & copy)
inline

Copy constructor. Copies the string data of parameter copy to this instance

Parameters
copyThe object to copy the contents from.

Definition at line 95 of file localstring.hpp.

Here is the call graph for this function:

◆ TLocalString() [3/4]

template<typename TChar , integer TCapacity>
TLocalString ( TLocalString< TChar, TCapacity > && move)
inlinenoexcept

Move constructor. See Copy/Move Constructor and Assignment for details.

Parameters
moveThe object to move.

Definition at line 108 of file localstring.hpp.

◆ TLocalString() [4/4]

template<typename TChar , integer TCapacity>
template<class TAppendable >
TLocalString ( const TAppendable & src)
inline

Constructs the object and uses parent's method Append to create a string representation of given "appendable" object src .

See also
Manual chapter 5.1 Appending Custom Types for more information about which types are supported and how external, user defined types can be made compatible to this implicit constructor.
Template Parameters
TAppendableThe type of parameter src that has a specialization of functor T_Append .
Parameters
srcThe source to take the buffer and length from of template type T.

Definition at line 214 of file localstring.hpp.

Here is the call graph for this function:

Method Details:

◆ operator=() [1/2]

template<typename TChar , integer TCapacity>
TLocalString & operator= ( const TLocalString< TChar, TCapacity > & copy)
inline

Copy assign operator. Copies the contents of the given object copy .

Parameters
copyThe object to copy the contents from.
Returns
*this to allow concatenated calls.

Definition at line 146 of file localstring.hpp.

Here is the call graph for this function:

◆ operator=() [2/2]

template<typename TChar , integer TCapacity>
TLocalString & operator= ( TLocalString< TChar, TCapacity > && move)
inline

Move assign operator. Copies the contents of the given object copy .

Parameters
moveThe object to move the contents from.
Returns
*this to allow concatenated calls.

Definition at line 164 of file localstring.hpp.

Here is the call graph for this function:

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