Windows.cpp
3.53 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
//===-- Windows.cpp -------------------------------------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
// This file provides Windows support functions
#include "lldb/Host/PosixApi.h"
#include "lldb/Host/windows/windows.h"
#include "llvm/Support/ConvertUTF.h"
#include <assert.h>
#include <cerrno>
#include <ctype.h>
#include <io.h>
#include <stdarg.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
namespace {
bool utf8ToWide(const char *utf8, wchar_t *buf, size_t bufSize) {
const llvm::UTF8 *sourceStart = reinterpret_cast<const llvm::UTF8 *>(utf8);
size_t sourceLen = strlen(utf8) + 1 /* convert null too */;
llvm::UTF16 *target = reinterpret_cast<llvm::UTF16 *>(buf);
llvm::ConversionFlags flags = llvm::strictConversion;
return llvm::ConvertUTF8toUTF16(&sourceStart, sourceStart + sourceLen, &target,
target + bufSize, flags) == llvm::conversionOK;
}
bool wideToUtf8(const wchar_t *wide, char *buf, size_t bufSize) {
const llvm::UTF16 *sourceStart = reinterpret_cast<const llvm::UTF16 *>(wide);
size_t sourceLen = wcslen(wide) + 1 /* convert null too */;
llvm::UTF8 *target = reinterpret_cast<llvm::UTF8 *>(buf);
llvm::ConversionFlags flags = llvm::strictConversion;
return llvm::ConvertUTF16toUTF8(&sourceStart, sourceStart + sourceLen, &target,
target + bufSize, flags) == llvm::conversionOK;
}
}
int vasprintf(char **ret, const char *fmt, va_list ap) {
char *buf;
int len;
size_t buflen;
va_list ap2;
va_copy(ap2, ap);
len = vsnprintf(NULL, 0, fmt, ap2);
if (len >= 0 &&
(buf = (char *)malloc((buflen = (size_t)(len + 1)))) != NULL) {
len = vsnprintf(buf, buflen, fmt, ap);
*ret = buf;
} else {
*ret = NULL;
len = -1;
}
va_end(ap2);
return len;
}
char *strcasestr(const char *s, const char *find) {
char c, sc;
size_t len;
if ((c = *find++) != 0) {
c = tolower((unsigned char)c);
len = strlen(find);
do {
do {
if ((sc = *s++) == 0)
return 0;
} while ((char)tolower((unsigned char)sc) != c);
} while (strncasecmp(s, find, len) != 0);
s--;
}
return const_cast<char *>(s);
}
#ifdef _MSC_VER
char *basename(char *path) {
char *l1 = strrchr(path, '\\');
char *l2 = strrchr(path, '/');
if (l2 > l1)
l1 = l2;
if (!l1)
return path; // no base name
return &l1[1];
}
char *dirname(char *path) {
char *l1 = strrchr(path, '\\');
char *l2 = strrchr(path, '/');
if (l2 > l1)
l1 = l2;
if (!l1)
return NULL; // no dir name
*l1 = 0;
return path;
}
int strcasecmp(const char *s1, const char *s2) { return stricmp(s1, s2); }
int strncasecmp(const char *s1, const char *s2, size_t n) {
return strnicmp(s1, s2, n);
}
#if _MSC_VER < 1900
namespace lldb_private {
int vsnprintf(char *buffer, size_t count, const char *format, va_list argptr) {
int old_errno = errno;
int r = ::vsnprintf(buffer, count, format, argptr);
int new_errno = errno;
buffer[count - 1] = '\0';
if (r == -1 || r == count) {
FILE *nul = fopen("nul", "w");
int bytes_written = ::vfprintf(nul, format, argptr);
fclose(nul);
if (bytes_written < count)
errno = new_errno;
else {
errno = old_errno;
r = bytes_written;
}
}
return r;
}
} // namespace lldb_private
#endif
#endif // _MSC_VER