ost::String(3) | Library Functions Manual | ost::String(3) |
NAME¶
ost::String - This is a generic and portable string class.
SYNOPSIS¶
#include <string.h>
Inherited by ost::SString.
Public Types¶
typedef size_t size_type
Public Member Functions¶
String ()
Construct an empty string. String (const String &original)
Copy constructor. String (const char *str)
Create a string from a cstring. String (std::string string)
Create a String from std::string. String (const String
&str, size_t offset, size_t len=npos)
Create a new string from a subset of another string. String (size_t
size, const char *format,...)
Create a string from formatted text input. String (size_t count,
const char fill=' ')
Fill a new string with character data. virtual ~String ()
Destroy the string... const char * getIndex (size_t index) const
Get a string pointer to string content based on an indexed offset. char *
getText (void) const
Get the text of a string. long getValue (long defvalue=0l) const
Get the value of a string. bool getBool (bool defbool=false) const
Get the bool flag of a string. const size_t getLength (void) const
Get the assigned length of string. const size_t getSize (void) const
Get the allocation size of the string variable. bool isEmpty (void)
const
Return true if string is empty. void resize (size_t size)
Re-allocate buffer space for string. void clear (void)
Clear the contents of the entire string. char at (ssize_t offset) const
Return a character at a known offset. unsigned count (const
String &s, size_t offset=0) const
Count the number of occurences of a specific string within our string.
unsigned count (const char *s, size_t offset=0, size_t len=0) const
Count the number of occurrences of a specific text pattern within our string.
String token (const char *delim=' 0r', size_t offset=0)
Extract a new string as a token from the current string. size_t find
(const String &s, size_t offset=0, unsigned instance=1) const
Find the index to the nth instance of a substring in our string. size_t
rfind (const String &s, size_t offset=0) const
Find last occurence of a substring in our string. size_t find (const
char *s, size_t offset=0, size_t len=0, unsigned count=1) const
Find the index to the nth instance of text in our string. size_t rfind
(const char *s, size_t offset=0, size_t len=0) const
Find last occurence of a text in our string. void trim (const char *cs)
Trim trailing characters from a string. void chop (const char *cs)
Chop leading characters from a string. void strip (const char *cs)
Strip lead and trailing characters from a string. void chop (size_t
chars)
Chop n leading characters from a string. void trim (size_t
count)
Trim n trailing characters from a string. void erase (size_t start,
size_t len=npos)
Erase a portion of string. void insert (size_t start, const char
*text, size_t len=0)
Insert text into a string. void insert (size_t start, const
String &str)
Insert other string into our string. void replace (size_t start, size_t
len, const char *text, size_t count=0)
Replace text at a specific position in the string with new text. void
replace (size_t start, size_t len, const String &string)
Replace text at a specific position in the string with new string,. size_t
find (unsigned instance, const char *text, size_t offset=0,
size_t len=0) const
A more convenient version of find for nth occurences, by putting the instance
first. size_t find (unsigned instance, const String
&string, size_t offset=0) const
A more convenient version of find for nth occurences, by putting the instance
first. String substr (size_t start, size_t len) const
Return a new string that contains a specific substring of the current string.
const char *() index (size_t ind) const
Return an indexed string based on the index, such as from a find. void
compact (void)
Reduce the size of the string allocation to the minimum needed based on the
current effective length. char * c_str (void) const
Old ANSI C++ compatible string pointer extraction. operator char * ()
const
Get our string data through dereference operator. bool operator! (void)
const
Logical test for string empty. char * text (void) const
Alternate get text method. char * data (void) const
Alternate get text method. size_t length (void) const
Get length as if null terminated string. size_t size (void) const
Get actual length of string data. size_t capacity (void) const
Get space allocated to hold current string. bool empty (void) const
Return true if string is empty. void append (const char *str, size_t
count=0)
Append text to the end of the current string. void append (size_t
size, const char *format,...)
Append formatted text to the end of the current string. void append
(const char *str, size_t offset, size_t count)
Append text into the current string. void add (char c)
Add a character to the end of a string. void append (const
String &str)
Append string to the end of the current string. const char operator[]
(unsigned ind) const
Extract a character by array indexing. const char * operator= (const
char *str)
Assign our string for c string. String & operator+= (const
String &str)
Append operator. String & operator+= (char c)
Append operator. String & operator+= (const char *str)
Append operator. String & operator+= (const std::string
&str)
Append operator. bool operator< (const String &str) const
bool operator< (const char *str) const
bool operator> (const String &str) const
bool operator> (const char *str) const
bool operator<= (const String &str) const
bool operator<= (const char *str) const
bool operator>= (const String &str) const
bool operator>= (const char *str) const
bool operator== (const String &str) const
bool operator== (const char *str) const
bool operator!= (const String &str) const
bool operator!= (const char *str) const
String & operator+= (int i)
Append operator. String & operator+= (unsigned int i)
String & operator+= (long l)
String & operator+= (unsigned long l)
String & operator+= (float f)
String & operator+= (double d)
String & operator+= (short s)
String & operator+= (unsigned short s)
String & operator= (int i)
Assignment operator. String & operator= (unsigned int i)
String & operator= (long l)
String & operator= (unsigned long l)
String & operator= (float f)
String & operator= (double d)
String & operator= (short s)
String & operator= (unsigned short s)
String & operator= (const String &original)
bool operator*= (const String &str) const
Test if string is contained in our string. bool operator*= (const char
*str) const
Test if text is contained in our string.
Static Public Attributes¶
static const size_t npos
Protected Member Functions¶
bool isBig (void) const
Determine if string is allocated in local variable or an external reference.
const char * set (const char *str, size_t len=0)
Set the content of the string variable to the specified string value, and use
smart re-allocation strategies if appropriate to shrink the size of the
variable. void set (const String &str)
Set the content of the string variable to that of another variable. const char
* set (size_t size, const char *format,...)
Set the content of the string variable to that of a formatted printf style
string. void copy (const String &str)
Impliment the copy constructor, used internally. void init (void)
Used to initialize a string object. size_t setSize (size_t size)
Set the size of allocated space in the string variable (capacity) to a known
value. void setLength (size_t len)
Set the length value of the string content. virtual int compare (const
char *text, size_t len=0, size_t index=0) const
A derivable low level comparison operator. size_t search (const char
*text, size_t clen=0, size_t offset=0) const
An internal method used to search for a substring starting at a known offset.
Static Protected Member Functions¶
static char * getSpace (size_t size)
Used to fetch memory, if needed, based on the size, from the pager, or the
system heap.
Static Protected Attributes¶
static const unsigned minsize
static const unsigned slotsize
static const unsigned pagesize
static const unsigned slotlimit
static const unsigned slotcount
Friends¶
class StringObject
class MemPager
__EXPORT String operator+ (const String &s1,
const String &s2)
Add two strings and return a temporary object. __EXPORT String
operator+ (const String &s1, const char *s2)
__EXPORT String operator+ (const char *s1, const
String &s2)
__EXPORT String operator+ (const String &s1,
const char c2)
__EXPORT String operator+ (const char c1, const
String &s2)
std::istream & getline (std::istream &is, String
&str, char delim, size_t size)
Fetch input from a std::istream into the current string variable until either
the string variable is filled (based on current length) or the deliminator
is read. __EXPORT std::ostream & operator<<
(std::ostream &os, const String &str)
Stream the content of our string variable directly to a C++ streaming source.
std::istream & operator>> (std::istream &is,
String &str)
Stream input into our variable. __EXPORT int strprintf
(String &str, size_t size, const char *format,...)
Print values directly into a string variable.
Detailed Description¶
This is a generic and portable string class.
It uses optimized memory allocation strategies to efficiently handle smaller string content by grouping strings into 32 byte aligned slots that can be re-allocated from a free list directly.
While meant to cover the basic functionality of the ANSI C++ string class in form and function, this class offers some important enhancements, including the ability to derive class type specific versions of itself. The latter might be used to derive a unicode string, a string for data and time data types, or to add case insensitive comparisons, for example.
Author
Generic string class.
Member Typedef Documentation¶
typedef size_t ost::String::size_type¶
Constructor & Destructor Documentation¶
ost::String::String ()¶
Construct an empty string.
ost::String::String (const String & original)¶
Copy constructor.
Parameters
ost::String::String (const char * str)¶
Create a string from a cstring.
Parameters
ost::String::String (std::string string)¶
Create a String from std::string.
Parameters
ost::String::String (const String & str, size_t offset, size_t len = npos)¶
Create a new string from a subset of another string.
Parameters
offset offset to start of data in prior string.
len length of our substring.
ost::String::String (size_t size, const char * format, ...)¶
Create a string from formatted text input.
Parameters
format of data to input.
ost::String::String (size_t count, const char fill = ' ')¶
Fill a new string with character data.
Parameters
fill char to fill string with.
virtual ost::String::~String () [virtual]¶
Destroy the string...
Member Function Documentation¶
void ost::String::add (char c)¶
Add a character to the end of a string.
Parameters
void ost::String::append (const char * str, size_t count = 0)¶
Append text to the end of the current string.
Parameters
count size of text to append.
void ost::String::append (const char * str, size_t offset, size_t count)¶
Append text into the current string.
Parameters
offset offset to overlay.
count size of text to append.
void ost::String::append (const String & str)¶
Append string to the end of the current string.
Parameters
void ost::String::append (size_t size, const char * format, ...)¶
Append formatted text to the end of the current string.
Parameters
format of data to append.
char ost::String::at (ssize_t offset) const¶
Return a character at a known offset.
Returns
char* ost::String::c_str (void) const [inline]¶
Old ANSI C++ compatible string pointer extraction.
Returns
size_t ost::String::capacity (void) const [inline]¶
Get space allocated to hold current string.
Returns
void ost::String::chop (const char * cs) [inline]¶
Chop leading characters from a string.
Parameters
References ost::strchop().
void ost::String::chop (size_t chars) [inline]¶
Chop n leading characters from a string.
Parameters
void ost::String::clear (void)¶
Clear the contents of the entire string.
void ost::String::compact (void) [inline]¶
Reduce the size of the string allocation to the minimum needed based on the current effective length.
virtual int ost::String::compare (const char * text, size_t len = 0, size_t index = 0) const [protected], [virtual]¶
A derivable low level comparison operator. This can be used to create custom comparison data types in derived string classes.
Returns
Parameters
len length of text to compare.
index offset from start of string, used in searchs.
void ost::String::copy (const String & str) [protected]¶
Impliment the copy constructor, used internally. Will always create a minimum sized string allocation.
Parameters
unsigned ost::String::count (const char * s, size_t offset = 0, size_t len = 0) const¶
Count the number of occurrences of a specific text pattern within our string.
Returns
Parameters
offset offset to start from.
len length of text pattern if specified.
unsigned ost::String::count (const String & s, size_t offset = 0) const¶
Count the number of occurences of a specific string within our string.
Returns
Parameters
offset offset to start from.
char* ost::String::data (void) const [inline]¶
Alternate get text method.
Returns
bool ost::String::empty (void) const [inline]¶
Return true if string is empty.
void ost::String::erase (size_t start, size_t len = npos)¶
Erase a portion of string.
Parameters
len number of characters to erase.
size_t ost::String::find (const char * s, size_t offset = 0, size_t len = 0, unsigned count = 1) const¶
Find the index to the nth instance of text in our string.
Returns
Parameters
offset offset to start at.
len size of string text.
count instance to look for.
size_t ost::String::find (const String & s, size_t offset = 0, unsigned instance = 1) const¶
Find the index to the nth instance of a substring in our string.
Returns
Parameters
offset offset to start at.
instance instance to look for.
size_t ost::String::find (unsigned instance, const char * text, size_t offset = 0, size_t len = 0) const [inline]¶
A more convenient version of find for nth occurences, by putting the instance first.
Parameters
text text to look for.
offset offset to start at.
len length of text.
References ost::find().
size_t ost::String::find (unsigned instance, const String & string, size_t offset = 0) const [inline]¶
A more convenient version of find for nth occurences, by putting the instance first.
Parameters
string reference to look for.
offset offset to start at.
References ost::find().
bool ost::String::getBool (bool defbool = false) const¶
Get the bool flag of a string.
Returns
const char* ost::String::getIndex (size_t index) const¶
Get a string pointer to string content based on an indexed offset. A NULL is returned if the index is outsize of range.
Returns
Parameters
const size_t ost::String::getLength (void) const¶
Get the assigned length of string.
Returns
const size_t ost::String::getSize (void) const¶
Get the allocation size of the string variable.
Returns
static char* ost::String::getSpace (size_t size) [static], [protected]¶
Used to fetch memory, if needed, based on the size, from the pager, or the system heap.
Returns
Parameters
char* ost::String::getText (void) const¶
Get the text of a string.
Returns
long ost::String::getValue (long defvalue = 0l) const¶
Get the value of a string.
Returns
const char*() ost::String::index (size_t ind) const [inline]¶
Return an indexed string based on the index, such as from a find. If out of range, a NULL string is returned.
Returns
Parameters
void ost::String::init (void) [protected]¶
Used to initialize a string object.
void ost::String::insert (size_t start, const char * text, size_t len = 0)¶
Insert text into a string.
Parameters
text text to insert.
len size of text to insert.
void ost::String::insert (size_t start, const String & str)¶
Insert other string into our string.
Parameters
str string to insert.
bool ost::String::isBig (void) const [inline], [protected]¶
Determine if string is allocated in local variable or an external reference.
Returns
bool ost::String::isEmpty (void) const¶
Return true if string is empty.
Returns
size_t ost::String::length (void) const [inline]¶
Get length as if null terminated string.
Returns
ost::String::operator char * () const [inline]¶
Get our string data through dereference operator.
Returns
bool ost::String::operator! (void) const [inline]¶
Logical test for string empty.
Returns
bool ost::String::operator!= (const char * str) const¶
bool ost::String::operator!= (const String & str) const¶
bool ost::String::operator*= (const char * str) const¶
Test if text is contained in our string.
bool ost::String::operator*= (const String & str) const¶
Test if string is contained in our string.
String& ost::String::operator+= (char c) [inline]¶
Append operator.
String& ost::String::operator+= (const char * str) [inline]¶
Append operator.
String& ost::String::operator+= (const std::string & str) [inline]¶
Append operator.
String& ost::String::operator+= (const String & str) [inline]¶
Append operator.
String& ost::String::operator+= (double d) [inline]¶
String& ost::String::operator+= (float f) [inline]¶
String& ost::String::operator+= (int i) [inline]¶
Append operator.
String& ost::String::operator+= (long l) [inline]¶
String& ost::String::operator+= (short s) [inline]¶
String& ost::String::operator+= (unsigned int i) [inline]¶
String& ost::String::operator+= (unsigned long l) [inline]¶
String& ost::String::operator+= (unsigned short s) [inline]¶
bool ost::String::operator< (const char * str) const¶
bool ost::String::operator< (const String & str) const¶
bool ost::String::operator<= (const char * str) const¶
bool ost::String::operator<= (const String & str) const¶
const char* ost::String::operator= (const char * str) [inline]¶
Assign our string for c string.
String& ost::String::operator= (const String & original) [inline]¶
String& ost::String::operator= (double d) [inline]¶
String& ost::String::operator= (float f) [inline]¶
String& ost::String::operator= (int i) [inline]¶
Assignment operator.
String& ost::String::operator= (long l) [inline]¶
String& ost::String::operator= (short s) [inline]¶
String& ost::String::operator= (unsigned int i) [inline]¶
String& ost::String::operator= (unsigned long l) [inline]¶
String& ost::String::operator= (unsigned short s) [inline]¶
bool ost::String::operator== (const char * str) const¶
bool ost::String::operator== (const String & str) const¶
bool ost::String::operator> (const char * str) const¶
bool ost::String::operator> (const String & str) const¶
bool ost::String::operator>= (const char * str) const¶
bool ost::String::operator>= (const String & str) const¶
const char ost::String::operator[] (unsigned ind) const [inline]¶
Extract a character by array indexing.
Returns
void ost::String::replace (size_t start, size_t len, const char * text, size_t count = 0)¶
Replace text at a specific position in the string with new text.
Parameters
len length of text to remove.
text text to replace with.
count size of replacement text.
void ost::String::replace (size_t start, size_t len, const String & string)¶
Replace text at a specific position in the string with new string,.
Parameters
len length of text to remove.
string reference to replace with.
void ost::String::resize (size_t size)¶
Re-allocate buffer space for string.
Parameters
size_t ost::String::rfind (const char * s, size_t offset = 0, size_t len = 0) const¶
Find last occurence of a text in our string.
Returns
Parameters
offset offset to start from.
len size of string to look for.
size_t ost::String::rfind (const String & s, size_t offset = 0) const¶
Find last occurence of a substring in our string.
Returns
Parameters
offset offset to start from.
size_t ost::String::search (const char * text, size_t clen = 0, size_t offset = 0) const [protected]¶
An internal method used to search for a substring starting at a known offset. Used by find and count methods.
Returns
Parameters
clen length of search text.
offset offset to start from.
const char* ost::String::set (const char * str, size_t len = 0) [protected]¶
Set the content of the string variable to the specified string value, and use smart re-allocation strategies if appropriate to shrink the size of the variable.
Parameters
len length of string if passed.
void ost::String::set (const String & str) [protected]¶
Set the content of the string variable to that of another variable. Uses the string set method.
Parameters
const char* ost::String::set (size_t size, const char * format, ...) [protected]¶
Set the content of the string variable to that of a formatted printf style string.
Parameters
format of string to write into object.
void ost::String::setLength (size_t len) [protected]¶
Set the length value of the string content.
Parameters
size_t ost::String::setSize (size_t size) [protected]¶
Set the size of allocated space in the string variable (capacity) to a known value. The value is recomputed and adjusted based on allocation method.
Parameters
size_t ost::String::size (void) const [inline]¶
Get actual length of string data.
Returns
void ost::String::strip (const char * cs)¶
Strip lead and trailing characters from a string.
Parameters
String ost::String::substr (size_t start, size_t len) const [inline]¶
Return a new string that contains a specific substring of the current string.
Returns
Parameters
len length of substring.
char* ost::String::text (void) const [inline]¶
Alternate get text method.
Returns
String ost::String::token (const char * delim = ' 0r', size_t offset = 0)¶
Extract a new string as a token from the current string.
Returns
Parameters
offset offset to start from.
void ost::String::trim (const char * cs) [inline]¶
Trim trailing characters from a string.
Parameters
References ost::strtrim().
void ost::String::trim (size_t count)¶
Trim n trailing characters from a string.
Parameters
Friends And Related Function Documentation¶
std::istream& getline (std::istream & is, String & str, char delim, size_t size) [friend]¶
Fetch input from a std::istream into the current string variable until either the string variable is filled (based on current length) or the deliminator is read.
Parameters
str string to save into.
delim deliminator to use.
size optional size limitor.
friend class MemPager [friend]¶
__EXPORT String operator+ (const char * s1, const String & s2) [friend]¶
__EXPORT String operator+ (const char c1, const String & s2) [friend]¶
__EXPORT String operator+ (const String & s1, const char * s2) [friend]¶
__EXPORT String operator+ (const String & s1, const char c2) [friend]¶
__EXPORT String operator+ (const String & s1, const String & s2) [friend]¶
Add two strings and return a temporary object.
__EXPORT std::ostream& operator<< (std::ostream & os, const String & str) [friend]¶
Stream the content of our string variable directly to a C++ streaming source.
std::istream& operator>> (std::istream & is, String & str) [friend]¶
Stream input into our variable.
friend class StringObject [friend]¶
__EXPORT int strprintf (String & str, size_t size, const char * format, ...) [friend]¶
Print values directly into a string variable.
Returns
Parameters
size of string required.
format of data.
Member Data Documentation¶
bool ost::String::big¶
struct { ... } ost::String::bigstring¶
size_t ost::String::length¶
char ost::String::length¶
struct { ... } ost::String::ministring¶
const unsigned ost::String::minsize [static], [protected]¶
const size_t ost::String::npos [static]¶
const unsigned ost::String::pagesize [static], [protected]¶
size_t ost::String::size¶
const unsigned ost::String::slotcount [static], [protected]¶
const unsigned ost::String::slotlimit [static], [protected]¶
const unsigned ost::String::slotsize [static], [protected]¶
char* ost::String::text¶
char ost::String::text[(sizeof(char *)+(sizeof(size_t) *2)+1)]¶
Author¶
Generated automatically by Doxygen for GNU CommonC++ from the source code.
Sun Dec 27 2020 | GNU CommonC++ |