[ADT] Replace std::isprint by llvm::isPrint.
authorMichael Kruse <llvm@meinersbur.de>
Thu, 26 Jul 2018 15:31:41 +0000 (15:31 +0000)
committerMichael Kruse <llvm@meinersbur.de>
Thu, 26 Jul 2018 15:31:41 +0000 (15:31 +0000)
commit6f1da6e345ccf89a7a0d0bc964bee7f1eb7ed9f6
tree1465f700b8ebf02710fb2c9734ebd1d8972f0b91
parenteda3c9efa2bfc2dad3d8cde62334577cee1d9d6b
[ADT] Replace std::isprint by llvm::isPrint.

The standard library functions ::isprint/std::isprint have platform-
and locale-dependent behavior which makes LLVM's output less
predictable. In particular, regression tests my fail depending on the
implementation of these functions.

Implement llvm::isPrint in StringExtras.h with a standard behavior and
replace all uses of ::isprint/std::isprint by a call it llvm::isPrint.
The function is inlined and does not look up language settings so it
should perform better than the standard library's version.

Such a replacement has already been done for isdigit, isalpha, isxdigit
in r314883. gtest does the same in gtest-printers.cc using the following
justification:

    // Returns true if c is a printable ASCII character.  We test the
    // value of c directly instead of calling isprint(), which is buggy on
    // Windows Mobile.
    inline bool IsPrintableAscii(wchar_t c) {
      return 0x20 <= c && c <= 0x7E;
    }

Similar issues have also been encountered by Julia:
https://github.com/JuliaLang/julia/issues/7416

I noticed the problem myself when on Windows isprint('\t') started to
evaluate to true (see https://stackoverflow.com/questions/51435249) and
thus caused several unit tests to fail. The result of isprint doesn't
seem to be well-defined even for ASCII characters. Therefore I suggest
to replace isprint by a platform-independent version.

Differential Revision: https://reviews.llvm.org/D49680

llvm-svn: 338034
llvm/include/llvm/ADT/StringExtras.h
llvm/include/llvm/Support/raw_ostream.h
llvm/lib/MC/MCAsmStreamer.cpp
llvm/lib/ProfileData/InstrProfReader.cpp
llvm/lib/Support/StringExtras.cpp
llvm/lib/Support/raw_ostream.cpp
llvm/lib/Support/regengine.inc
llvm/tools/llvm-bcanalyzer/llvm-bcanalyzer.cpp
llvm/tools/llvm-objdump/llvm-objdump.cpp
llvm/tools/llvm-readobj/ObjDumper.cpp
llvm/unittests/ADT/StringExtrasTest.cpp