diff options
author | Eli Friedman <eli.friedman@gmail.com> | 2009-06-01 05:25:02 +0000 |
---|---|---|
committer | Eli Friedman <eli.friedman@gmail.com> | 2009-06-01 05:25:02 +0000 |
commit | d8cec57b9dc2e39d6c853c28d1062c3a99186883 (patch) | |
tree | fa07c73f887c283774104371e010678751bf5499 /clang/lib/Lex | |
parent | cb8317dac955bfd58be4461662b640201c2bba63 (diff) | |
download | bcm5719-llvm-d8cec57b9dc2e39d6c853c28d1062c3a99186883.tar.gz bcm5719-llvm-d8cec57b9dc2e39d6c853c28d1062c3a99186883.zip |
PR4283: Don't truncate multibyte character constants in the
preprocessor.
llvm-svn: 72686
Diffstat (limited to 'clang/lib/Lex')
-rw-r--r-- | clang/lib/Lex/LiteralSupport.cpp | 1 | ||||
-rw-r--r-- | clang/lib/Lex/PPExpressions.cpp | 8 |
2 files changed, 7 insertions, 2 deletions
diff --git a/clang/lib/Lex/LiteralSupport.cpp b/clang/lib/Lex/LiteralSupport.cpp index 398082ff70c..0324c0b0128 100644 --- a/clang/lib/Lex/LiteralSupport.cpp +++ b/clang/lib/Lex/LiteralSupport.cpp @@ -680,6 +680,7 @@ CharLiteralParser::CharLiteralParser(const char *begin, const char *end, PP.Diag(Loc, diag::ext_multichar_character_literal); else PP.Diag(Loc, diag::ext_four_char_character_literal); + IsMultiChar = true; } // Transfer the value from APInt to uint64_t diff --git a/clang/lib/Lex/PPExpressions.cpp b/clang/lib/Lex/PPExpressions.cpp index 47c3f8d1c70..709e316b803 100644 --- a/clang/lib/Lex/PPExpressions.cpp +++ b/clang/lib/Lex/PPExpressions.cpp @@ -221,8 +221,12 @@ static bool EvaluateValue(PPValue &Result, Token &PeekTok, DefinedTracker &DT, // Character literals are always int or wchar_t, expand to intmax_t. TargetInfo &TI = PP.getTargetInfo(); - unsigned NumBits = TI.getCharWidth(Literal.isWide()); - + unsigned NumBits; + if (Literal.isMultiChar()) + NumBits = TI.getIntWidth(); + else + NumBits = TI.getCharWidth(Literal.isWide()); + // Set the width. llvm::APSInt Val(NumBits); // Set the value. |