|  | 
|  | ustring () | 
|  | 
|  | ~ustring () noexcept | 
|  | 
|  | ustring (const ustring & other) | 
|  | 
|  | ustring (ustring && other) | 
|  | 
| ustring & | operator= (const ustring & other) | 
|  | 
| ustring & | operator= (ustring && other) | 
|  | 
| void | swap (ustring & other) | 
|  | 
|  | ustring (const std::string & src) | 
|  | 
|  | ustring (std::string && src) | 
|  | 
|  | ustring (const ustring & src, size_type i, size_type n=npos) | 
|  | 
|  | ustring (const char * src, size_type n) | 
|  | 
|  | ustring (const char * src) | 
|  | 
|  | ustring (size_type n, gunichar uc) | 
|  | 
|  | ustring (size_type n, char c) | 
|  | 
| template<class In > | 
|  | ustring (In pbegin, In pend) | 
|  | 
|  | 
| ustring & | operator= (const std::string & src) | 
|  | 
| ustring & | operator= (std::string && src) | 
|  | 
| ustring & | operator= (const char * src) | 
|  | 
| ustring & | operator= (gunichar uc) | 
|  | 
| ustring & | operator= (char c) | 
|  | 
| ustring & | assign (const ustring & src) | 
|  | 
| ustring & | assign (ustring && src) | 
|  | 
| ustring & | assign (const ustring & src, size_type i, size_type n) | 
|  | 
| ustring & | assign (const char * src, size_type n) | 
|  | 
| ustring & | assign (const char * src) | 
|  | 
| ustring & | assign (size_type n, gunichar uc) | 
|  | 
| ustring & | assign (size_type n, char c) | 
|  | 
| template<class In > | 
| ustring & | assign (In pbegin, In pend) | 
|  | 
|  | 
| ustring & | operator+= (const ustring & src) | 
|  | 
| ustring & | operator+= (const char * src) | 
|  | 
| ustring & | operator+= (gunichar uc) | 
|  | 
| ustring & | operator+= (char c) | 
|  | 
| void | push_back (gunichar uc) | 
|  | 
| void | push_back (char c) | 
|  | 
| ustring & | append (const ustring & src) | 
|  | 
| ustring & | append (const ustring & src, size_type i, size_type n) | 
|  | 
| ustring & | append (const char * src, size_type n) | 
|  | 
| ustring & | append (const char * src) | 
|  | 
| ustring & | append (size_type n, gunichar uc) | 
|  | 
| ustring & | append (size_type n, char c) | 
|  | 
| template<class In > | 
| ustring & | append (In pbegin, In pend) | 
|  | 
|  | 
| ustring & | insert (size_type i, const ustring & src) | 
|  | 
| ustring & | insert (size_type i, const ustring & src, size_type i2, size_type n) | 
|  | 
| ustring & | insert (size_type i, const char * src, size_type n) | 
|  | 
| ustring & | insert (size_type i, const char * src) | 
|  | 
| ustring & | insert (size_type i, size_type n, gunichar uc) | 
|  | 
| ustring & | insert (size_type i, size_type n, char c) | 
|  | 
| iterator | insert (iterator p, gunichar uc) | 
|  | 
| iterator | insert (iterator p, char c) | 
|  | 
| void | insert (iterator p, size_type n, gunichar uc) | 
|  | 
| void | insert (iterator p, size_type n, char c) | 
|  | 
| template<class In > | 
| void | insert (iterator p, In pbegin, In pend) | 
|  | 
|  | 
| ustring & | replace (size_type i, size_type n, const ustring & src) | 
|  | 
| ustring & | replace (size_type i, size_type n, const ustring & src, size_type i2, size_type n2) | 
|  | 
| ustring & | replace (size_type i, size_type n, const char * src, size_type n2) | 
|  | 
| ustring & | replace (size_type i, size_type n, const char * src) | 
|  | 
| ustring & | replace (size_type i, size_type n, size_type n2, gunichar uc) | 
|  | 
| ustring & | replace (size_type i, size_type n, size_type n2, char c) | 
|  | 
| ustring & | replace (iterator pbegin, iterator pend, const ustring & src) | 
|  | 
| ustring & | replace (iterator pbegin, iterator pend, const char * src, size_type n) | 
|  | 
| ustring & | replace (iterator pbegin, iterator pend, const char * src) | 
|  | 
| ustring & | replace (iterator pbegin, iterator pend, size_type n, gunichar uc) | 
|  | 
| ustring & | replace (iterator pbegin, iterator pend, size_type n, char c) | 
|  | 
| template<class In > | 
| ustring & | replace (iterator pbegin, iterator pend, In pbegin2, In pend2) | 
|  | 
|  | 
| void | clear () | 
|  | 
| ustring & | erase (size_type i, size_type n=npos) | 
|  | 
| ustring & | erase () | 
|  | 
| iterator | erase (iterator p) | 
|  | 
| iterator | erase (iterator pbegin, iterator pend) | 
|  | 
|  | 
| int | compare (UStringView rhs) const | 
|  | 
| int | compare (size_type i, size_type n, UStringView rhs) const | 
|  | 
| int | compare (size_type i, size_type n, const ustring & rhs, size_type i2, size_type n2) const | 
|  | 
| int | compare (size_type i, size_type n, const char * rhs, size_type n2) const | 
|  | 
| std::string | collate_key () const | 
|  | 
| std::string | casefold_collate_key () const | 
|  | 
|  | 
| value_type | operator[] (size_type i) const | 
|  | 
| value_type | at (size_type i) const | 
|  | 
| ustring | substr (size_type i=0, size_type n=npos) const | 
|  | 
|  | 
| iterator | begin () | 
|  | 
| iterator | end () | 
|  | 
| const_iterator | begin () const | 
|  | 
| const_iterator | end () const | 
|  | 
| reverse_iterator | rbegin () | 
|  | 
| reverse_iterator | rend () | 
|  | 
| const_reverse_iterator | rbegin () const | 
|  | 
| const_reverse_iterator | rend () const | 
|  | 
| const_iterator | cbegin () const | 
|  | 
| const_iterator | cend () const | 
|  | 
|  | 
| size_type | find (const ustring & str, size_type i=0) const | 
|  | 
| size_type | find (const char * str, size_type i, size_type n) const | 
|  | 
| size_type | find (const char * str, size_type i=0) const | 
|  | 
| size_type | find (gunichar uc, size_type i=0) const | 
|  | 
| size_type | find (char c, size_type i=0) const | 
|  | 
| size_type | rfind (const ustring & str, size_type i=npos) const | 
|  | 
| size_type | rfind (const char * str, size_type i, size_type n) const | 
|  | 
| size_type | rfind (const char * str, size_type i=npos) const | 
|  | 
| size_type | rfind (gunichar uc, size_type i=npos) const | 
|  | 
| size_type | rfind (char c, size_type i=npos) const | 
|  | 
|  | 
| size_type | find_first_of (const ustring & match, size_type i=0) const | 
|  | 
| size_type | find_first_of (const char * match, size_type i, size_type n) const | 
|  | 
| size_type | find_first_of (const char * match, size_type i=0) const | 
|  | 
| size_type | find_first_of (gunichar uc, size_type i=0) const | 
|  | 
| size_type | find_first_of (char c, size_type i=0) const | 
|  | 
| size_type | find_last_of (const ustring & match, size_type i=npos) const | 
|  | 
| size_type | find_last_of (const char * match, size_type i, size_type n) const | 
|  | 
| size_type | find_last_of (const char * match, size_type i=npos) const | 
|  | 
| size_type | find_last_of (gunichar uc, size_type i=npos) const | 
|  | 
| size_type | find_last_of (char c, size_type i=npos) const | 
|  | 
| size_type | find_first_not_of (const ustring & match, size_type i=0) const | 
|  | 
| size_type | find_first_not_of (const char * match, size_type i, size_type n) const | 
|  | 
| size_type | find_first_not_of (const char * match, size_type i=0) const | 
|  | 
| size_type | find_first_not_of (gunichar uc, size_type i=0) const | 
|  | 
| size_type | find_first_not_of (char c, size_type i=0) const | 
|  | 
| size_type | find_last_not_of (const ustring & match, size_type i=npos) const | 
|  | 
| size_type | find_last_not_of (const char * match, size_type i, size_type n) const | 
|  | 
| size_type | find_last_not_of (const char * match, size_type i=npos) const | 
|  | 
| size_type | find_last_not_of (gunichar uc, size_type i=npos) const | 
|  | 
| size_type | find_last_not_of (char c, size_type i=npos) const | 
|  | 
|  | 
| bool | empty () const | 
|  | Returns true if the string is empty.  More... 
 | 
