// RUN: %clang_analyze_cc1 -analyzer-checker=core.BitwiseShift \
// RUN: -analyzer-config core.BitwiseShift:Pedantic=true \
// RUN: -analyzer-checker=debug.ExprInspection \
// RUN: -analyzer-config eagerly-assume=false \
// RUN: -verify=expected,c \
// RUN: -triple x86_64-pc-linux-gnu -x c %s \
// RUN: -Wno-shift-count-negative -Wno-shift-negative-value \
// RUN: -Wno-shift-count-overflow -Wno-shift-overflow \
// RUN: -Wno-shift-sign-overflow
//
// RUN: %clang_analyze_cc1 -analyzer-checker=core.BitwiseShift \
// RUN: -analyzer-config core.BitwiseShift:Pedantic=true \
// RUN: -analyzer-checker=debug.ExprInspection \
// RUN: -analyzer-config eagerly-assume=false \
// RUN: -verify=expected,cxx \
// RUN: -triple x86_64-pc-linux-gnu -x c++ -std=c++14 %s \
// RUN: -Wno-shift-count-negative -Wno-shift-negative-value \
// RUN: -Wno-shift-count-overflow -Wno-shift-overflow \
// RUN: -Wno-shift-sign-overflow
// Tests for validating the state updates provided by the BitwiseShift checker.
// These clang_analyzer_value() tests are in a separate file because
// debug.ExprInspection repeats each 'warning' with an superfluous 'note', so
// note level output (-analyzer-output=text) is not enabled in this file.
void clang_analyzer_value(int);
void clang_analyzer_eval(int);
int state_update_generic(int left, int right) {
int x = left << right;
clang_analyzer_value(left); // expected-warning {{32s:{ [0, 2147483647] } }}
clang_analyzer_value(right); // expected-warning {{32s:{ [0, 31] } }}
return x;
}
int state_update_exact_shift(int arg) {
int x = 65535 << arg;
clang_analyzer_value(arg);
// c-warning@-1 {{32s:{ [0, 15] } }}
// cxx-warning@-2 {{32s:{ [0, 16] } }}
return x;
}