summaryrefslogtreecommitdiffstats
path: root/source/core/slang-string.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'source/core/slang-string.cpp')
-rw-r--r--source/core/slang-string.cpp27
1 files changed, 24 insertions, 3 deletions
diff --git a/source/core/slang-string.cpp b/source/core/slang-string.cpp
index 64b8e4dc1..54703def1 100644
--- a/source/core/slang-string.cpp
+++ b/source/core/slang-string.cpp
@@ -14,8 +14,8 @@ namespace Slang
// OSString
OSString::OSString()
- : m_begin(0)
- , m_end(0)
+ : m_begin(nullptr)
+ , m_end(nullptr)
{}
OSString::OSString(wchar_t* begin, wchar_t* end)
@@ -23,7 +23,7 @@ namespace Slang
, m_end(end)
{}
- OSString::~OSString()
+ void OSString::_releaseBuffer()
{
if (m_begin)
{
@@ -31,6 +31,27 @@ namespace Slang
}
}
+ void OSString::set(const wchar_t* begin, const wchar_t* end)
+ {
+ if (m_begin)
+ {
+ delete[] m_begin;
+ m_begin = nullptr;
+ m_end = nullptr;
+ }
+ const size_t len = end - begin;
+ if (len > 0)
+ {
+ // TODO(JS): The allocation is only done this way to be compatible with the buffer being detached from an array
+ // This is unfortunate, because it means that the allocation stores the size (and alignment fix), which is a shame because we know the size
+ m_begin = new wchar_t[len + 1];
+ memcpy(m_begin, begin, len * sizeof(wchar_t));
+ // Zero terminate
+ m_begin[len] = 0;
+ m_end = m_begin + len;
+ }
+ }
+
static const wchar_t kEmptyOSString[] = { 0 };
wchar_t const* OSString::begin() const