-
Notifications
You must be signed in to change notification settings - Fork 271
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Feat code actions forall calc (#6044)
### What was changed? First, for implicit assertions, if they are surrounded by a declaration that supports by clause (like AssertStmt or CallStmt), the by clause is preferred to inserting the assertion before. data:image/s3,"s3://crabby-images/2400e/2400ec20b6678b4927020697f1e331250423bcca" alt="InsertVarByStatement" And that works also for well-formedness, since well-formedness is now proved by by-blocks (thanks @keyboardDrummer for that, and @alex-chew for creating Dafny expressions for well-formedness) data:image/s3,"s3://crabby-images/131f1/131f1497054567c836750ba51699d62e73548de5" alt="InsertAssertByPreconditionStatement" Moreover, if a by clause already exist, the code action will insert into it. data:image/s3,"s3://crabby-images/d048c/d048c666f7e36f399a5b8e2419e143ae23f14ebe" alt="InsertAssertExistingByPreconditionStatement" Second, assertion of foralls now support a proof sketch by inserting forall statement data:image/s3,"s3://crabby-images/6036b/6036bd65b94cdd65e8e372d27796fa555a406d73" alt="InsertForallStatement" Third, assertions of equalities or equivalence now support a proof sketch by inserting a calc statement. data:image/s3,"s3://crabby-images/09c51/09c5187d91391c8998133b6f9c9551101a76633f" alt="InsertCalcStatement" data:image/s3,"s3://crabby-images/ed43e/ed43e0e797c01afe9506d886049a4978955de89e" alt="InsertCalcEquivStatement" The code for inserting such proof sketches has been refactored so that it will be even more easy to extend in the future. ### How has this been tested? - Tests were updated for the insertion point (var....by) when possible and insert there if it already exist. - Tests were added for foralls, equalities and equivalences, and also new insertion points <small>By submitting this pull request, I confirm that my contribution is made under the terms of the [MIT license](https://github.com/dafny-lang/dafny/blob/master/LICENSE.txt).</small>
- Loading branch information
1 parent
18c538a
commit 867e0e2
Showing
5 changed files
with
436 additions
and
76 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.