From 196e10bbea8c6692530945a518ab1369cddd4dc3 Mon Sep 17 00:00:00 2001 From: Michael Hansen Date: Fri, 2 Jan 2015 18:58:55 -0800 Subject: [PATCH] Don't store the '\0' as part of the string when constructing literals --- Sources/Plasma/CoreLib/plString.h | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Sources/Plasma/CoreLib/plString.h b/Sources/Plasma/CoreLib/plString.h index efad1b0f..536031ea 100644 --- a/Sources/Plasma/CoreLib/plString.h +++ b/Sources/Plasma/CoreLib/plString.h @@ -279,7 +279,7 @@ public: * conversion from ISO-8859-1 8-bit data, use FromIso8859_1(). */ template - plString(const char (&literal)[_Sz]) { IConvertFromUtf8(literal, _Sz); } + plString(const char (&literal)[_Sz]) { IConvertFromUtf8(literal, _Sz - 1); } /** Copy constructor. */ plString(const plString ©) : fUtf8Buffer(copy.fUtf8Buffer) { } @@ -304,7 +304,7 @@ public: /** Assignment operator. Same as plString(const char (&)[_Sz]). */ template - plString &operator=(const char (&literal)[_Sz]) { IConvertFromUtf8(literal, _Sz); return *this; } + plString &operator=(const char (&literal)[_Sz]) { IConvertFromUtf8(literal, _Sz - 1); return *this; } /** Assignment operator. Same as plString(const plString &). */ plString &operator=(const plString ©) { fUtf8Buffer = copy.fUtf8Buffer; return *this; }