summaryrefslogtreecommitdiffstats
path: root/clang/lib/Lex
diff options
context:
space:
mode:
authorEli Friedman <eli.friedman@gmail.com>2009-06-01 05:25:02 +0000
committerEli Friedman <eli.friedman@gmail.com>2009-06-01 05:25:02 +0000
commitd8cec57b9dc2e39d6c853c28d1062c3a99186883 (patch)
treefa07c73f887c283774104371e010678751bf5499 /clang/lib/Lex
parentcb8317dac955bfd58be4461662b640201c2bba63 (diff)
downloadbcm5719-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.cpp1
-rw-r--r--clang/lib/Lex/PPExpressions.cpp8
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.
OpenPOWER on IntegriCloud