diff options
author | Henrik G. Olsson <hnrklssn@gmail.com> | 2025-04-23 20:27:12 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2025-04-23 20:27:12 -0700 |
commit | de1af6b7271c6f4fc67848a849cf8fa6000d2b97 (patch) | |
tree | ce6f998d42af18a7aae9e6c2dc63e5511aad6cda /clang/lib/AST/ExprConstant.cpp | |
parent | ea0dbee80813edf1c8a57d1c1bfd7fadee71d3fa (diff) | |
download | llvm-de1af6b7271c6f4fc67848a849cf8fa6000d2b97.zip llvm-de1af6b7271c6f4fc67848a849cf8fa6000d2b97.tar.gz llvm-de1af6b7271c6f4fc67848a849cf8fa6000d2b97.tar.bz2 |
Eval string one past end reland (#137091)
Relands #137078 after updating clang/test/AST/ByteCode/cxx20.cpp to
account for diagnostic outputs that differ between Linux and macOS.
Diffstat (limited to 'clang/lib/AST/ExprConstant.cpp')
-rw-r--r-- | clang/lib/AST/ExprConstant.cpp | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/clang/lib/AST/ExprConstant.cpp b/clang/lib/AST/ExprConstant.cpp index f598ef59..7c933f4 100644 --- a/clang/lib/AST/ExprConstant.cpp +++ b/clang/lib/AST/ExprConstant.cpp @@ -2232,10 +2232,15 @@ static bool ArePotentiallyOverlappingStringLiterals(const EvalInfo &Info, // within RHS. We don't need to look at the characters of one string that // would appear before the start of the other string if they were merged. CharUnits Offset = RHS.Offset - LHS.Offset; - if (Offset.isNegative()) + if (Offset.isNegative()) { + if (LHSString.Bytes.size() < (size_t)-Offset.getQuantity()) + return false; LHSString.Bytes = LHSString.Bytes.drop_front(-Offset.getQuantity()); - else + } else { + if (RHSString.Bytes.size() < (size_t)Offset.getQuantity()) + return false; RHSString.Bytes = RHSString.Bytes.drop_front(Offset.getQuantity()); + } bool LHSIsLonger = LHSString.Bytes.size() > RHSString.Bytes.size(); StringRef Longer = LHSIsLonger ? LHSString.Bytes : RHSString.Bytes; |