|  | 
| size_type | size () const | 
|  | Returns the number of characters in the string, not including any null-termination.  More... 
 | 
|  | 
| size_type | length () const | 
|  | This is the same as size().  More... 
 | 
|  | 
| size_type | bytes () const | 
|  | Returns the number of bytes in the string, not including any null-termination.  More... 
 | 
|  | 
|  | 
| void | resize (size_type n, gunichar uc) | 
|  | 
| void | resize (size_type n, char c='\0') | 
|  | 
|  | 
| size_type | capacity () const | 
|  | 
| size_type | max_size () const | 
|  | 
| void | reserve (size_type n=0) | 
|  | 
|  | 
|  | operator std::string () const | 
|  | 
| const std::string & | raw () const | 
|  | 
| std::string | release () | 
|  | 
| const char * | data () const | 
|  | 
| const char * | c_str () const | 
|  | 
| size_type | copy (char * dest, size_type n, size_type i=0) const | 
|  | 
|  | 
| bool | validate () const | 
|  | 
| bool | validate (iterator & first_invalid) | 
|  | 
| bool | validate (const_iterator & first_invalid) const | 
|  | 
| ustring | make_valid () const | 
|  | 
| bool | is_ascii () const | 
|  | 
| ustring | normalize (NormalizeMode mode=NormalizeMode::DEFAULT_COMPOSE) const | 
|  | 
| ustring | truncate_middle (gsize truncate_length) const | 
|  | 
|  | 
| ustring | uppercase () const | 
|  | 
| ustring | lowercase () const | 
|  | 
| ustring | casefold () const | 
|  | 
|  | 
| (Note that these are not member functions.)  | 
| std::istream & | operator>> (std::istream & is, Glib::ustring & utf8_string) | 
|  | Stream input operator.  More... 
 | 
