1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164
|
import org.checkerframework.checker.nullness.qual.*;
import org.checkerframework.checker.nullness.qual.EnsuresNonNullIf;
public class AssertIfChecked {
boolean unknown = false;
@Nullable Object value;
@EnsuresNonNullIf(result = true, expression = "value")
// :: error: (contracts.conditional.postcondition.invalid.returntype)
public void badform1() {}
@EnsuresNonNullIf(result = true, expression = "value")
// :: error: (contracts.conditional.postcondition.invalid.returntype)
public Object badform2() {
return new Object();
}
@EnsuresNonNullIf(result = false, expression = "value")
// :: error: (contracts.conditional.postcondition.invalid.returntype)
public void badform3() {}
@EnsuresNonNullIf(result = false, expression = "value")
// :: error: (contracts.conditional.postcondition.invalid.returntype)
public Object badform4() {
return new Object();
}
@EnsuresNonNullIf(result = true, expression = "value")
public boolean goodt1() {
return value != null;
}
@EnsuresNonNullIf(result = true, expression = "value")
public boolean badt1() {
// :: error: (contracts.conditional.postcondition.not.satisfied)
return value == null;
}
@EnsuresNonNullIf(result = false, expression = "value")
public boolean goodf1() {
return value == null;
}
@EnsuresNonNullIf(result = false, expression = "value")
public boolean badf1() {
// :: error: (contracts.conditional.postcondition.not.satisfied)
return value != null;
}
@EnsuresNonNullIf(result = true, expression = "value")
public boolean bad2() {
// :: error: (contracts.conditional.postcondition.not.satisfied)
return value == null || unknown;
}
@EnsuresNonNullIf(result = false, expression = "value")
public boolean bad3() {
// :: error: (contracts.conditional.postcondition.not.satisfied)
return value == null && unknown;
}
@EnsuresNonNullIf(result = true, expression = "#1")
boolean testParam(final @Nullable Object param) {
return param != null;
}
@EnsuresNonNullIf(result = true, expression = "#1")
boolean testLitTTgood1(final @Nullable Object param) {
if (param == null) {
return false;
}
return true;
}
@EnsuresNonNullIf(result = true, expression = "#1")
boolean testLitTTbad1(final @Nullable Object param) {
// :: error: (contracts.conditional.postcondition.not.satisfied)
return true;
}
@EnsuresNonNullIf(result = false, expression = "#1")
boolean testLitFFgood1(final @Nullable Object param) {
return true;
}
@EnsuresNonNullIf(result = false, expression = "#1")
boolean testLitFFgood2(final @Nullable Object param) {
if (param == null) {
return true;
}
return false;
}
@EnsuresNonNullIf(result = false, expression = "#1")
boolean testLitFFbad1(final @Nullable Object param) {
if (param == null) {
// :: error: (contracts.conditional.postcondition.not.satisfied)
return false;
}
return true;
}
@EnsuresNonNullIf(result = false, expression = "#1")
boolean testLitFFbad2(final @Nullable Object param) {
// :: error: (contracts.conditional.postcondition.not.satisfied)
return false;
}
@Nullable Object getValueUnpure() {
return value;
}
@org.checkerframework.dataflow.qual.Pure
@Nullable Object getValuePure() {
return value;
}
@EnsuresNonNullIf(result = true, expression = "getValuePure()")
public boolean hasValuePure() {
return getValuePure() != null;
}
@EnsuresNonNullIf(result = true, expression = "#1")
public static final boolean isComment(@Nullable String s) {
return s != null && (s.startsWith("//") || s.startsWith("#"));
}
@EnsuresNonNullIf(result = true, expression = "#1")
public boolean myEquals(@Nullable Object o) {
return (o instanceof String) && equals((String) o);
}
/*
* The next two methods are from Daikon's class Quant. They verify that
* EnsuresNonNullIf is correctly added to the assumptions after a check.
*/
@EnsuresNonNullIf(
result = true,
expression = {"#1", "#2"})
/* pure */ public static boolean sameLength(
boolean @Nullable [] seq1, boolean @Nullable [] seq2) {
return ((seq1 != null) && (seq2 != null) && seq1.length == seq2.length);
}
/* pure */ public static boolean isReverse(
boolean @Nullable [] seq1, boolean @Nullable [] seq2) {
if (!sameLength(seq1, seq2)) {
return false;
}
// This assert is not needed for inference.
// assert seq1 != null && seq2 != null; // because sameLength() = true
int length = seq1.length;
for (int i = 0; i < length; i++) {
if (seq1[i] != seq2[length - i - 1]) {
return false;
}
}
return true;
}
}
|