StringBuilder C++ Reference Documentation
CkStringBuilder
Current Version: 11.1.0
A simple class for building strings. (Represents a mutable string of characters.)
Note: This class was introduced in Chilkat v9.5.0.58.
Object Creation
// Local variable on the stack CkStringBuilder obj; // Dynamically allocate/delete CkStringBuilder *pObj = new CkStringBuilder(); // ... delete pObj;
Properties
DebugLogFilePath
const char *debugLogFilePath(void);
void put_DebugLogFilePath(const char *ansiOrUtf8Str);
If set to a file path, this property logs the LastErrorText of each Chilkat method or property call to the specified file. This logging helps identify the context and history of Chilkat calls leading up to any crash or hang, aiding in debugging.
Enabling the VerboseLogging property provides more detailed information. This property is mainly used for debugging rare instances where a Chilkat method call causes a hang or crash, which should generally not happen.
Possible causes of hangs include:
- A timeout property set to 0, indicating an infinite timeout.
- A hang occurring within an event callback in the application code.
- An internal bug in the Chilkat code causing the hang.
HasEmojis
Returns true if the content contains one or more emoji characters.
IntValue
void put_IntValue(int newVal);
Returns the content of the string converted to an integer.
topIsBase64
Returns true if the content contains only those characters allowed in the base64 encoding.  A base64 string is composed of characters 'A'..'Z', 'a'..'z', '0'..'9', '+', '/' and it is often padded at the end with up to two '=', to make the length a multiple of 4. Whitespace is ignored.
LastErrorHtml
Provides HTML-formatted information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
topLastErrorText
Provides plain text information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
LastErrorXml
Provides XML-formatted information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
topLastMethodSuccess
void put_LastMethodSuccess(bool newVal);
Indicates the success or failure of the most recent method call: true means success, false means failure. This property remains unchanged by property setters or getters.  This method is present to address challenges in checking for null or Nothing returns in certain programming languages.  Note: This property does not apply to methods that return integer values or to boolean-returning methods where the boolean does not indicate success or failure.
Length
The number of characters of the string contained within this instance.
topUtf8
void put_Utf8(bool newVal);
            When set to true, all const char * arguments and return values are interpreted as UTF-8 strings. When set to false, they are interpreted as ANSI strings.
            
            
            
            
            
            
