diff options
author | martinboehme <mboehme@google.com> | 2024-06-11 08:38:03 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-06-11 08:38:03 +0200 |
commit | 282534268e3be0949fcac1589b1004bc5672b434 (patch) | |
tree | e99de5de4e43525298d626fff2c2edb59e689c28 /clang/lib/Analysis/FlowSensitive/DataflowEnvironment.cpp | |
parent | 876c6204f12fa2738ff8ca886e664b826847d6d4 (diff) | |
download | llvm-282534268e3be0949fcac1589b1004bc5672b434.zip llvm-282534268e3be0949fcac1589b1004bc5672b434.tar.gz llvm-282534268e3be0949fcac1589b1004bc5672b434.tar.bz2 |
[clang][dataflow] Handle `AtomicExpr` in `ResultObjectVisitor`. (#94963)
This is one of the node kinds that should be considered an "original
initializer". The patch adds a test that was causing an assertion
failure in
`assert(Children.size() == 1)` without the fix.
Diffstat (limited to 'clang/lib/Analysis/FlowSensitive/DataflowEnvironment.cpp')
-rw-r--r-- | clang/lib/Analysis/FlowSensitive/DataflowEnvironment.cpp | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/clang/lib/Analysis/FlowSensitive/DataflowEnvironment.cpp b/clang/lib/Analysis/FlowSensitive/DataflowEnvironment.cpp index 0d7967c..7c88917 100644 --- a/clang/lib/Analysis/FlowSensitive/DataflowEnvironment.cpp +++ b/clang/lib/Analysis/FlowSensitive/DataflowEnvironment.cpp @@ -415,7 +415,7 @@ public: // below them can initialize the same object (or part of it). if (isa<CXXConstructExpr>(E) || isa<CallExpr>(E) || isa<LambdaExpr>(E) || isa<CXXDefaultArgExpr>(E) || isa<CXXDefaultInitExpr>(E) || - isa<CXXStdInitializerListExpr>(E) || + isa<CXXStdInitializerListExpr>(E) || isa<AtomicExpr>(E) || // We treat `BuiltinBitCastExpr` as an "original initializer" too as // it may not even be casting from a record type -- and even if it is, // the two objects are in general of unrelated type. |