|  | 
| std::ostream & | operator<< (std::ostream & os, const Glib::ustring & utf8_string) | 
|  | Stream output operator.  More... 
 | 
|  | 
| std::wistream & | operator>> (std::wistream & is, ustring & utf8_string) | 
|  | Wide stream input operator.  More... 
 | 
|  | 
| std::wostream & | operator<< (std::wostream & os, const ustring & utf8_string) | 
|  | Wide stream output operator.  More... 
 | 
|  | 
| void | swap (ustring & lhs, ustring & rhs) | 
|  | 
| template<typename T , typename  = std::enable_if_t<!std::is_base_of_v<ustring, T>>> | 
| bool | operator== (const ustring & lhs, const T & rhs) | 
|  | 
| bool | operator== (UStringView lhs, const ustring & rhs) | 
|  | 
| template<typename T , typename  = std::enable_if_t<!std::is_base_of_v<ustring, T>>> | 
| bool | operator!= (const ustring & lhs, const T & rhs) | 
|  | 
| bool | operator!= (UStringView lhs, const ustring & rhs) | 
|  | 
| template<typename T , typename  = std::enable_if_t<!std::is_base_of_v<ustring, T>>> | 
| bool | operator< (const ustring & lhs, const T & rhs) | 
|  | 
| bool | operator< (UStringView lhs, const ustring & rhs) | 
|  | 
| template<typename T , typename  = std::enable_if_t<!std::is_base_of_v<ustring, T>>> | 
| bool | operator> (const ustring & lhs, const T & rhs) | 
|  | 
| bool | operator> (UStringView lhs, const ustring & rhs) | 
|  | 
| template<typename T , typename  = std::enable_if_t<!std::is_base_of_v<ustring, T>>> | 
| bool | operator<= (const ustring & lhs, const T & rhs) | 
|  | 
| bool | operator<= (UStringView lhs, const ustring & rhs) | 
|  | 
| template<typename T , typename  = std::enable_if_t<!std::is_base_of_v<ustring, T>>> | 
| bool | operator>= (const ustring & lhs, const T & rhs) | 
|  | 
| bool | operator>= (UStringView lhs, const ustring & rhs) | 
|  | 
| ustring | operator+ (const ustring & lhs, const ustring & rhs) | 
|  | 
| ustring | operator+ (const ustring & lhs, const char * rhs) | 
|  | 
| ustring | operator+ (const char * lhs, const ustring & rhs) | 
|  | 
| ustring | operator+ (const ustring & lhs, gunichar rhs) | 
|  | 
| ustring | operator+ (gunichar lhs, const ustring & rhs) | 
|  | 
| ustring | operator+ (const ustring & lhs, char rhs) | 
|  | 
| ustring | operator+ (char lhs, const ustring & rhs) | 
|  | 
Glib::ustring has much the same interface as std::string, but contains Unicode characters encoded as UTF-8. 
- About UTF-8 and ASCII
- The standard character set ANSI_X3.4-1968 – more commonly known as ASCII – is a subset of UTF-8. So, if you want to, you can use Glib::ustring without even thinking about UTF-8. 
- Whenever ASCII is mentioned in this manual, we mean the real ASCII (i.e. as defined in ANSI_X3.4-1968), which contains only 7-bit characters. Glib::ustring can not be used with ASCII-compatible extended 8-bit charsets like ISO-8859-1. It's a good idea to avoid string literals containing non-ASCII characters (e.g. German umlauts) in source code, or at least you should use UTF-8 literals. 
- You can find a detailed UTF-8 and Unicode FAQ here: http://www.cl.cam.ac.uk/~mgk25/unicode.html
- Glib::ustring vs. std::string
- Glib::ustring has implicit type conversions to and from std::string. These conversions do not convert to/from the current locale (see Glib::locale_from_utf8() and Glib::locale_to_utf8() if you need that). You can always use std::string instead of Glib::ustring – however, using std::string with multi-byte characters is quite hard. For instance, std::string::operator[]might return a byte in the middle of a character, andstd::string::length()returns the number of bytes rather than characters. So don't do that without a good reason.
- You cannot always use Glib::ustring instead of std::string. 
constexpr void replace(_ForwardIterator __first, _ForwardIterator __last, const _Tp &__old_value, const _Tp &__new_value) 
Glib::ustring has much the same interface as std::string, but contains Unicode characters encoded as ... Definition: ustring.h:336 
 You can't use a Glib::ustring::iterator for writing to a Glib::ustring. See the documentation of Glib::ustring_Iterator for differences between it and std::string::iterator.
