mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-21 20:45:53 -04:00

Summary: Added a checker for non-determinism caused by iterating unordered containers like std::unordered_set containing pointer elements. Reviewers: NoQ, george.karpenkov, whisperity, Szelethus, baloghadamsoftware Reviewed By: Szelethus Subscribers: mgorny, xazax.hun, baloghadamsoftware, szepet, rnkovacs, a.sidorin, mikhail.ramalho, donat.nagy, dkrupp, jdoerfert, Charusso, cfe-commits Tags: #clang Differential Revision: https://reviews.llvm.org/D59279 llvm-svn: 361664
29 lines
947 B
C++
29 lines
947 B
C++
// RUN: %clang_analyze_cc1 %s -analyzer-output=text -verify \
|
|
// RUN: -analyzer-checker=core,alpha.nondeterminism.PointerIteration
|
|
|
|
#include "Inputs/system-header-simulator-cxx.h"
|
|
|
|
template<class T>
|
|
void f(T x);
|
|
|
|
void PointerIteration() {
|
|
int a = 1, b = 2;
|
|
std::set<int> OrderedIntSet = {a, b};
|
|
std::set<int *> OrderedPtrSet = {&a, &b};
|
|
std::unordered_set<int> UnorderedIntSet = {a, b};
|
|
std::unordered_set<int *> UnorderedPtrSet = {&a, &b};
|
|
|
|
for (auto i : OrderedIntSet) // no-warning
|
|
f(i);
|
|
|
|
for (auto i : OrderedPtrSet) // no-warning
|
|
f(i);
|
|
|
|
for (auto i : UnorderedIntSet) // no-warning
|
|
f(i);
|
|
|
|
for (auto i : UnorderedPtrSet) // expected-warning {{Iteration of pointer-like elements can result in non-deterministic ordering}} [alpha.nondeterminism.PointerIteration]
|
|
// expected-note@-1 {{Iteration of pointer-like elements can result in non-deterministic ordering}} [alpha.nondeterminism.PointerIteration]
|
|
f(i);
|
|
}
|