2012-04-18 04:03:03 +08:00
|
|
|
#include "llvm/Support/Locale.h"
|
2013-09-05 00:00:12 +08:00
|
|
|
#include "llvm/Support/Unicode.h"
|
2012-04-18 04:03:03 +08:00
|
|
|
|
2013-09-05 00:00:12 +08:00
|
|
|
namespace llvm {
|
|
|
|
namespace sys {
|
|
|
|
namespace locale {
|
|
|
|
|
|
|
|
int columnWidth(StringRef Text) {
|
|
|
|
#if LLVM_ON_WIN32
|
|
|
|
return Text.size();
|
2012-04-18 04:03:03 +08:00
|
|
|
#else
|
2013-09-05 00:00:12 +08:00
|
|
|
return llvm::sys::unicode::columnWidthUTF8(Text);
|
2012-04-18 04:03:03 +08:00
|
|
|
#endif
|
2013-09-05 00:00:12 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
bool isPrint(int UCS) {
|
|
|
|
#if LLVM_ON_WIN32
|
2015-06-19 09:53:21 +08:00
|
|
|
// Restrict characters that we'll try to print to the lower part of ASCII
|
2013-09-05 00:00:12 +08:00
|
|
|
// except for the control characters (0x20 - 0x7E). In general one can not
|
|
|
|
// reliably output code points U+0080 and higher using narrow character C/C++
|
|
|
|
// output functions in Windows, because the meaning of the upper 128 codes is
|
|
|
|
// determined by the active code page in the console.
|
|
|
|
return ' ' <= UCS && UCS <= '~';
|
|
|
|
#else
|
|
|
|
return llvm::sys::unicode::isPrintable(UCS);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace locale
|
|
|
|
} // namespace sys
|
|
|
|
} // namespace llvm
|