summaryrefslogtreecommitdiffstats
path: root/clang/lib/Lex/DependencyDirectivesSourceMinimizer.cpp
diff options
context:
space:
mode:
authorAlex Lorenz <arphaman@gmail.com>2019-07-10 22:00:59 +0000
committerAlex Lorenz <arphaman@gmail.com>2019-07-10 22:00:59 +0000
commit9a6c17b5b8628f2f9b23eaf4dfdb95862521bf99 (patch)
tree3eb83967bb56a54ec82ad0e744515f2153bb3386 /clang/lib/Lex/DependencyDirectivesSourceMinimizer.cpp
parentd7aae33a9513d29400157867cdc1f11c2e4a0c40 (diff)
downloadbcm5719-llvm-9a6c17b5b8628f2f9b23eaf4dfdb95862521bf99.tar.gz
bcm5719-llvm-9a6c17b5b8628f2f9b23eaf4dfdb95862521bf99.zip
[clang-scan-deps] Dependency directives source minimizer:
single quotes are not digit separators after a valid character literal prefix The single quote character can act as a c++ digit separator. However, the minimizer shouldn't treat it as such when it's actually following a valid character literal prefix, like L, U, u, or u8. Differential Revision: https://reviews.llvm.org/D64525 llvm-svn: 365700
Diffstat (limited to 'clang/lib/Lex/DependencyDirectivesSourceMinimizer.cpp')
-rw-r--r--clang/lib/Lex/DependencyDirectivesSourceMinimizer.cpp9
1 files changed, 8 insertions, 1 deletions
diff --git a/clang/lib/Lex/DependencyDirectivesSourceMinimizer.cpp b/clang/lib/Lex/DependencyDirectivesSourceMinimizer.cpp
index 6d7dfd11459..cfc37c5d3c6 100644
--- a/clang/lib/Lex/DependencyDirectivesSourceMinimizer.cpp
+++ b/clang/lib/Lex/DependencyDirectivesSourceMinimizer.cpp
@@ -262,7 +262,14 @@ static bool isQuoteCppDigitSeparator(const char *const Start,
if (Start == Cur)
return false;
// The previous character must be a valid PP number character.
- if (!isPreprocessingNumberBody(*(Cur - 1)))
+ // Make sure that the L, u, U, u8 prefixes don't get marked as a
+ // separator though.
+ char Prev = *(Cur - 1);
+ if (Prev == 'L' || Prev == 'U' || Prev == 'u')
+ return false;
+ if (Prev == '8' && (Cur - 1 != Start) && *(Cur - 2) == 'u')
+ return false;
+ if (!isPreprocessingNumberBody(Prev))
return false;
// The next character should be a valid identifier body character.
return (Cur + 1) < End && isIdentifierBody(*(Cur + 1));
OpenPOWER on IntegriCloud