SYNOPSIS

#include <Inventor/SbString.h>

Public Member Functions

SbString (void)

SbString (const char *s)

SbString (const char *s, int start, int end)

SbString (const SbString &s)

SbString (const int digits)

~SbString ()

uint32_t hash (void) const

int getLength (void) const

void makeEmpty (SbBool freeold=TRUE)

const char * getString (void) const

SbString getSubString (int startidx, int endidx=-1) const

void deleteSubString (int startidx, int endidx=-1)

void addIntString (const int value)

char operator[] (int index) const

SbString & operator= (const char *s)

SbString & operator= (const SbString &s)

SbString & operator+= (const char *s)

SbString & operator+= (const SbString &s)

SbString & operator+= (const char c)

int operator! (void) const

int compareSubString (const char *text, int offset=0) const

SbString & sprintf (const char *formatstr,...)

SbString & vsprintf (const char *formatstr, va_list args)

void apply (char(*func)(char input))

int find (const SbString &s) const

SbBool findAll (const SbString &s, SbIntList &found) const

SbString lower () const

SbString upper () const

void print (std::FILE *fp) const

Static Public Member Functions

static uint32_t hash (const char *s)

Friends

int operator== (const SbString &sbstr, const char *s)

int operator== (const char *s, const SbString &sbstr)

int operator== (const SbString &str1, const SbString &str2)

int operator!= (const SbString &sbstr, const char *s)

int operator!= (const char *s, const SbString &sbstr)

int operator!= (const SbString &str1, const SbString &str2)

const SbString operator+ (const SbString &str1, const SbString &str2)

const SbString operator+ (const SbString &sbstr, const char *s)

const SbString operator+ (const char *s, const SbString &sbstr)

Detailed Description

The SbString class is a string class with convenience functions for string operations.

This is the class used for storing and working with character strings. It automatically takes care of supporting all the 'bookkeeping' tasks usually associated with working with character strings, like memory allocation and deallocation etc.

This class should also be well suited for use by the application programmer throughout the application using the Coin library.

See also:

SbName

Constructor & Destructor Documentation

SbString::SbString (void)\fC [inline]\fP

This is the default constructor. It initializes the string to be empty.

SbString::SbString (const char *str)\fC [inline]\fP

This constructor assigns from the given string.

SbString::SbString (const char *str, intstart, intend)\fC [inline]\fP

This constructor constructs a string from the given substring from start to end indices inclusive. If end is -1, the substring from start until the end of the string is used.

SbString::SbString (const \fBSbString\fP &str)\fC [inline]\fP

This is the copy constructor.

SbString::SbString (const intdigits)\fC [inline]\fP

Construct an SbString instance containing the digits of the integer argument.

SbString::~SbString ()\fC [inline]\fP

The destructor. Deallocates any internal resources used during the lifetime of the SbString instance.

Member Function Documentation

uint32_t SbString::hash (void) const\fC [inline]\fP

This method returns a reasonable hash value for the current string.

See also:

uint32_t SbString::hash(const char * s)

uint32_t SbString::hash (const char *s)\fC [inline]\fP, \fC [static]\fP

This static method returns a hash value for the given string.

int SbString::getLength (void) const\fC [inline]\fP

This method returns the length of the string.

void SbString::makeEmpty (SbBoolfreeold = \fCTRUE\fP)\fC [inline]\fP

This method clears the string, making it an empty string (''). If freeold is TRUE (which is the default), the memory used by the old string is freed. Otherwise, memory will be kept and reused when the string is manipulated later.

const char * SbString::getString (void) const\fC [inline]\fP

This method returns the pointer to the string (character array).

\fBSbString\fP SbString::getSubString (intstartidx, intendidx = \fC-1\fP) const\fC [inline]\fP

This method returns a new string which contains a substring defined by the given indices startidx and endidx (inclusive).

If endidx is -1, the substring from startidx to the end of the string is used.

This will return a string which is (endidx - startidx + 1) characters long, i.e. if this string is 'foo/bar' and we call by SbString::getSubString(0, 3), the returned string will be 'foo/'.

void SbString::deleteSubString (intstartidx, intendidx = \fC-1\fP)\fC [inline]\fP

This method deletes the substring defined by startidx and endidx (inclusive). If endidx is -1, the substring from startidx to the end of the string is deleted.

