blob: ded8a7ef890be14d0f6630eb3d9493a9462ddc8d [file] [log] [blame]
// Test case for kelloggm 215
// https://github.com/kelloggm/checker-framework/issues/215
import org.checkerframework.checker.index.qual.NonNegative;
public class RefineSubtrahend {
void withConstant(int[] a, @NonNegative int l) {
if (a.length - l > 10) {
int x = a[l + 10];
}
if (a.length - 10 > l) {
int x = a[l + 10];
}
if (a.length - l >= 10) {
// :: error: (array.access.unsafe.high)
int x = a[l + 10];
int x1 = a[l + 9];
}
}
void withVariable(int[] a, @NonNegative int l, @NonNegative int j, @NonNegative int k) {
if (a.length - l > j) {
if (k <= j) {
int x = a[l + k];
}
}
if (a.length - j > l) {
if (k <= j) {
int x = a[l + k];
}
}
if (a.length - j >= l) {
if (k <= j) {
// :: error: (array.access.unsafe.high)
int x = a[l + k];
// :: error: (array.access.unsafe.low)
int x1 = a[l + k - 1];
}
}
}
void cases(int[] a, @NonNegative int l) {
switch (a.length - l) {
case 1:
int x = a[l];
break;
case 2:
int y = a[l + 1];
break;
}
}
}