X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/ce65118e6290c24828c81be08149136423daaff2..e39de7022c2fb33d79b4d1770fa6e3911128d2d6:/include/wx/unichar.h diff --git a/include/wx/unichar.h b/include/wx/unichar.h index 6ce0789215..defc237114 100644 --- a/include/wx/unichar.h +++ b/include/wx/unichar.h @@ -96,7 +96,7 @@ public: bool operator&&(bool v) const { return (bool)*this && v; } // Assignment operators: - wxUniChar& operator=(const wxUniChar& c) { m_value = c.m_value; return *this; } + wxUniChar& operator=(const wxUniChar& c) { if (&c != this) m_value = c.m_value; return *this; } wxUniChar& operator=(const wxUniCharRef& c); wxUniChar& operator=(char c) { m_value = From8bit(c); return *this; } wxUniChar& operator=(unsigned char c) { m_value = From8bit((char)c); return *this; } @@ -141,18 +141,26 @@ private: // characters purely for performance reasons static value_type From8bit(char c) { +#if wxUSE_UNICODE if ( (unsigned char)c < 0x80 ) return c; return FromHi8bit(c); +#else + return c; +#endif } static char To8bit(value_type c) { +#if wxUSE_UNICODE if ( c < 0x80 ) return c; return ToHi8bit(c); +#else + return c; +#endif } // helpers of the functions above called to deal with non-ASCII chars @@ -210,7 +218,7 @@ public: #endif wxUniCharRef& operator=(const wxUniCharRef& c) - { return *this = c.UniChar(); } + { if (&c != this) *this = c.UniChar(); return *this; } wxUniCharRef& operator=(char c) { return *this = wxUniChar(c); } wxUniCharRef& operator=(unsigned char c) { return *this = wxUniChar(c); }