void SbString::addIntString (const intvalue)\fC [inline]\fP

Constructs a string from the given integer (e.g. intToString(42) creates the string '42'), and adds this to the contents of the string.

char SbString::operator[] (intindex) const\fC [inline]\fP

Returns character at position index in the string.

See also:

getSubString()

\fBSbString\fP & SbString::operator= (const char *str)\fC [inline]\fP

This is the assignment operator.

\fBSbString\fP & SbString::operator= (const \fBSbString\fP &str)\fC [inline]\fP

Assign from the given string.

\fBSbString\fP & SbString::operator+= (const char *str)\fC [inline]\fP

Concatenate the given string to the end of the current one.

\fBSbString\fP & SbString::operator+= (const \fBSbString\fP &str)\fC [inline]\fP

Concatenate the given string to the end of the current one.

\fBSbString\fP & SbString::operator+= (const charc)\fC [inline]\fP

Concatenate the given character to the end of the current string.

Note:

This member function is not compatible with OpenInventor.

int SbString::operator! (void) const\fC [inline]\fP

This unary operator results in TRUE if the current string is empty ('') or FALSE otherwise.

int SbString::compareSubString (const char *text, intoffset = \fC0\fP) const\fC [inline]\fP

Uses text as a substring to be compared to the string, starting at offset offset. Return value is 0 upon success, and the failing character comparison difference upon failure.

\fBSbString\fP & SbString::sprintf (const char *formatstr, ...)\fC [inline]\fP

Set SbString instance to the formatted string formatstr, replacing the current contents. The control characters within formatstr and the remaining arguments should follow the conventions of the printf() call.

Note that this function is not part of the original Open Inventor API.

\fBSbString\fP & SbString::vsprintf (const char *formatstr, va_listargs)\fC [inline]\fP

Set SbString instance to the formatted string formatstr, replacing the current contents. The control characters within formatstr and the arguments of the args argument list should follow the conventions of the printf() call.

Note that this function is not part of the original Open Inventor API.

int SbString::find (const \fBSbString\fP &strarg) const

If s is found, the method returns the first index where s starts. Otherwise it returns -1.

Note: SbString::find() is a Coin specific extension to the original Open Inventor API.

See also:

SbString::findAll()

Since:

Coin 2.0

SbBool SbString::findAll (const \fBSbString\fP &strarg, \fBSbIntList\fP &found) const

All occurences of str is represented in found as indices to the characters where str starts. If 1 or more is found, TRUE is returned, else FALSE is returned.

Note: SbString::findAll() is an extension to the original Open Inventor API.

See also:

SbString::find()

Since:

Coin 2.0

\fBSbString\fP SbString::lower () const

Converts all of the characters to lowercase using tolower().

Since:

Coin 3.1

\fBSbString\fP SbString::upper () const

Converts all of the characters to uppercase using toupper().

Since:

Coin 3.1

void SbString::print (std::FILE *fp) const

Dump the state of this object to the file stream. Only works in debug version of library, method does nothing in an optimized compile.

Friends And Related Function Documentation

int operator== (const \fBSbString\fP &str, const char *s)\fC [friend]\fP

Equality operator. Check if the strings have the same contents.

int operator== (const char *s, const \fBSbString\fP &str)\fC [friend]\fP

Equality operator. Check if the strings have the same contents.

int operator== (const \fBSbString\fP &str1, const \fBSbString\fP &str2)\fC [friend]\fP

Equality operator. Check if the strings have the same contents.

int \fBoperator!\fP= (const \fBSbString\fP &str, const char *s)\fC [friend]\fP

Inequality operator.

int \fBoperator!\fP= (const char *s, const \fBSbString\fP &str)\fC [friend]\fP

Inequality operator.

int \fBoperator!\fP= (const \fBSbString\fP &str1, const \fBSbString\fP &str2)\fC [friend]\fP

Inequality operator.

const \fBSbString\fP operator+ (const \fBSbString\fP &str1, const \fBSbString\fP &str2)\fC [friend]\fP

Addition operator.

const \fBSbString\fP operator+ (const \fBSbString\fP &sbstr, const char *s)\fC [friend]\fP

Addition operator.

const \fBSbString\fP operator+ (const char *s, const \fBSbString\fP &sbstr)\fC [friend]\fP

Addition operator.

Author

Generated automatically by Doxygen for Coin from the source code.