<ply-base.h>namespace plyStrings
<ply-base.h>namespace plyPlywood strings are general-purpose blocks of memory allocated from the heap. They're often used to manipulate text, but they can store binary data as well. There are three main classes for working with strings:
Stringowns a block of memory and frees it when the destructor is called.StringViewis a read-only view into a block of memory.MutStringViewis a read-write view into a block of memory.
These classes all use 32-bit integers for indexing, which means they can refereance a maximum of roughly 4 GB of memory.
Plywood strings aren't null-terminated unless you add an explicit null byte to the end. This is sometimes necessary when passing strings to legacy functions that expect a null terminator.
String str = "Hello, world!"; // The legacy function 'puts' expects a null terminator: puts((str + '\0').bytes());
These classes aren't thread-safe. Functions that read from the same string can be called concurrently from separate threads, but functions that modify the same string must not be called concurrently.
Common String Methods
The following member functions are implemented in both String and StringView:
| Accessing String Bytes | |
char* | bytes() |
const char* | bytes() const |
u32 | num_bytes() const |
char& | operator[](u32 index) |
const char& | operator[](u32 index) const |
char& | back(s32 ofs) |
const char& | back(s32 ofs) const |
| Examining String Contents | |
bool | is_empty() const |
explicit | operator bool() const |
bool | operator==(StringView other) const |
bool | starts_with(StringView arg) const |
bool | ends_with(StringView arg) const |
s32 | find(StringView substr, u32 start_pos) const |
s32 | find(const MatchFunc& match_func, u32 start_pos) const |
s32 | reverse_find(StringView substr, u32 start_pos) const |
s32 | reverse_find(const MatchFunc& match_func, u32 start_pos) const |
StringView | substr(u32 start) const |
StringView | substr(u32 start, u32 num_bytes) const |
StringView | left(u32 num_bytes) const |
StringView | shortened_by(u32 num_bytes) const |
StringView | right(u32 num_bytes) const |
StringView | trim(bool, bool left, bool right) const |
StringView | trim_left(bool) const |
StringView | trim_right(bool) const |
| Creating New Strings | |
String | upper() const |
String | lower() const |
Array<StringView> | split(StringView separator) const |
String | join(ArrayView<const StringView> comps) const |
String | operator+(StringView other) |
| Pattern Matching | |
template <typename... Args> | |
bool | match(StringView pattern, const Args&& args) |
Accessing String Bytes
char& operator[](u32 index)
const char& operator[](u32 index) constSubscript operator with runtime bounds checking. Can be used to read individual bytes or modify indvidual bytes (for
Stringonly). Ifindexis out of range, an assert will be triggered.String str = "Hello, world!"; char c = str[4]; // 'o' str[0] = 'J'; // "Jello, world!"
char& back(s32 ofs)
const char& back(s32 ofs) constReturns a reference to a byte relative to the end of the string. By default, returns the last byte. Pass
-2for the second-to-last byte, and so on.
Examining String Contents
bool is_empty() constReturns
trueif the string contains no bytes.bool starts_with(StringView arg) constReturns
trueif the string begins with the specified prefix.bool ends_with(StringView arg) constReturns
trueif the string ends with the specified suffix.s32 find(StringView substr, u32 start_pos) constSearches for the first occurrence of
substrstarting fromstart_pos. Returns the index of the first match, or-1if not found.s32 find(const MatchFunc& match_func, u32 start_pos) constSearches for the first byte that satisfies the match function starting from
start_pos. Returns the index of the first match, or-1if not found.s32 reverse_find(StringView substr, s32 start_pos) constSearches backwards for the last occurrence of
substrstarting fromstart_pos(or the end if-1). Returns the index of the match, or-1if not found.s32 reverse_find(const MatchFunc& match_func, s32 start_pos) constSearches backwards for the last byte that satisfies the match function. Returns the index of the match, or
-1if not found.StringView substr(u32 start) constReturns a view of the substring starting at
startand extending to the end of the string.StringView substr(u32 start, u32 num_bytes) constReturns a view of the substring starting at
startwith lengthnum_bytes.StringView left(u32 num_bytes) constReturns a view of the first
num_bytesbytes of the string.StringView shortened_by(u32 num_bytes) constReturns a view of the string with
num_bytesremoved from the end.StringView right(u32 num_bytes) constReturns a view of the last
num_bytesbytes of the string.StringView trim(bool, bool left, bool right) constReturns a view with matching characters removed from both ends. By default, trims whitespace characters.
StringView trim_left(bool) constReturns a view with matching characters removed from the beginning. By default, trims whitespace.
StringView trim_right(bool) constReturns a view with matching characters removed from the end. By default, trims whitespace.
Creating New Strings
String upper() constReturns a new string with all ASCII lowercase letters converted to uppercase. Non-ASCII bytes are unchanged.
String lower() constReturns a new string with all ASCII uppercase letters converted to lowercase. Non-ASCII bytes are unchanged.
Array<StringView> split(StringView separator) constSplits the string at each occurrence of
separatorand returns an array of views.String join(ArrayView<const StringView> comps) constJoins an array of string components using this string as the separator.
String operator+(StringView other)Returns a new string with the contents of this string followed by the contents of
other.
Pattern Matching
template <typename... Args> bool match(StringView pattern, const Args&& args)Matches the string against a pattern containing
{}placeholders. If the match succeeds, captured values are written to the output arguments.
String
The String class owns a block of memory allocated from the Plywood heap. The memory is freed when the String object is destroyed.
String objects are movable, copyable and construct to an empty string by default. In addition to the common string functions listed in the previous section, they provide the following member functions:
| Type Conversions | |
| String(StringView other) |
| String(const char* s) |
| operator StringView() const |
| Modifying String Contents | |
void | clear() |
String& | operator+=(StringView other) |
void | resize(u32 num_bytes) |
char* | release() |
| Creating New Strings | |
static String | allocate(u32 num_bytes) |
static String | adopt(char* bytes, u32 num_bytes) |
| Formatting | |
static String | format(StringView fmt, const Args& args) |
static String | from_date_time(const DateTime& date_time) |
Type Conversions
String(StringView other)Constructs a new string by copying the contents of a
StringView.String(const char* s)Constructs a string from a null-terminated C string. The characters are copied into a newly allocated memory block except for the null terminator.
operator StringView() constImplicitly converts the string to a
StringView. This allowsStringobjects to be passed directly to functions that expectStringViewparameters.
Modifying String Contents
void clear()Frees the internal memory block and resets to an empty state.
void operator+=(StringView other)Appends the bytes from
otherto this string, reallocating if necessary.void resize(u32 num_bytes)Resizes the string to the specified length, reallocating if necessary. New bytes are uninitialized.
char* release()Releases ownership of the internal memory block and returns a pointer to it. The caller is responsible for freeing the memory later using
Heap::free.
Creating New Strings
static String allocate(u32 num_bytes)Allocates a new string of the specified size. The contents are uninitialized.
static String adopt(char* bytes, u32 num_bytes)Creates a
Stringobject that takes ownership of an existing buffer. The buffer must have been allocated from the Plywood heap and will be freed when theStringis destroyed.
Formatting
static String format(StringView fmt, const Args& args)Creates a formatted string using
{}placeholders. Arguments are converted to text and substituted in order.[TBD]
static String from_date_time(const DateTime& date_time)Creates a string representation of a
DateTimeobject using a format string. See the Time and Date chapter for format specifiers.
StringView
By convention, Plywood passes StringView to functions by value instead of by reference, since copying a StringView doesn't copy the underlying bytes.
[TBD]
MutStringView
By convention, Plywood passes MutStringView objects to functions by value instead of by reference.
[TBD]