summaryrefslogtreecommitdiff
path: root/new/text_windows.c
diff options
context:
space:
mode:
authorPietro Gagliardi <[email protected]>2015-04-09 09:23:44 -0400
committerPietro Gagliardi <[email protected]>2015-04-09 09:24:08 -0400
commit1f18d88f565844436fb4487b596175ba48138c05 (patch)
tree39aaac35a85e48e572f7f4d7b3798fcf7289c116 /new/text_windows.c
parent723f2af8c621525848a234d88d98b5107cf0d683 (diff)
Split toUTF16() into a new file; other Windows text functions will also be there.
Diffstat (limited to 'new/text_windows.c')
-rw-r--r--new/text_windows.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/new/text_windows.c b/new/text_windows.c
new file mode 100644
index 0000000..e483a95
--- /dev/null
+++ b/new/text_windows.c
@@ -0,0 +1,18 @@
+// 9 april 2015
+#include "uipriv_windows.h"
+
+#define MBTWC(str, wstr, bufsiz) MultiByteToWideChar(CP_UTF8, 0, str, -1, wstr, bufsiz)
+
+WCHAR *toUTF16(const char *str)
+{
+ WCHAR *wstr;
+ int n;
+
+ n = MBTWC(str, NULL, 0);
+ if (n == 0)
+ logLastError("error figuring out number of characters to convert to in toUTF16()");
+ wstr = (WCHAR *) uiAlloc(n * sizeof (WCHAR), "WCHAR[]");
+ if (MBTWC(str, wstr, n) != n)
+ logLastError("error converting from UTF-8 to UTF-16 in toUTF16()");
+ return wstr;
+}