diff options
author | Rustan Leino <leino@microsoft.com> | 2012-10-04 16:39:13 -0700 |
---|---|---|
committer | Rustan Leino <leino@microsoft.com> | 2012-10-04 16:39:13 -0700 |
commit | 5441447b52d9850683679c1dc7aa675d8ddc2927 (patch) | |
tree | c9172fbf1853fe13c2d42da1d8d9987d16025283 /Source/Dafny/Translator.cs | |
parent | a54b7d394f92a9af32cff46e854eb4d37705439e (diff) |
changed default decreases clause for functions with a reads clause: use the reads clause followed by the list of parameters
Diffstat (limited to 'Source/Dafny/Translator.cs')
-rw-r--r-- | Source/Dafny/Translator.cs | 19 |
1 files changed, 9 insertions, 10 deletions
diff --git a/Source/Dafny/Translator.cs b/Source/Dafny/Translator.cs index 40795129..a6eb404f 100644 --- a/Source/Dafny/Translator.cs +++ b/Source/Dafny/Translator.cs @@ -3008,18 +3008,17 @@ namespace Microsoft.Dafny { List<Expression> decr = f.Decreases.Expressions;
if (decr.Count == 0) {
decr = new List<Expression>();
- if (f.Reads.Count == 0) {
- foreach (Formal p in f.Formals) {
- if (IsOrdered(p.Type)) {
- IdentifierExpr ie = new IdentifierExpr(p.tok, p.UniqueName);
- ie.Var = p; ie.Type = ie.Var.Type; // resolve it here
- decr.Add(ie); // use the function's first parameter instead
- }
+ if (f.Reads.Count != 0) {
+ decr.Add(FrameToObjectSet(f.Reads)); // start the lexicographic tuple with the reads clause
+ }
+ foreach (Formal p in f.Formals) {
+ if (IsOrdered(p.Type)) {
+ IdentifierExpr ie = new IdentifierExpr(p.tok, p.UniqueName);
+ ie.Var = p; ie.Type = ie.Var.Type; // resolve it here
+ decr.Add(ie);
}
- inferredDecreases = true;
- } else {
- decr.Add(FrameToObjectSet(f.Reads)); // use its reads clause instead
}
+ inferredDecreases = true; // use 'true' even if decr.Count==0, because this will trigger an error message that asks the user to consider supplying a decreases clause
}
return decr;
}
|