summaryrefslogtreecommitdiff
path: root/Source
diff options
context:
space:
mode:
authorGravatar 0biha <unknown>2014-12-15 15:55:16 +0100
committerGravatar 0biha <unknown>2014-12-15 15:55:16 +0100
commita52c0284e81842302786cfc1c8cca6b7be2ac6dc (patch)
tree266ed6a73e3a99c94a20758aed0dd74fce310baa /Source
parent5cd65c78dbea38def191147c65a4450934fc068f (diff)
Made invariant of class 'Requires' robust by changing the design (replaced public field by private field + getter/setter).
Diffstat (limited to 'Source')
-rw-r--r--Source/Core/Absy.cs19
1 files changed, 16 insertions, 3 deletions
diff --git a/Source/Core/Absy.cs b/Source/Core/Absy.cs
index ac4f3d63..35232e6b 100644
--- a/Source/Core/Absy.cs
+++ b/Source/Core/Absy.cs
@@ -2743,11 +2743,24 @@ namespace Microsoft.Boogie {
public class Requires : Absy, IPotentialErrorNode {
public readonly bool Free;
- public Expr/*!*/ Condition;
+
+ private Expr/*!*/ _condition;
+
+ public Expr/*!*/ Condition {
+ get {
+ Contract.Ensures(Contract.Result<Expr>() != null);
+ return this._condition;
+ }
+ set {
+ Contract.Requires(value != null);
+ this._condition = value;
+ }
+ }
+
public string Comment;
[ContractInvariantMethod]
void ObjectInvariant() {
- Contract.Invariant(Condition != null);
+ Contract.Invariant(this._condition != null);
Contract.Invariant(errorData == null || errorData is string);
}
@@ -2787,7 +2800,7 @@ namespace Microsoft.Boogie {
Contract.Requires(condition != null);
Contract.Requires(token != null);
this.Free = free;
- this.Condition = condition;
+ this._condition = condition;
this.Comment = comment;
this.Attributes = kv;
}