Date 31/08/24
- Domain axioms can now refer to functions that have decreases clauses (but no preconditions) #802
- Improved
Simplifier
simplifies many additional expressions; new option determines whether simplification must preserve well-definedness #810 - Chopper is now aware of opaque functions #779
- Chopper has improved dependency analysis for axioms #776
- Removed filtering of duplicate errors inside Viper (this is now left to frontends) #778
- Fixed various issues with macro expansion:
- Fixed incorrect
Simplifier
handling of division and modulo expressions #794 - Fixed crash in proof obligation computation for expressions #783
- Termination plugin: Improved encoding of checks for
unfolding
-expressions #773 - ADT plugin: Fixed crash when plugin is used with other AST extensions #800
- Added experimental support for (command line) verification debugging. With the new option
--enableDebugging
, users can see the state (store, heap, branch conditions and assumptions) in a format that that can be understood on the Viper level (avoiding internal Silicon concepts) at the point where a verification error occurs, locally assert or assume expressions to debug the error, and change SMT solver options. viperproject/silicon#863 - Soundness fixes:
- Fixed unsound rewrite for
--conditionalizePermissions
option viperproject/silicon#853 - Fixed unsound handling of quantified permissions with unsatisfiable condition viperproject/silicon#843
- Fixed unsound handling of quantified permissions with trivial condition viperproject/silicon#834
- Improved encoding of magic wand snapshots that prevents unsoundness for
applying
-expressions viperproject/silicon#836 - Fixed incorrect order of function precondition assumptions viperproject/silicon#811
- Fixed unsound rewrite for
- Completeness improvements:
- Recording missing constraints during function verification viperproject/silicon#852 and viperproject/silicon#825
- Fixed treatment of snapshot maps defined while evaluating quantifiers viperproject/silicon#840
- Avoiding using a quantifier for wildcard constraints for quantified resources when possible viperproject/silicon#817
- Performance improvements:
- Improved snapshot map caching for quantified permissions (also improves completeness) viperproject/silicon#846
- Avoiding creating new snapshot maps for quantified resources when unnecessary viperproject/silicon#839
- Eagerly assuming non-aliasing for quantified field chunks viperproject/silicon#835
- More efficient function axiomatization for functions with many branches viperproject/silicon#808
- Flexible path joining options:
- With command line argument
--moreJoins=1
, Silicon joins only branches stemming from impure implications (immediately after branching). With--moreJoins=2
it joins all branches, including branches stemming from program control flow, at the earliest possible point. viperproject/silicon#823 - The new annotation
@moreJoins(n)
, withn
bein1
or2
as just described, can be used to enable path joining on a per-method level viperproject/silicon#823
- With command line argument
- More flexible state consolidation:
- Added several new options for state consolidation behavior viperproject/silicon#827
- The new annotation
@stateConsolidationMode(n)
allows configuring state consolidation on a per-method level viperproject/silicon#827
- Other improvements:
- Fixed crash resulting from double-declarations of macros with
--parallelizeBranches
viperproject/silicon#813 - Fixed error reporting for method call arguments viperproject/silicon#841
- Silicon now tries to find the Z3 executable in PATH if no path is explicitly provided viperproject/silicon#818
- Fixed crash resulting from double-declarations of macros with
- Bug fixes:
- Preventing Boogie crash when using annotations viperproject/carbon#505
Date 16/02/24
unfold
,fold
, andunfolding
now require a strictly positive permission amount (i.e.,none
is no longer allowed) (Silicon#754) and (Carbon#469). This fixes an unsoundness (Silver#444). A new error reasonNonPositivePermission
is reported if this condition is not satisfied (Silver#744).- When generic functions are used inside axioms of their own domain and the type arguments are not constrained, Viper no longer uses
Int
as the type argument, but instead uses the domain's type parameter itself (i.e., it states that the axiom must hold for all type arguments). (Silver#758) - Functions can be annotated as
@opaque()
, which means that their definitions are not available by default. For opaque functions, any use of the function can be annotated with@reveal()
to make the definition available for that specific function application. (Silicon#767) and (Carbon#474)
- The classes
ErrorReason
andVerificationError
are now sealed. Code that extended them must now extendExtensionAbstractVerificationError
andExtensionAbstractErrorReason
, respectively. (Silver#749) - The ParseAST has been heavily reworked, which may require adaptations in plugins that work on the ParseAST level. Additionally, the order of constructor arguments of the
PredicateInstance
class in the predicate instance plugin has been switched. (Silver#764)
- Viper now includes a new smoke detection plugin that automatically checks if e.g. preconditions are unsatisfiable or branches are reachable by inserting
refute false
in various locations in the program. The plugin is not enabled by default. (Silver#762) - The ADT plugin now automatically generates well-foundedness axioms for each declared ADT type if the termination plugin is used, s.t. ADT values can be used as termination measures without the user having to declare them. (Silver#743)
- Two bug fixes in the termination plugin:
- An incompleteness in the termination plugin affecting functions whose preconditions contain quantified permissions has been fixed (Silver#754)
decreases
clauses with predicate instances can now be written anywhere in function specifications (previously could not be after the postcondition) (Silver#738)
- Fixed a bug in the refute plugin that prevented it from working inside loops in Carbon (Silver#736)
- Substantially improved parsing and type checking errors (as well as parsing performance) (Silver#764)
- Fixed a bug where domain axioms were not instantiated for all relevant cases (Silver#742)
- Two improvements in trigger inference:
- Proper treatment of
let
-expressions when generating triggers (Silver#753) - Trigger inference no longer incorrectly omits
old
(Silver#747)
- Proper treatment of
- Soundness fixes:
- Fixed a long-standing unsoundness and incompleteness related to packaging magic wands (Silicon#757)
- Fixed an incorrect well-definedness check of branch conditions inside
goto
-loops (Silicon#774) - Fixed a missing check for map lookups (Silicon#770)
- Completeness improvements:
- Silicon now uses Carbon's more complete axiomatization for sequences, sets and multisets. This usually comes with little or no performance cost, but we have observed individual examples where the new axioms caused non-termination or significantly worse verification time. We would be very grateful if users who observe additional examples where the new axiomatization leads to severe problems filed issues or sent us the problematic examples in some other way. Silicon's old axiomatization is still available and can be used via the command line option
--useOldAxiomatization
. (Silicon#642) - Fixed an incompleteness when exhaling a quantified permission with a permission amount that depends on the quantified variable inside a
package
block (Silicon#797) - Fixed an issue where a function definition was available too late (Silicon#744)
- Two completeness improvements of exhale mode 1 (aka
moreCompleteExhale
) (Silicon#760) and (Silicon#795)
- Silicon now uses Carbon's more complete axiomatization for sequences, sets and multisets. This usually comes with little or no performance cost, but we have observed individual examples where the new axioms caused non-termination or significantly worse verification time. We would be very grateful if users who observe additional examples where the new axiomatization leads to severe problems filed issues or sent us the problematic examples in some other way. Silicon's old axiomatization is still available and can be used via the command line option
- Fixed crashes:
- when using Z3 via its API and interpreted functions (Silicon#752)
- when using predicate or wand triggers inside functions (Silicon#759)
- Performance improvements
- More consistent caching for quantified permissions (Silicon#792)
- Better heuristics for quantified permissions (Silicon#789)
- Other improvements
- Added a command line flag
--disableNL
to easily disable non-linear integer arithmetic reasoning in Z3 (Silicon#783) - Added support for an experimental method annotation
@proverArgs(key=value)
that allows setting Z3 configuration parameters on a per-method basis (Silicon#784) - Fixed incorrect branch conditions in symbolic execution log (Silicon#790)
- Added a command line flag
-
Soundness fixes:
- Exhaling quantified magic wands is now sound (Carbon#473)
-
Other improvements:
- Added support for several missing features: (Carbon#473)
- quantified magic wands
- magic wands as triggers
perm
for magic wandsforperm
with more than one quantified variableforperm
for magic wands
- Added a command line option
--timeout=n
to set an overall verification timeout (in seconds) (Carbon#483) - Several internal encoding improvements:
- Improved encoding of the old state (Carbon#482)
- Improved encoding of
if
statements (Carbon#478) - Improved encoding of method calls (Carbon#477)
- Added support for several missing features: (Carbon#473)
Date 31/07/23
- Improved language flexibility (Silver#685): The syntax of declarations and assignments is now more permissive, allowing, for example, multiple declarations at once:
Additionally, method calls and new statements can now have fields or newly-declared local variables on their left hand side:
field n: Ref, m: Ref // Declare multiple fields at once var a: Ref, b: Ref, c: Int // Declare multiple locals at once
The Viper AST remains unchanged; the newly-supported syntax is desugared into equivalent code that uses the existing Viper AST.var f: Ref := new(n) // Declare and initialise locals with `new` a, f.n := get_refs() // Assign to field from method call f.n := new(n) // Assign to field with `new`
- Annotations (Silver#666): The Viper language now has support for annotations on statements, expressions, and top-level declarations. The syntax for an annotation is
@key("value", "value2", ...)
, i.e., they have a key which is preceded by an@
sign and a sequence of values written as comma-separated string literals. A single expression/statement/declaration can have multiple annotations. If there are two annotations of the same key, their value sequences are concatenated. In the AST, annotations are represented in theinfo
field of the annotated AST node using anAnnotationInfo
object. Currently, there are two supported annotations:@weight("n")
on quantifiers, wheren
is a positive integer, sets the weight of the quantifier in the SMT solver. The second annotation is exclusive to the Symbolic Execution backend (see below). Unknown annotations are ignored. - Domain axioms may now refer to non-domain functions that do not have any preconditions (Silver#698).
- Support for chained comparisons (Silver#713): expressions like
e1 < e2 <= e3 > e4
can now be parsed and will be desugared to(e1 < e2) && (e2 <= e3) && (e3 > e4)
. The AST nodes for comparison operations remain unchanged. - Two important changes in the termination plugin:
- The termination plugin now enforces that functions that refer to themselves (or to other functions that call the original function in a mutually-recursive way) in their own postconditions have a
decreases
clause (Silver#711). That is, for such functions, one must either prove termination using adecreases
clause, or explicitly state that termination should be assumed by writingdecreases *
. This change addresses frequent issues where users wrote functions that are not well-defined using such postconditions and subsequently reported seemingly unsound behavior (e.g., (Silver#525) and (Silver#668)). - The termination plugin now automatically imports the default definitions of well-founded orders if
decreases
-clauses are used but no such definitions are present in the program (Silver#710). That is, it is not longer necessary (but still possible) to write an import statement likeimport <decreases/int.vpr>
when using a termination measure of type integer.
- The termination plugin now enforces that functions that refer to themselves (or to other functions that call the original function in a mutually-recursive way) in their own postconditions have a
- The
Rational
type, an alias forPerm
, is deprecated. Viper issues a warning whenever the type is used.
- Introduced a new API for frontends to interact with Viper (Silver#732). Frontends can create instances of
ViperFrontendAPI
and interact exclusively through those (instead of instances ofVerifier
orSilFrontend
), which saves some boilerplate code and lets Viper manage plugins.
- Improved error messages for parse errors (Silver#702) and type errors ((Silver#684), (Silver#724))
- Fixed parsing and pretty-printing of scopes (Silver#704), which were previously ommitted under some circumstances by both the pretty-printer and the parser, which could make otherwise valid Viper code invalid.
- Introduced caching to improve performance of common lookups on the AST ((Silver#659) and (Silver#719))
- Viper now reports inferred quantifiers using a
QuantifierInstantiationsMessage
(Silver#653) - Introduced various new consistency checks for invalid code that used to crash the backends or lead to unexpected behavior:
perm
-expressions are no longer allowed in function postconditions (Silver#681)wildcard
is no longer allowed as part of compound expressions (Silver#700)- empty ADTs are rejected (Silver#696)
- predicate argument expressions must be pure (Silver#721)
- Labelled
old
-expressions may now be used as triggers (Silver#695) - Various small fixes for crashes or other incorrect behavior.
- The previously experimental mode
--moreCompleteExhale
is no longer experimental, but is now a supported mode that performs exhales and heap lookups in a way that is usually more complete (but possibly slower). However, Silicon's previous exhale mode remains the default. (Silicon#682)- The new flag
--exhaleMode=n
, wheren
is 0, 1, or 2, can now be used to select the exhale mode. 0 is the default, 1 is the previousmoreCompleteExhale
mode. - The new
exhaleMode
2 uses the default exhale mode 0 throughout the program, until it encounters a verification error. When it does, it retries proving the failing assertion using the (more complete) mode 1. Since mode 0 is usually faster than mode 1, mode 2 often results in the best mix of performance and completeness. - Additionally, one can now override the exhale mode selected via command line for individual methods using an annotation
@exhaleMode("n")
on the method (Silicon#724)
- The new flag
- Via the option
--prover=Z3-API
, Silicon can now use Z3 as a library via its Java API ((Silicon#633) and (Silicon#692)). Note that this requires a native version oflibz3java
to be present on the path Java uses to look for native libraries (which can be set, e.g., via the environment variableLD_LIBRARY_PATH
on Linux orDYLD_LIBRARY_PATH
on MacOS). Depending on the OS and the Viper program, this option can lead to a significant speedup. - Silicon now emits warnings in cases where it cannot use the triggers specified by the user (Silicon#687)
old
-expressions in triggers are now interpreted correctly (Silicon#710); previously, they were sometimes ignored.- Changed default options used for Z3; the new options have similar performance and completeness characteristics with the supported Z3 version 4.8.7, but perform better with newer versions (tested in particular with 4.12.1) (Silicon#694)
- Silicon no longer creates a
tmp
directory containing.smt2
files that log its prover interactions by default (Silicon#709). The flag--disableTempDirectory
no longer exists. Instead, one can use the new flag--enableTempDirectory
or the flag--proverLogFile
. - Improved heuristics for handling of quantified permissions, which improves performance in some cases (Silicon#704)
- Fixed some incorrect (too short) timeouts, which could lead to unstable verification results in some cases (Silicon#705)
- Added a new command line flag
--reportReasonUnknown
, which instructs Silicon to report the reason the SMT solver names for not being able to prove a property (per error) (Silicon#701). This flag can be useful to find out whether an error occurred due to non-linear arithmetic or timeouts. - Fixed five unsoundnesses:
- Incorrect handling of
old
-expressions in postconditions of methods called inside apackage
statement (Silicon#699) - Incorrect handling of
fold
statements for predicates that are used inside a quantified permission in the current method (Silicon#696) - Incorrect behavior for quantifiers whose bodies have unreachable branches (Silicon#690)
- Incorrectly terminating verification after using a
refute
(Silicon#741) - Exhale mode 1 now correctly checks permission amounts in function preconditions (Silicon#682)
- Incorrect handling of
- Fixed and generalized the experimental mode
--conditionalizePermissions
, which avoids branching on conditional permission assertions (e.g.,b ==> acc(x.f)
) by rewriting them to unconditional assertions with conditional permission amounts (e.g.,acc(x.f, b ? write : none)
whenever possible (Silicon#685). For programs with many branches, this option can improve performance. - Resource triggers on existentials now work correctly (Silicon#679)
- More complete computation of function footprints (Silicon#684)
- Various smaller bug fixes
- Improved encoding of well-definedness checks for field accesses and permission division (Carbon#451). As a result, Carbon now emits well-definedness errors in the expected order in some cases where this was previously not the case.
- Improved encoding of definedness checks during exhale (Carbon#457). This fixed both possible unsoundness and incompleteness issues.
- Using stdin instead of a temporary file to communicate with Boogie (Carbon#456)
Date 25/01/23
- Quasihavoc: New statements
quasihavoc
andquasihavocall
allow explicitly losing information about a resource. E.g.,quasihavoc c ==> P(x)
havocs the snapshot of resourceP(x)
ifc
is true and some permission toP(x)
is held, and does nothing otherwise. Semantically equivalent to (conditionally) exhaling the current permission amount to the given resource and inhaling it again, but implemented more efficiently. For more details, see this report (Silver#611). Currently, the Symbolic Execution backend (Silicon) fully supportsquasihavoc
andquasihavocall
, while the Verification Condition Generation backend (Carbon) only supportsquasihavoc
for field and predicate resources and does not suportquasihavocall
. - Syntax for backend types added in the form of domains with interpretations: Domains can be annotated with interpretations for different backends. E.g.,
domain myBV interpretation (SMTLIB: “(_ BitVec 32)”, Boogie: “bv32”) { ... }
will be interpreted by Silicon as the SMTLIB type(_ BitVec 32)
and by Carbon as the Boogie typebv32
. Similarly, domain functions can be annotated with SMTLIB interpretations. (Silver#638)
- Breaking change: The plugin API has been extended with a method to transform verification results for individual entities, in addition to the existing method to transform the verification result for the entire Viper program. Plugins should implement both methods; the former is used to transform verification results for individual members that are streamed via the Reporter interface (Silver#641). Additionally, the signature of the existing method has been changed in order to remove the need for plugins to maintain state.
- Experimental quantifier weight support: Quantifiers can be given a weight to be used by the SMT solver by annotating them with special WeightedQuantifier info objects (Silver#633). Currently only available on the AST level (without syntax support), and only supported in the Symbolic Execution backend.
- Breaking change: AST nodes for BackendFunctions have been changed to accommodate the new syntax for interpreted domains (see above): Among other small changes, BackendFunc objects no longer exist, and are replaced by DomainFuncs with interpretations. (Silver#638)
- Improved pretty-printing of ASTs (Silver#616)
- Improved parsing and better consistency checks for invalid triggers, invalid predicate accesses, and invalid domain types (Silver#601), (Silver#614), (Silver#626), (Silver#643)
- Improved type checking performance for large methods (Silver#631)
- Termination plugin generates simpler code (Silver#613) and supports more complex expressions (Silver#618)
- Several bug fixes (Silver#607), (Silver#590), (Silver#636), (Silver#635)
- Parallel branch verification: Use option
--parallelizeBranches
to verify different branches of a method in parallel. Generally speeds up verification but may lead to non-deterministic verification time. (Silicon#634) - Parallel Silicon instances: Multiple verifier instances can be used in parallel (Silicon#635), (Silver#600)
- Soundness fixes for several long-standing soundness issues. As a result, standard Silicon currently has no known soundness issues outside of magic wands. Fixes include:
- Function encoding (Silicon#376), (Silicon#369)
- Quantified permission encoding for finite domains (Silicon#342), (Silicon#636)
- Quantifier encoding (Silicon#560), (Silicon#652)
- Improved SymbExLogger is now thread safe and reports records via a SymbLogListener interface (Silicon#622).
- Multiple performance improvements, mostly related to quantified permissions (Silicon#668), (Silicon#649), (Silicon#651), (Silver#604), (Silver#605)
- Fixed crashes and other issues (Silicon#648), (Silicon#321), (Silicon#641), (Silicon#665)
- Boogie Version upgraded to 2.15.9 (Carbon#441)
- Inconsistent interpretation of division and modulo fixed (Carbon#448)
- Boogie and Z3 instances are now stopped if Carbon is interrupted (Carbon#426)
Date 29/07/22
- ADT plugin added. It is enabled by default, and can be disabled with the
--disableAdtPlugin
command-line option. This plugin converts ADT (abstract datatype) declarations of the formadt (name) { Constructor1(args) ... }
into domain types with constructors, destructors, discriminants, and corresponding axioms. More information can be found in the tutorial (Silver#574) - Added support for a
refute (expression)
statement. This statement behaves like an assertion, except the expression is expected to be provably false. More information can be found in the tutorial (Silver#583) - Division of two
Perm
-typed expressions is now allowed. (Silver#572) - Typed function application syntax (
(foo(...) : T)
) now parses properly. (Silver#584)
- Output sent to the backend solver is now SMT-LIB 2.6 conformant. Additionally, there is experimental support for the CVC5 solver using the
--prover cvc5
command-line option. (Silicon#609) - Improved counterexamples. Counterexamples are now generated for domain types as well, and are included in the output with the
--counterexample mapped
command-line option. (Silicon#631)
- Breaking change: wildcard
acc
expressions inexhale
statements are no longer reordered. Behaviour is now consistent with Silicon and all permissions in anexhale
statement are always exhaled left to right. (Silicon#30, Carbon#411)
- "Chopper" API is now available to front ends. This functionality allows a single Viper file to be split into multiple smaller files that can be verified separately. Dependencies between functions, methods, and predicates are correctly determined to minimise the size of the individual Viper files. (Silver#589)
- Upgraded projects to use
sbt
version 1.6.2. (Silicon#627, Silver#592) - Viper IDE uses
.vpr
as its default file extension. (viper-ide#223) - Viper IDE now requires at least Java version 11. (viper-ide#250)
- Cache improvements. (Silver#578)
- Various bug fixes. (Carbon#423, Carbon#425, viper-ide#248, Silver#496, Silver#587, Silver#590)
Date 28/02/22
- Breaking change: As mentioned in the release notes for 2021.7, starting with the 2022.2 release, Viper will check injectivity of inhaled quantified permissions by default, instead of assuming it. In the previous release, this feature was enabled with the
--checkInjectivity
flag. It is now enabled by default and can instead by disabled with the--assumeInjectivityOnInhale
flag. This change makes the injectivity requirement consistent with other well-definedness conditions in Viper (such as ruling out potential division by zero).
- Added new option to report multiple errors per path, potentially allowing verification to continue beyond a failing pure condition (e.g. assert statement). The command-line argument
--numberOfErrorsToReport
(by default 1, 0 indicates all errors are to be reported) controls how many errors will be reported by the verifier before it stops. (Silicon#575) - Added new option to report branch conditions in errors using the command-line argument
--enableBranchconditionReporting
. When enabled, errors reported on the command line additionally show a list of conditions or their negations that were reached on the path to the error. (Silicon#575) - Fixed a memory leak (Silicon#579).
- When Z3 quantifier reporting is enabled (for example, by passing
--z3Args '"smt.qi.profile=true smt.qi.profile_freq=10000"'
to Silicon), its output is now recognised and printed in Silicon's output, to enable a quick check for likely matching loops. (Silicon#587) - Removed magic-wand-related heuristics described in ECOOP’15 (these were not generally enabled for standard Viper input files). (Silicon#589) Bug fixes. (Silicon#582, Silicon#583, Silicon#584)
- Check that predicate bodies are self-framing. (Carbon#397)
- Bug fixes. (Carbon#398)
- CI workflows for Viper tools migrated to GitHub actions.
- Silver AST can now represent all SMT-LIB bitvector functions, although these are not yet supported in the language. (Silver#537)
- Impure assumes rewriter fix. (Silver#553)
- Viper IDE cache can be stored to a file. (ViperServer#44)
- Position information fix. (Silver#555)
Date 27/07/21 Download
- Breaking change: Inhaling possibly-negative permission amounts now leads to a verification failure, whereas in previous releases it led to an inconsistent state (Silver, 522). For example,
inhale acc(x.f, e)
for some permission expressione
will now cause a failure ife
is not known to be non-negative, rather than implicitly assuming this property. - Planned future breaking change: Currently, Viper checks the injectivity of the receiver expression when exhaling quantified permissions, but not when inhaling quantified permissions (when this property is currently assumed). We plan to change this in the January 2022 release, that is Viper will also check injectivity is known when inhaling quantified permissions. Since this is an important breaking change, we have provided access to it in this release but only if the
--checkInjectivity
flag is provided. This flag will be removed in the next release, and the corresponding injectivity checks will be enabled by default.
- Added new option for displaying counterexamples using the
--counterexample mapped
command-line argument. This option produces pretty-printed counterexamples with heap chunks resolved to their contained fields. - Added a new option for selecting different state consolidation modes affecting how complete, and thus expensive, a state consolidation is [experimental]
- Added scope-based logging of symbolic execution details (PR #562)
- Fixed labelled old expressions that potentially refer to labels that have not yet been defined (Carbon, PR 387)
- Added support for loops formed via gotos (Carbon, PR 389)
- Minor bug fixes (382, 386)
-
Compatibility with latest versions of Silicon and Carbon incl. latest Viper features (e.g.
Map
types and anonymous axioms). -
Mono is no longer a requirement.
-
The JAVA installation has to be version 11 or higher and must be 64-bit.
-
The IDE now shows non-critical warning messages.
-
Build version of Viper Tools (i.e. the dependencies) can be configured in the VSCode settings:
Stable
/Nightly
: the latest Viper Tools in the corresponding build configuration will be used. The Preferences specify from which URL the Viper Tools will be downloaded. The Viper Tools are not automatically updated. They only get installed when they are not present yet or when a manual update is triggered (via the command palette). The installation folder has changed for these two build versions: They always get installed to<VSCode Installation>/User/globalStorage/viper-admin.viper
where<VSCode Installation>
corresponds to~/Library/Application Support/Code
(on macOS),c:\Users\<user>\AppData\Roaming\Code
(on Windows), and~/.config/Code
(on Linux).Local
: uses the Viper Tools located at the path specified asviperSettings.paths.viperToolsPath
.
-
Locating the JAVA installation has been improved. A warning appears if it cannot be uniquely identified. A fixed path to a Java installation can be provided in the settings as
viperSettings.javaSettings.javaBinary
(more details). -
Sound effects for a successful or failed verification can be enabled by setting
viperSettings.preferences.enableSoundEffects
to true. -
Minor bug fixes (#23)
Date 15/02/21 Download
- Basic support for partial maps. The associated keywords domain and range are experimental. Please report any observed incompletenesses w.r.t. map reasoning.
- Optimized parser for large Viper files (Silver, 477).
- Breaking change: New Scala (2.13.4) and fastparse version.
- Breaking change: The constructor of DomainFuncApp now requires that the function's return type is passed as for standard function applications (and not using call-by-name as before) (Silver, 490).
- Due to the deprecation of the Traversable trait, the Node class now extends the Iterable trait instead. The interface is similar, but the implementation of some methods like find and exists is less efficient because it internally creates a collection with all the elements on which to iterate over (Silver, 493 and Silver, 497).
- New backend support for SMTLib types on the AST-level (particularly bitvectors and floats) (Silver, 428).
- Magic wands used inside predicate definitions of function preconditions generate errors (these usages were never fully supported, but a clear error wasn’t shown). We hope to add support for these cases in future.
-
- Several minor bugfixes.
- Two permission-related incompleteness fixed: (Silicon, 512) and (Silicon, 508).
- Command-line option for avoiding creation of a local temp directory (Silicon, 15).
-
Verification Condition Generation Verifier
- Boogie upgrade: Boogie is now built with .NET Core and is shipped with all dependencies. As a result, Mono is not required anymore for Boogie on Linux.
- Minor fixes
- Boogie AST changed to support unnamed parameters in domain functions (Carbon, 363).
- Fix negative fraction check in quantified permissions (Carbon, 362).
-
The Viper IDE (VSCode extension) cannot yet use the new Boogie version, and thus will continue to use the 2020.7 release.
-
Viper performs worse with Z3 4.8.9 than with 4.8.6, thus we recommend the use of Z3 4.8.6.
Date 17/07/20 Download
Our repositories are now on GitHub: github.com/viperproject
- Axiom names are now optional (Silver, 193).
For example, we now allow domains such as:
domain MyDomain { function foo(): Int axiom { foo() > 2 } axiom upperlimit { foo() < 8 } }
- Experimental support for termination checks tutorial section about termination.
- This extension provides support for specifying termination measures for heap-dependent functions and using them to prove termination.
- There is also support for proving termination of methods and loops, but those are still experimental and support for these features as well as the semantics of the specifications might change.
- Details are explained in the Viper tutorial.
- Experimental support for counter examples:
- Added the command line option
--counterexample
. When using either backend with--counterexamples=variables
, it will return, along with each verification error, a counter example for the values of all local variables (but not the heap or functions) on the Viper level. Alternatively, using the option--counterexample=native
will return a backend-specific counter example along with each error that contains the entire model exactly as returned by the SMT solver, i.e., including any renaming and encoding the backends may have performed.
- Added the command line option
- 64-bit Z3 is now shipped with the Windows distribution (the 32-bit version which was inadvertently still being shipped can cause memory issues for some examples) (Silicon, 375)
- Intermittent Failures on Viper Online (web interface) should no longer happen (but for now we only support the default backend) (Silver, 264)
- Reserved words are declared in only one place in the codebase (Silver, 301)
- The phases used to organise programmatically calling verifiers (frontends, in the codebase) have been made more consistent and flexible (Silver, 270)
- Several examples which had long runtimes are now apparently stable (but we would appreciate any feedback to the contrary!). e.g. (Silver, 457)
- The
DomainAxiom
AST node no longer exists, it was replaced by:NamedDomainAxiom
, providing exactly the same features asDomainAxiom
.AnonymousDomainAxiom
, which is similar to the node above except for the absence of thename
parameter.
-
- More-complete aliasing properties can be deduced in programs using quantified permissions (Silicon, 502)
- Potential crash removed when using quantifiers and unfolding expressions in a function body (Silicon, 491)
-
Verification Condition Generation Verifier
- Axioms used for sequence operations should be more complete (especially for cases such as dropping more elements than a sequence has) (Carbon, 36)
- Sequence contains function now works in triggers (Carbon, 349)
- Carbon should now kill child Boogie and Z3 processes eagerly on stop(); this behaviour may be setup-dependent so please report any outstanding issues (Carbon, 225)
- Predicates whose parameters include bound variables (e.g. from outer-quantifiers) now work in function specifications (Carbon, 271)
- Work in progress on correct handling of perm-expressions inside unfolding expressions / quantifiers: some issues have been fixed; a summary of the current status is provided (Carbon, 348)
Date 31/01/20 Download
-
Support for variable scopes. For example, now it is possible to define two variables with the same name in different branches:
if (b) { var x: Int := 5; } else { var x: Bool := true; }
-
Added support for using field lookups and predicates as triggers, e.g.
forall r: Ref :: {r.f} r in s ==> r.f > 0 forall r: Ref :: {P(r)} r in s ==> (unfolding P(r) in r.f > 0)
Note: this support still has some issues in Viper's VCG-based verifier.
-
Added support for trigger annotations on existential quantifiers. These are written and behave analogously to those already supported on forall quantifiers, and are relevant in the logically dual cases, typically when proving an existentially-quantified assertion (189).
-
Extended support for Viper plugins (designed to make lightweight Viper front-end tools simple to write). In particular, extending the grammar of the parser via plugins is now possible.
-
Removed the experimental built-in function termination checking. An experimental termination plugin is available: https://bitbucket.org/viperproject/termination-plugin/ Feedback is welcome; we plan support for termination checking in the next release.
-
Renamed all example files from .sil to .vpr (287).
-
The unary plus operator has been removed (108).
-
Whitespace between unary operations and their operands is no-longer allowed (272).
-
The
fresh
statement was removed (87). -
Macros can now take field names as parameters (170).
-
LHS of field assignment statements can now be a macro invocation (214).
-
Warnings are now generated for unused macro parameters (267).
-
Macro definitions are disallowed inside magic wand proof scripts (215).
- Conditional assertions as part of quantified permissions are properly supported, e.g.
inhale forall j : Int :: (j == k ? acc(s.f) : true)
(260). - Expression macros with missing bodies no-longer cause spurious parser errors (for next construct) (273).
new(..)
parameterised by identifiers which are present in the program but are not field names now produces an appropriate error message (247).- Type checker no longer crashes on ASTs with sharing (191).
- Macro names are now checked for clashes (167).
- The AST utility method
Expressions.instantiateVariables
is now capture-avoiding (an additional parameter can be provided to exclude certain names from being chosen when renaming bound variables) (286). - Eliminated spurious type error involving #E type when using empty Multisets via macros (282).
- AST transformation framework's Rewritable is no-longer limited w.r.t. collections of Rewritables (225).
LocalVar
AST node no longer has type as an optional field (281).Result
AST node no longer has type in its second parameter list (283).Call
trait,FuncApp
andDomainFuncApp
AST nodes no longer have aformalArgs
field; this information can be obtained from the enclosingProgram
(241).- Upgraded all dependencies, libraries, plugins and development environment:
- SBT 1.2.6, rewriting all build files.
- Scala 2.12.7
- fastparse 1.0.0
- ScalaTest 3.0.5.
- scallop 3.1.3.
- jgrapht-core 1.2.0.
- scala-parser-combinators 1.1.1.
- commons-io 2.6.
- guava 26.0.
- slf4j-api 1.7.25.
- logback-classic 1.2.3.
- scala-logging 3.9.0
- sbt-assembly 0.14.7
- sbteclipse-plugin 5.2.4.
- Symbolic Execution Verifier
- Implemented an experimental feature that allows using the quantified
permissions based handling of permissions for all permissions. This
handling of permissions is expected to be more complete and may be faster;
however, the implementation is still in beta state. The feature can be
enabled with the
--enableMoreCompleteExhale
flag. - (API) Uses logback library instead of log4j for logging.
- (API) Changed how the verifier reports errors: introduced a reporter class that is responsible for reporting errors to the user (before errors were reported via logging). Verification results of a particular method are reported via the reporter as soon as they become available without waiting for all methods to be verified.
- Implemented an experimental feature that allows using the quantified
permissions based handling of permissions for all permissions. This
handling of permissions is expected to be more complete and may be faster;
however, the implementation is still in beta state. The feature can be
enabled with the
- Verification Condition Generation Verifier
- Quantified permissions with multiple forall-bound variables are now supported (205).
- Experimental adjustments to the background axioms used for set, sequence and multiset support. These should mostly add completeness; fewer scenarios should require user assertions to verify. Please report any bugs observed (particularly examples which exhibit poorer performance). In the next release, this will be stabilised, and migrated analogously to Viper's Symbolic Execution back-end.
- Old expressions in triggers are now translated correctly (236).
- Substitution of actuals for formals in method specifications, predicate unfoldings and function preconditions is now capture-avoiding (262), (282).
- Quantified predicates without arguments no-longer cause a crash (279).
- We observed that 'Out of memory' errors can occur for some larger examples if using a 32-bit (rather than 64-bit) version of Z3 (286). We recommend always using a 64-bit version.