diff foosdk/sdk/pfc/string-conv-lite.cpp @ 1:20d02a178406 default tip

*: check in everything else yay
author Paper <paper@tflc.us>
date Mon, 05 Jan 2026 02:15:46 -0500
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/foosdk/sdk/pfc/string-conv-lite.cpp	Mon Jan 05 02:15:46 2026 -0500
@@ -0,0 +1,32 @@
+#include "pfc-lite.h"
+#include "string_conv.h"
+#include "string-conv-lite.h"
+
+namespace pfc {
+	wstringLite wideFromUTF8(const char* pUTF8, size_t inSize) {
+		wstringLite ret;
+		size_t estimate = pfc::stringcvt::estimate_utf8_to_wide(pUTF8, inSize);
+		ret.m_buffer.resize(estimate);
+		pfc::stringcvt::convert_utf8_to_wide(ret.m_buffer.get_ptr(), estimate, pUTF8, inSize);
+		return ret;
+	}
+	string8 utf8FromWide(const wchar_t* pWide, size_t inSize) {
+		string8 ret;
+		size_t estimate = pfc::stringcvt::estimate_wide_to_utf8(pWide,inSize);
+		PFC_ASSERT(estimate > 0);
+		char* ptr = ret.lock_buffer(estimate-1/*nullterm included in estimate*/);
+		pfc::stringcvt::convert_wide_to_utf8(ptr, estimate, pWide, inSize);
+		ret.unlock_buffer();
+		return ret;
+	}
+	wstringLite wideFromUTF8(const char* pUTF8) {
+		wstringLite ret;
+		size_t estimate = pfc::stringcvt::estimate_utf8_to_wide(pUTF8);
+		ret.m_buffer.resize(estimate);
+		pfc::stringcvt::convert_utf8_to_wide_unchecked(ret.m_buffer.get_ptr(), pUTF8);
+		return ret;
+	}
+	string8 utf8FromWide(const wchar_t* pWide) {
+		return utf8FromWide(pWide, SIZE_MAX);
+	}
+}