- Many member functions and operators of Glib::ustring and Glib::ustring_Iterator assume that the string contains only valid UTF-8 data. If it does not, memory outside the bounds of the string can be accessed. If you're uncertain, use validate() and/or make_valid(). 
- In a perfect world the C++ Standard Library would contain a UTF-8 string class. Unfortunately, the C++98 standard doesn't mention UTF-8 at all. C++11 has UTF-8 literals but no UTF-8 string class. Note that std::wstring is not a UTF-8 string class because it contains only fixed-width characters (where width could be 32, 16, or even 8 bits).
- Glib::ustring and stream input/output
- The stream I/O operators, that is operator<<() and operator>>(), perform implicit charset conversion to/from the current locale. If that's not what you intended (e.g. when writing to a configuration file that should always be UTF-8 encoded) use ustring::raw() to override this behaviour. 
- If you're using std::ostringstream to build strings for display in the user interface, you must convert the result back to UTF-8 as shown below: 
                                                                              output << percentage << " % done"; __string_type str() const 
static locale global(const locale &__loc) 
Glib::ustring locale_to_utf8(const std::string &opsys_string) Convert from the current locale's encoding to UTF-8. 
 
- Formatted output and internationalization
- The methods ustring::compose() and ustring::format() provide a convenient and powerful alternative to string streams, as shown in the example below. Refer to the method documentation of compose() and format() for details. 
  ios_base & hex(ios_base &__base) 
static ustring compose(const ustring &fmt) 
static ustring format(const Ts &... args) 
 
- Glib::ustring as key in unordered associative containers
- To use e.g. std::unordered_map<Glib::ustring, int> there must be a std::hash<Glib::ustring> specialization. Since glibmm 2.78 there is such a specialization in glibmm, but it's available only if you include the ustring_hash.h file. #include <glibmm/ustring_hash.h> 
- Implementation notes
- Glib::ustring does not inherit from std::string, because std::string was intended to be a final class. For instance, it does not have a virtual destructor. Also, a HAS-A relationship is more appropriate because ustring can't just enhance the std::string interface. Rather, it has to reimplement the interface so that all operations are based on characters instead of bytes.