mirror of
git://sigrok.org/libserialport
synced 2023-08-10 21:13:24 +03:00
windows: wc_to_utf8: use some clearer variable names.
This commit is contained in:
parent
fdbb55ae1e
commit
6aaf844863
15
windows.c
15
windows.c
@ -28,32 +28,33 @@
|
|||||||
static void enumerate_hub(struct sp_port *port, const char *hub_name,
|
static void enumerate_hub(struct sp_port *port, const char *hub_name,
|
||||||
const char *parent_path, DEVINST dev_inst);
|
const char *parent_path, DEVINST dev_inst);
|
||||||
|
|
||||||
static char *wc_to_utf8(PWCHAR wc_buffer, ULONG size)
|
static char *wc_to_utf8(PWCHAR wc_buffer, ULONG wc_bytes)
|
||||||
{
|
{
|
||||||
ULONG wc_length = size / sizeof(WCHAR);
|
ULONG wc_length = wc_bytes / sizeof(WCHAR);
|
||||||
|
ULONG utf8_bytes;
|
||||||
WCHAR *wc_str = NULL;
|
WCHAR *wc_str = NULL;
|
||||||
char *utf8_str = NULL;
|
char *utf8_str = NULL;
|
||||||
|
|
||||||
/* Allocate aligned wide char buffer */
|
/* Allocate aligned wide char buffer */
|
||||||
if (!(wc_str = malloc(size + sizeof(WCHAR))))
|
if (!(wc_str = malloc((wc_length + 1) * sizeof(WCHAR))))
|
||||||
goto wc_to_utf8_end;
|
goto wc_to_utf8_end;
|
||||||
|
|
||||||
/* Zero-terminate the wide char string. */
|
/* Zero-terminate the wide char string. */
|
||||||
memcpy(wc_str, wc_buffer, size);
|
memcpy(wc_str, wc_buffer, wc_bytes);
|
||||||
wc_str[wc_length] = 0;
|
wc_str[wc_length] = 0;
|
||||||
|
|
||||||
/* Compute the size of the UTF-8 converted string. */
|
/* Compute the size of the UTF-8 converted string. */
|
||||||
if (!(size = WideCharToMultiByte(CP_ACP, WC_NO_BEST_FIT_CHARS, wc_str, -1,
|
if (!(utf8_bytes = WideCharToMultiByte(CP_ACP, WC_NO_BEST_FIT_CHARS, wc_str, -1,
|
||||||
NULL, 0, NULL, NULL)))
|
NULL, 0, NULL, NULL)))
|
||||||
goto wc_to_utf8_end;
|
goto wc_to_utf8_end;
|
||||||
|
|
||||||
/* Allocate UTF-8 output buffer. */
|
/* Allocate UTF-8 output buffer. */
|
||||||
if (!(utf8_str = malloc(size)))
|
if (!(utf8_str = malloc(utf8_bytes)))
|
||||||
goto wc_to_utf8_end;
|
goto wc_to_utf8_end;
|
||||||
|
|
||||||
/* Actually converted to UTF-8. */
|
/* Actually converted to UTF-8. */
|
||||||
if (!WideCharToMultiByte(CP_ACP, WC_NO_BEST_FIT_CHARS, wc_str, -1,
|
if (!WideCharToMultiByte(CP_ACP, WC_NO_BEST_FIT_CHARS, wc_str, -1,
|
||||||
utf8_str, size, NULL, NULL)) {
|
utf8_str, utf8_bytes, NULL, NULL)) {
|
||||||
free(utf8_str);
|
free(utf8_str);
|
||||||
utf8_str = NULL;
|
utf8_str = NULL;
|
||||||
goto wc_to_utf8_end;
|
goto wc_to_utf8_end;
|
||||||
|
Loading…
Reference in New Issue
Block a user