In Chilkat v11.0.0 and later, the default value is true. Before v11.0.0, it was false.
VerboseLogging
void put_VerboseLogging(bool newVal);
If set to true, then the contents of LastErrorText (or LastErrorXml, or LastErrorHtml) may contain more verbose information. The default value is false.  Verbose logging should only be used for debugging.  The potentially large quantity of logged information may adversely affect peformance.
Version
Methods
Append
Appends a copy of the specified string to this instance.
Returns true for success, false for failure.
topAppendBd
Appends the contents of binData. The charset specifies the character encoding of the bytes contained in binData. The charset can be any of the supported encodings listed at Chilkat Supported Character Encodings. To append the entire contents of binData, set offset and numBytes equal to zero. To append a range of binData, set the offset and numBytes to specify the range.
Returns true for success, false for failure.
topAppendInt
Appends the string representation of a specified 32-bit signed integer to this instance.
Returns true for success, false for failure.
topAppendInt64
Appends the string representation of a specified 64-bit signed integer to this instance.
Returns true for success, false for failure.
topAppendLine
Appends the value followed by a CRLF or LF  to the end of the curent StringBuilder object.   If crlf is true, then a CRLF line ending is used.  Otherwise a LF line ending is used.
Returns true for success, false for failure.
topAppendRandom
Append numBytes random bytes encoded according to encoding.  encoding can be hex, hex_lower, base64, base64url, or any other encoding supported by Chilkat.
Returns true for success, false for failure.
topAppendSb
Appends the contents of another StringBuilder to this instance.
Returns true for success, false for failure.
topAppendUuid
Generates and appends a random GUID/UUID such as 63c35f38-2b5f-4600-b3da-3ddee86d62b3.   If lowerCase is true, then the hex values use lowercase (a - f).   If lowerCase is false then uppercase is used (A - F).
Note: This generates a version 4 UUID.
Returns true for success, false for failure.
AppendUuid7
Generates and appends a random version 7 UUID.   If lowerCase is true, then the hex values use lowercase (a - f).   If lowerCase is false then uppercase is used (A - F).
Returns true for success, false for failure.
topClear
Removes all characters from the current StringBuilder instance.
topContains
Returns true if the str is contained within this object.   For case sensitive matching, set caseSensitive equal to true.  For case-insensitive, set caseSensitive equal to false.
ContainsWord
Returns true if the word is contained within this object, but only if it is a whole word.  This method is limited to finding whole words in strings that only contains characters in the Latin1 charset (i.e. iso-8859-1 or Windows-1252).    A whole word can only contain alphanumeric chars where the alpha chars are restricted to those of the Latin1 alpha chars.  (The underscore character is also considered part of a word.)
For case sensitive matching, set caseSensitive equal to true.  For case-insensitive, set caseSensitive equal to false.
ContentsEqual
Returns true if the contents of this object equals the str.  Returns false if unequal.  For case insensitive equality, set caseSensitive equal to false.
ContentsEqualSb
Returns true if the contents of this object equals the sb.  Returns false if unequal.  For case insensitive equality, set caseSensitive equal to false.
Decode
Decodes and replaces the contents with the decoded string. The encoding can be set to any of the following strings: base64, hex, quoted-printable (or qp), url, base32, Q, B, url_rc1738, url_rfc2396, url_rfc3986, url_oauth, uu, modBase64, or html (for HTML entity encoding).   The full up-to-date list of supported binary encodings is available at the link entitled Supported Binary Encodings below.
Note: This method can only be called if the encoded content decodes to a string.  The charset indicates the charset to be used in intepreting the decoded bytes.  For example, the charset can be utf-8, utf-16, iso-8859-1, shift_JIS, etc.
Returns true for success, false for failure.
DecodeAndAppend
Decodes a binary encoded string, where the binary encoding (such as url, hex, base64, etc.) is specified by encoding, and the underlying charset encoding (such as utf-8, windows-1252, etc.) is specified by charset.  The decoded string is appended to this object.
Returns true for success, false for failure.
Encode
Encodes to base64, hex, quoted-printable, URL encoding, etc. The encoding can be set to any of the following strings: base64, hex, quoted-printable (or qp), url, base32, Q, B, url_rc1738, url_rfc2396, url_rfc3986, url_oauth, uu, modBase64, or html (for HTML entity encoding).   The full up-to-date list of supported binary encodings is available at the link entitled Supported Binary Encodings below.
Returns true for success, false for failure.
EndsWith
Returns true if the string ends with substr.  Otherwise returns false.  The comparison is case sensitive if caseSensitive is true, and case insensitive if caseSensitive is false.
EntityDecode
Decodes HTML entities. See HTML entities for more information about HTML entities.
Returns true for success, false for failure.
GetAfterBetween
const char *getAfterBetween(const char *searchAfter, const char *beginMark, const char *endMark);
Begin searching after the 1st occurrence of searchAfter is found, and then return the substring found between the next occurrence of beginMark and the next occurrence of endMark.
Returns true for success, false for failure.
GetAfterFinal
const char *getAfterFinal(const char *marker, bool removeFlag);
Returns the substring found after the final occurrence of marker.  If removeFlag is true, the marker and the content that follows is removed from this content.
If the marker is not present, then the entire string is returned.  In this case, if removeFlag is true, this object is also cleared.
Returns true for success, false for failure.
GetAsString
GetBefore
const char *getBefore(const char *marker, bool removeFlag);
Returns the substring found before the 1st occurrence of marker.  If removeFlag is true, the content up to and including the marker is removed from this object's contents.
If the marker is not present, then the entire string is returned.  In this case, if removeFlag is true, this object is also cleared.
Returns true for success, false for failure.
GetBetween
const char *getBetween(const char *beginMark, const char *endMark);
Returns the substring found between the 1st occurrence of beginMark and the next occurrence of endMark.
Returns true for success, false for failure.
GetEncoded
const char *getEncoded(const char *encoding, const char *charset);
Returns the string contents encoded in an encoding such as base64, hex, quoted-printable, or URL-encoding. The encoding can be set to any of the following strings: base64, hex, quoted-printable (or qp), url, base32, Q, B, url_rc1738, url_rfc2396, url_rfc3986, url_oauth, uu, modBase64, or html (for HTML entity encoding).   The full up-to-date list of supported binary encodings is available at the link entitled Supported Binary Encodings below.
Note: The Encode method modifies the content of this object. The GetEncoded method leaves this object's content unmodified.
Returns true for success, false for failure.
GetHash
const char *getHash(const char *algorithm, const char *encoding, const char *charset);
Returns the hash of the contents of this object.  The algorithm is the hash algorithm, and can be sha1, sha256, sha384, sha512, sha3-224, sha3-256, sha3-384, sha3-512, md2, md5, ripemd128, ripemd160,ripemd256, or ripemd320.  
The encoding  can be base64, modBase64, base64Url, base32, base58,  qp (for quoted-printable), url (for url-encoding), hex, hexLower, or any of the encodings found at Chilkat Binary Encodings List.
The charset is the character encoding byte representation to hash.  It is typically utf-8.  It can be any of the chacter encodings listed at Chilkat Character Encodings List.
Returns true for success, false for failure.
GetNth
const char *getNth(int index, const char *delimiterChar, bool exceptDoubleQuoted, bool exceptEscaped);
Returns the Nth substring in string that is a list delimted by delimiterChar.  The first substring is at index 0.  If exceptDoubleQuoted is true, then the delimiter char found between double quotes is not treated as a delimiter.  If exceptEscaped is true, then an escaped (with a backslash) delimiter char is not treated as a delimiter.
Returns true for success, false for failure.
GetRange
const char *getRange(int startIndex, int numChars, bool removeFlag);
Returns a string containing the specified range of characters from this instance.  If removeFlag is true, then the range of chars is removed from this instance.
Note: It was discovered that the range of chars was always removed regardless of the value of removeFlag. This is fixed in v9.5.0.89.
Returns true for success, false for failure.
LastNLines
const char *lastNLines(int numLines, bool bCrlf);
Returns the last N lines of the text.  If fewer than numLines lines exists, then all of the text is returned.  If bCrlf is true, then the line endings of the returned string are converted to CRLF, otherwise the line endings are converted to LF-only.
Returns true for success, false for failure.
LoadFile
Loads the contents of a file.
Returns true for success, false for failure.
MaskQuotedStrings
This function masks the content inside single and/or double-quoted strings by replacing it with a specified mask character (maskChar). The content of each masked quoted string is saved to maskedStrings. The contents can be restored by calling RestoreMaskedStrings.
quoteType determines which types of quoted strings are masked:
- Both single and double quoted.
- Only single quoted strings.
- Only double quoted strings.
Returns true for success, false for failure.
topObfuscate
Obfuscates the string. (The Unobfuscate method can be called to reverse the obfuscation to restore the original string.)
The Chilkat string obfuscation algorithm works by taking the utf-8 bytes of the string, base64 encoding it, and then scrambling the letters of the base64 encoded string. It is deterministic in that the same string will always obfuscate to the same result. It is NOT a secure way of encrypting a string. It is only meant to be a simple means of transforming a string into something unintelligible.
Prepend
Prepends a copy of the specified string to this instance.
Returns true for success, false for failure.
topPunyDecode
In-place decodes the string from punycode.
Returns true for success, false for failure.
PunyEncode
In-place encodes the string to punycode.
Returns true for success, false for failure.
RegexMatch
Searches the content of this object for substrings that match a regular expression pattern and returns the matches in json. Returns the number of matches or -1 for failure. timeoutMs is the maximum number of milliseconds of processing allowed before giving up. Pass 0 for an infinite amount of time. Failure information is also returned in json.
RegexReplace
Replaces the substrings of capture groups found in a previous call to RegexMatch.
RemoveAccents
Removes the accents (diacritics) from European accented characters. This applies only to the accented characters found in the Windows-1252 (Latin alphabet) and Windows-1250 (Central European) charsets. Accent marks for characters in other languages will not be removed.
Returns true for success, false for failure.
RemoveAfterFinal
Removes the substring found after the final occurrence of the marker.  Also removes the marker.  Returns true if the marker was found and content was removed.  Otherwise returns false.
Returns true for success, false for failure.
RemoveBefore
Removes the substring found before the 1st occurrence of the marker.  Also removes the marker.  Returns true if the marker was found and content was removed.  Otherwise returns false.
Returns true for success, false for failure.
RemoveCharsAt
Removes the specified range of characters from this instance.
Returns true for success, false for failure.
RemoveEmojis
Removes all emoji characters from the string.
topReplace
Replaces all occurrences of a specified string in this instance with another specified string. Returns the number of replacements.
topReplaceAfterFinal
Replaces the content found after the final occurrence of marker with replacement.
Returns true for success, false for failure.
topReplaceAllBetween
Replaces the first occurrence of ALL the content found between beginMark and endMark with replacement.   The beginMark and endMark are included in what is replaced if replaceMarks is true.
Returns true for success, false for failure.
ReplaceBetween
Replaces all occurrences of value with replacement, but only where value is found between beginMark and endMark. Returns the number of replacements made.
ReplaceFirst
Replaces the first occurrence of a specified string in this instance with another string.  Returns true if the value was found and replaced.  Otherwise returns false.
Returns true for success, false for failure.
ReplaceI
Replaces all occurrences of value with the decimal integer replacement. Returns the number of replacements.
topReplaceNoCase
Replaces all occurrences of value with replacement (case insensitive). Returns the number of replacements.
topReplaceWord
Replaces all word occurrences of a specified string in this instance with another specified string. Returns the number of replacements made.
Important: This method is limited to replacing whole words in strings that only contains characters in the Latin1 charset (i.e. iso-8859-1 or Windows-1252). A whole word can only contain alphanumeric chars where the alpha chars are restricted to those of the Latin1 alpha chars. (The underscore character is also considered part of a word.)
RestoreMaskedStrings
Restores single and/or double-quoted strings previously masked by MaskQuotedStrings.
quoteType determines which types of quoted strings are masked:
- Both single and double quoted.
- Only single quoted strings.
- Only double quoted strings.
Returns true for success, false for failure.
topSecureClear
Removes all characters from the current StringBuilder instance, and write zero bytes to the allocated memory before deallocating.
topSetNth
Sets the Nth substring in string in a list delimted by delimiterChar.  The first substring is at index 0.  If exceptDoubleQuoted is true, then the delimiter char found between double quotes is not treated as a delimiter.  If exceptEscaped is true, then an escaped (with a backslash) delimiter char is not treated as a delimiter.
Returns true for success, false for failure.
SetString
Sets this instance to a copy of the specified string.
Returns true for success, false for failure.
topShorten
Shortens the string by removing the last numChars chars.
Returns true for success, false for failure.
StartsWith
Returns true if the string starts with substr.  Otherwise returns false.  The comparison is case sensitive if caseSensitive is true, and case insensitive if caseSensitive is false.
ToCRLF
ToLF
ToLowercase
ToUppercase
Trim
TrimInsideSpaces
Replaces all tabs, CR's, and LF's, with SPACE chars, and removes extra SPACE's so there are no occurances of more than one SPACE char in a row.
Returns true for success, false for failure.
topUnobfuscate
Unobfuscates the string.
The Chilkat string obfuscation algorithm works by taking the utf-8 bytes of the string, base64 encoding it, and then scrambling the letters of the base64 encoded string. It is deterministic in that the same string will always obfuscate to the same result. It is not a secure way of encrypting a string. It is only meant to be a simple means of transforming a string into something unintelligible.
WriteFile
Writes the contents to a file.  If emitBom is true, then the BOM (also known as a preamble), is emitted for charsets that define a BOM (such as utf-8, utf-16, utf-32, etc.)
Returns true for success, false for failure.
topWriteFileIfModified
Writes the contents to a file, but only if it is a new file or if the contents are different than the existing file.  If emitBom is true, then the BOM (also known as a preamble), is emitted for charsets that define a BOM (such as utf-8, utf-16, utf-32, etc.)
Returns true for success, false for failure.
topDeprecated
AppendEncoded Deprecated
Appends binary data using the encoding specified by encoding, such as base64, hex, etc.
Returns true for success, false for failure.
GetDecoded Deprecated
Decodes and returns the decoded bytes. The encoding can be set to any of the following strings: base64, hex, quoted-printable (or qp), url, base32, Q, B, url_rc1738, url_rfc2396, url_rfc3986, url_oauth, uu, modBase64, or html (for HTML entity encoding).   The full up-to-date list of supported binary encodings is available at the link entitled Supported Binary Encodings below.
Returns true for success, false for failure.
top