StringBuilder Tcl Reference Documentation
StringBuilder
Current Version: 10.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
set myStringBuilder [new CkStringBuilder]
Properties
IntValue
set intVal [CkStringBuilder_get_IntValue $myStringBuilder]
CkStringBuilder_put_IntValue $myStringBuilder $intVal
Returns the content of the string converted to an integer.
topIsBase64
set boolVal [CkStringBuilder_get_IsBase64 $myStringBuilder]
Returns 1 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.
topLastMethodSuccess
set boolVal [CkStringBuilder_get_LastMethodSuccess $myStringBuilder]
CkStringBuilder_put_LastMethodSuccess $myStringBuilder $boolVal
Indicate whether the last method call succeeded or failed. A value of 1 indicates success, a value of 0 indicates failure. This property is automatically set for method calls. It is not modified by property accesses. The property is automatically set to indicate success for the following types of method calls:
- Any method that returns a string.
- Any method returning a Chilkat object, binary bytes, or a date/time.
- Any method returning a standard boolean status value where success = 1 and failure = 0.
- Any method returning an integer where failure is defined by a return value less than zero.
Note: Methods that do not fit the above requirements will always set this property equal to 1. For example, a method that returns no value (such as a "void" in C++) will technically always succeed.
topLength
set intVal [CkStringBuilder_get_Length $myStringBuilder]
The number of characters of the string contained within this instance.
topUtf8
set boolVal [CkStringBuilder_get_Utf8 $myStringBuilder]
CkStringBuilder_put_Utf8 $myStringBuilder $boolVal
When set to 1, all "const char *" arguments are interpreted as utf-8 strings. If set to 0 (the default), then "const char *" arguments are interpreted as ANSI strings. Also, when set to 1, and Chilkat method returning a "const char *" is returning the utf-8 representation. If set to 0, all "const char *" return values are ANSI strings.
topMethods
Append
set status [CkStringBuilder_Append $value]
AppendBd
# charset is a string
# offset is an integer
# numBytes is an integer
set status [CkStringBuilder_AppendBd $binData $charset $offset $numBytes]
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 1 for success, 0 for failure.
topAppendEncoded
# encoding is a string
set status [CkStringBuilder_AppendEncoded $binaryData $encoding]
Appends binary data using the encoding specified by encoding, such as "base64", "hex", etc.
Returns 1 for success, 0 for failure.
AppendInt
set status [CkStringBuilder_AppendInt $value]
Appends the string representation of a specified 32-bit signed integer to this instance.
Returns 1 for success, 0 for failure.
topAppendInt64
set status [CkStringBuilder_AppendInt64 $value]
Appends the string representation of a specified 64-bit signed integer to this instance.
Returns 1 for success, 0 for failure.
topAppendLine
# crlf is a boolean
set status [CkStringBuilder_AppendLine $value $crlf]
Appends the value followed by a CRLF or LF to the end of the curent StringBuilder object. If crlf is 1, then a CRLF line ending is used. Otherwise a LF line ending is used.
Returns 1 for success, 0 for failure.
topAppendRandom
# encoding is a string
set status [CkStringBuilder_AppendRandom $numBytes $encoding]
Append numBytes random bytes encoded according to encoding. encoding can be "hex", "hex_lower", "base64", "base64url", or any other encoding supported by Chilkat.
Returns 1 for success, 0 for failure.
topAppendSb
set status [CkStringBuilder_AppendSb $sb]
Appends the contents of another StringBuilder to this instance.
Returns 1 for success, 0 for failure.
topAppendUuid
set status [CkStringBuilder_AppendUuid $lowerCase]
Generates and appends a random GUID/UUID such as 63c35f38-2b5f-4600-b3da-3ddee86d62b3. If lowerCase is 1, then the hex values use lowercase ("a" - "f"). If lowerCase is 0 then uppercase is used ("A" - "F").
Note: This generates a version 4 UUID.
Returns 1 for success, 0 for failure.
AppendUuid7
set status [CkStringBuilder_AppendUuid7 $lowerCase]
Generates and appends a random version 7 UUID. If lowerCase is 1, then the hex values use lowercase ("a" - "f"). If lowerCase is 0 then uppercase is used ("A" - "F").
Returns 1 for success, 0 for failure.
topClear
Removes all characters from the current StringBuilder instance.
topContains
# caseSensitive is a boolean
set retBool [CkStringBuilder_Contains $str $caseSensitive]
Returns 1 if the str is contained within this object. For case sensitive matching, set caseSensitive equal to 1. For case-insensitive, set caseSensitive equal to 0.
topContainsWord
# caseSensitive is a boolean
set retBool [CkStringBuilder_ContainsWord $word $caseSensitive]
Returns 1 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 1. For case-insensitive, set caseSensitive equal to 0.
topContentsEqual
# caseSensitive is a boolean
set retBool [CkStringBuilder_ContentsEqual $str $caseSensitive]
Returns 1 if the contents of this object equals the str. Returns 0 if unequal. For case insensitive equality, set caseSensitive equal to 0.
topContentsEqualSb
# caseSensitive is a boolean
set retBool [CkStringBuilder_ContentsEqualSb $sb $caseSensitive]
Returns 1 if the contents of this object equals the sb. Returns 0 if unequal. For case insensitive equality, set caseSensitive equal to 0.
topDecode
# charset is a string
set status [CkStringBuilder_Decode $encoding $charset]
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 1 for success, 0 for failure.
DecodeAndAppend
# encoding is a string
# charset is a string
set status [CkStringBuilder_DecodeAndAppend $value $encoding $charset]
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 1 for success, 0 for failure.
Encode
# charset is a string
set status [CkStringBuilder_Encode $encoding $charset]
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 1 for success, 0 for failure.
EndsWith
# caseSensitive is a boolean
set retBool [CkStringBuilder_EndsWith $substr $caseSensitive]
Returns 1 if the string ends with substr. Otherwise returns 0. The comparison is case sensitive if caseSensitive is 1, and case insensitive if caseSensitive is 0.
topEntityDecode
Decodes HTML entities. See HTML entities for more information about HTML entities.
Returns 1 for success, 0 for failure.
GetAfterBetween
# beginMark is a string
# endMark is a string
# outStr is a CkString (output)
set status [CkStringBuilder_GetAfterBetween $searchAfter $beginMark $endMark $outStr]
set retStr [CkStringBuilder_getAfterBetween $myStringBuilder $searchAfter $beginMark $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 1 for success, 0 for failure.
GetAfterFinal
# removeFlag is a boolean
# outStr is a CkString (output)
set status [CkStringBuilder_GetAfterFinal $marker $removeFlag $outStr]
set retStr [CkStringBuilder_getAfterFinal $myStringBuilder $marker $removeFlag]
Returns the substring found after the final occurrence of marker. If removeFlag is 1, 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 1, this object is also cleared.
Returns 1 for success, 0 for failure.
GetAsString
set status [CkStringBuilder_GetAsString $outStr]
set retStr [CkStringBuilder_getAsString $myStringBuilder]
GetBefore
# removeFlag is a boolean
# outStr is a CkString (output)
set status [CkStringBuilder_GetBefore $marker $removeFlag $outStr]
set retStr [CkStringBuilder_getBefore $myStringBuilder $marker $removeFlag]
Returns the substring found before the 1st occurrence of marker. If removeFlag is 1, 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 1, this object is also cleared.
Returns 1 for success, 0 for failure.
GetBetween
# endMark is a string
# outStr is a CkString (output)
set status [CkStringBuilder_GetBetween $beginMark $endMark $outStr]
set retStr [CkStringBuilder_getBetween $myStringBuilder $beginMark $endMark]
Returns the substring found between the 1st occurrence of beginMark and the next occurrence of endMark.
Returns 1 for success, 0 for failure.
GetDecoded
# outBytes is a CkByteData (output)
set status [CkStringBuilder_GetDecoded $encoding $outData]
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 1 for success, 0 for failure.
topGetEncoded
# charset is a string
# outStr is a CkString (output)
set status [CkStringBuilder_GetEncoded $encoding $charset $outStr]
set retStr [CkStringBuilder_getEncoded $myStringBuilder $encoding $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 1 for success, 0 for failure.
GetHash
# encoding is a string
# charset is a string
# outStr is a CkString (output)
set status [CkStringBuilder_GetHash $algorithm $encoding $charset $outStr]
set retStr [CkStringBuilder_getHash $myStringBuilder $algorithm $encoding $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 1 for success, 0 for failure.
GetNth
# delimiterChar is a string
# exceptDoubleQuoted is a boolean
# exceptEscaped is a boolean
# outStr is a CkString (output)
set status [CkStringBuilder_GetNth $index $delimiterChar $exceptDoubleQuoted $exceptEscaped $outStr]
set retStr [CkStringBuilder_getNth $myStringBuilder $index $delimiterChar $exceptDoubleQuoted $exceptEscaped]
Returns the Nth substring in string that is a list delimted by delimiterChar. The first substring is at index 0. If exceptDoubleQuoted is 1, then the delimiter char found between double quotes is not treated as a delimiter. If exceptEscaped is 1, then an escaped (with a backslash) delimiter char is not treated as a delimiter.
Returns 1 for success, 0 for failure.
GetRange
# numChars is an integer
# removeFlag is a boolean
# outStr is a CkString (output)
set status [CkStringBuilder_GetRange $startIndex $numChars $removeFlag $outStr]
set retStr [CkStringBuilder_getRange $myStringBuilder $startIndex $numChars $removeFlag]
Returns a string containing the specified range of characters from this instance. If removeFlag is 1, 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 1 for success, 0 for failure.
LastNLines
# bCrlf is a boolean
# outStr is a CkString (output)
set status [CkStringBuilder_LastNLines $numLines $bCrlf $outStr]
set retStr [CkStringBuilder_lastNLines $myStringBuilder $numLines $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 1, then the line endings of the returned string are converted to CRLF, otherwise the line endings are converted to LF-only.
Returns 1 for success, 0 for failure.
LoadFile
# charset is a string
set status [CkStringBuilder_LoadFile $path $charset]
Loads the contents of a file.
Returns 1 for success, 0 for failure.
Obfuscate
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
set status [CkStringBuilder_Prepend $value]
PunyDecode
In-place decodes the string from punycode.
Returns 1 for success, 0 for failure.
PunyEncode
In-place encodes the string to punycode.
Returns 1 for success, 0 for failure.
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 1 for success, 0 for failure.
RemoveAfterFinal
set status [CkStringBuilder_RemoveAfterFinal $marker]
Removes the substring found after the final occurrence of the marker. Also removes the marker. Returns 1 if the marker was found and content was removed. Otherwise returns 0.
Returns 1 for success, 0 for failure.
RemoveBefore
set status [CkStringBuilder_RemoveBefore $marker]
Removes the substring found before the 1st occurrence of the marker. Also removes the marker. Returns 1 if the marker was found and content was removed. Otherwise returns 0.
Returns 1 for success, 0 for failure.
RemoveCharsAt
# numChars is an integer
set status [CkStringBuilder_RemoveCharsAt $startIndex $numChars]
Removes the specified range of characters from this instance.
Returns 1 for success, 0 for failure.
Replace
# replacement is a string
set retInt [CkStringBuilder_Replace $value $replacement]
Replaces all occurrences of a specified string in this instance with another specified string. Returns the number of replacements.
topReplaceAfterFinal
# replacement is a string
set status [CkStringBuilder_ReplaceAfterFinal $marker $replacement]
Replaces the content found after the final occurrence of marker with replacement.
Returns 1 for success, 0 for failure.
topReplaceAllBetween
# endMark is a string
# replacement is a string
# replaceMarks is a boolean
set status [CkStringBuilder_ReplaceAllBetween $beginMark $endMark $replacement $replaceMarks]
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 1.
Returns 1 for success, 0 for failure.
ReplaceBetween
# endMark is a string
# value is a string
# replacement is a string
set retInt [CkStringBuilder_ReplaceBetween $beginMark $endMark $value $replacement]
Replaces all occurrences of value with replacement, but only where value is found between beginMark and endMark. Returns the number of replacements made.
ReplaceFirst
# replacement is a string
set status [CkStringBuilder_ReplaceFirst $value $replacement]
Replaces the first occurrence of a specified string in this instance with another string. Returns 1 if the value was found and replaced. Otherwise returns 0.
Returns 1 for success, 0 for failure.
ReplaceI
# replacement is an integer
set retInt [CkStringBuilder_ReplaceI $value $replacement]
Replaces all occurrences of value with the decimal integer replacement. Returns the number of replacements.
topReplaceNoCase
# replacement is a string
set retInt [CkStringBuilder_ReplaceNoCase $value $replacement]
Replaces all occurrences of value with replacement (case insensitive). Returns the number of replacements.
topReplaceWord
# replacement is a string
set retInt [CkStringBuilder_ReplaceWord $value $replacement]
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.)
SecureClear
Removes all characters from the current StringBuilder instance, and write zero bytes to the allocated memory before deallocating.
topSetNth
# value is a string
# delimiterChar is a string
# exceptDoubleQuoted is a boolean
# exceptEscaped is a boolean
set status [CkStringBuilder_SetNth $index $value $delimiterChar $exceptDoubleQuoted $exceptEscaped]
Sets the Nth substring in string in a list delimted by delimiterChar. The first substring is at index 0. If exceptDoubleQuoted is 1, then the delimiter char found between double quotes is not treated as a delimiter. If exceptEscaped is 1, then an escaped (with a backslash) delimiter char is not treated as a delimiter.
Returns 1 for success, 0 for failure.
SetString
set status [CkStringBuilder_SetString $value]
Shorten
set status [CkStringBuilder_Shorten $numChars]
Shortens the string by removing the last numChars chars.
Returns 1 for success, 0 for failure.
StartsWith
# caseSensitive is a boolean
set retBool [CkStringBuilder_StartsWith $substr $caseSensitive]
Returns 1 if the string starts with substr. Otherwise returns 0. The comparison is case sensitive if caseSensitive is 1, and case insensitive if caseSensitive is 0.
topToCRLF
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 1 for success, 0 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
# charset is a string
# emitBom is a boolean
set status [CkStringBuilder_WriteFile $path $charset $emitBom]
Writes the contents to a file. If emitBom is 1, 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 1 for success, 0 for failure.
topWriteFileIfModified
# charset is a string
# emitBom is a boolean
set status [CkStringBuilder_WriteFileIfModified $path $charset $emitBom]
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 1, 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 1 for success, 0 for failure.
top