Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[WIP] Various IDE improvements and new features #1334

Draft
wants to merge 90 commits into
base: master
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
90 commits
Select commit Hold shift + click to select a range
ddb4779
collecting information
cedihegi Nov 8, 2022
bbc07cc
some updates, had a lot of problems with just passing flags...
cedihegi Nov 11, 2022
dc4b1d5
passing method calls and verification items to ide
cedihegi Nov 22, 2022
dc079fa
fixed duplicate method calls
cedihegi Dec 4, 2022
c1d86d2
Fixed the issue of no_verify causing subsequent verifications to fail…
cedihegi Dec 4, 2022
207a4ad
now finding correct defpath for function calls and also handling bino…
cedihegi Dec 10, 2022
4636373
Fixed a bug for calls where the DefId can not be found apparently.
cedihegi Dec 11, 2022
e311df9
fixed minor bug and formatting
cedihegi Dec 12, 2022
3780ce1
now finding defpath's for MethodCalls too
cedihegi Dec 12, 2022
e518ef4
Figured out how to resolve MethodCalls, but we are still in trouble..
cedihegi Dec 19, 2022
295040c
Commit finally to own fork
Dec 19, 2022
7adf64e
Finally catching all relevant method calls as far as I can tell..
cedihegi Dec 29, 2022
4943255
initial quantifier instantiations working
Jan 3, 2023
0bd03b9
generating signatures correctly in some cases, struggling with traitb…
cedihegi Jan 5, 2023
fe577dc
successfully resolving projections (it seems)
cedihegi Jan 5, 2023
dedc17b
started on generating external specs for traits
cedihegi Jan 6, 2023
8812f3d
WIP: stream messages from server to client
Jan 8, 2023
c1cbde9
Managed to subst EarlyBinders
cedihegi Jan 19, 2023
b4f93ae
Merge remote-tracking branch 'upstream/master'
cedihegi Jan 19, 2023
41e1964
Merge branch 'master' into proto-extspec
cedihegi Jan 19, 2023
6facfce
upgraded my parts to current rust version
cedihegi Jan 19, 2023
3ac17ee
Asynchronously report messages from the server to the client via WebS…
Jan 31, 2023
24ad838
refactored extern spec generation to try and make it more readable.
cedihegi Feb 4, 2023
5d141eb
renamed stuff
cedihegi Feb 7, 2023
95b78ca
Merge branch 'joseph_quant' into proto-extspec
cedihegi Feb 7, 2023
9b0b5ad
Merge remote-tracking branch 'upstream/master' into proto-extspec
cedihegi Feb 7, 2023
bb6ddb2
Adjusted viper VerificationResult so we can passe times, and whether …
cedihegi Feb 8, 2023
a4dce76
WIP: restructure the process verification a bit
Feb 8, 2023
f84219c
Fixed warnings and a bug.
cedihegi Feb 8, 2023
d9e067c
renamed a file and adjusted text for IDE information output
cedihegi Feb 12, 2023
a069cef
Finish process_verification restructuring. Add a parameter for qi.pro…
Feb 12, 2023
92c92c3
Merge remote-tracking branch 'cedric/proto-extspec' into quant
Feb 12, 2023
ca86115
Changed message for fake errors and adjusted names of CompilerInfo pr…
cedihegi Feb 13, 2023
4e1a547
Merge remote-tracking branch 'jthomme1/quant' into proto-extspec
cedihegi Feb 15, 2023
26ea0af
Add QuantifierChosenTriggersMessage reporting
Feb 15, 2023
872b3c1
Merge remote-tracking branch 'cedric/proto-extspec' into quant
Feb 15, 2023
2cbc865
passing information about specifications of calls to IDE now, called …
cedihegi Feb 16, 2023
c3a2c6f
WIP: async processing of verification info
Feb 16, 2023
5ed232e
(IDE) Contract Spans are now also collected for pedges and termatinat…
cedihegi Feb 19, 2023
91b91c4
Cleaning up unused imports and debugging print statements
cedihegi Feb 19, 2023
ba54ed7
Some minor output changes
Feb 20, 2023
e4810ec
Merge cedric's branch
Feb 20, 2023
f886f8b
Minor fixes
Feb 20, 2023
93a78c7
Merge remote-tracking branch 'upstream/master' into quant
Feb 20, 2023
9ef451a
give spans of pledges to IDE and filter out trusted methods and predi…
cedihegi Feb 21, 2023
5df2a04
Merge remote-tracking branch 'joseph/quant' into proto-extspec
cedihegi Feb 21, 2023
b6ba6f6
updated ide-parts to new compiler version
cedihegi Feb 21, 2023
f27499c
Emit everything in a compiler note/message
Feb 21, 2023
cf53b8e
Make every token CamelCase
Feb 21, 2023
158b9ad
Set config variable for viper message reporting to default false.
Feb 21, 2023
195af4d
Proper camelCase messages
Feb 22, 2023
91f4ff9
Can not automatically generate extern_specs for local methods anymore
cedihegi Feb 22, 2023
82e6063
Fix GlobalRef detaching warning. Add a few comments. Remove some debu…
Feb 22, 2023
849b18d
Better comment for the VerificationRequestProcessing global variable.
Feb 22, 2023
33a2e63
Remove leftover comment.
Feb 22, 2023
ed8b1b6
Merge remote-tracking branch 'jthomme1/quant'
cedihegi Feb 22, 2023
1b1242d
Correct formatting and removed all clippy warnings except for 2
cedihegi Feb 22, 2023
ebfdd1b
Fix last 2 clippy warnings
Feb 22, 2023
ca1d9d6
Updated viper-toolchain, added various comments / documentation, addr…
cedihegi Feb 22, 2023
137f9a2
corrected tag for recent viper-ide nightly release
cedihegi Feb 22, 2023
f79e966
updated viper-toolchain again, this time to a compatible version
cedihegi Feb 23, 2023
f2fa93a
fixed error due to new scala version
cedihegi Feb 23, 2023
5600499
made testcases compile at least, but one is hard to update to new str…
cedihegi Feb 23, 2023
7e6ceaf
Fixed prusti-server test. Why do we get a 255 exit code on a successf…
Feb 23, 2023
e8bddf0
Adjusted ui testcase that has additional note about existential quant…
cedihegi Feb 23, 2023
ede8451
Bugfixes for 2 testcases. All tests should be passing now
cedihegi Feb 23, 2023
3572fea
Add debug output
Feb 24, 2023
be04342
Merge remote-tracking branch 'cedric/master' into quant
Feb 24, 2023
7d434b5
Merge remote-tracking branch 'jthomme1/quant'
cedihegi Feb 24, 2023
bac27bf
Make cache save when not using a server
Feb 25, 2023
9ca7602
Merge remote-tracking branch 'jthomme1/quant'
cedihegi Feb 25, 2023
b373c14
Gracefully close also the receiving end of the websocket.
Feb 25, 2023
e84688f
Close the websocket connection correctly
Feb 25, 2023
2cc9233
Merge remote-tracking branch 'jthomme1/quant'
cedihegi Feb 25, 2023
c39ece5
Fix bug where successful selective verification is still cached
cedihegi Feb 25, 2023
f83a088
Fix bug in translation of spans to vscode-spans
cedihegi Feb 27, 2023
8b4563f
Bump prusti version to 0.3.0
cedihegi Mar 1, 2023
eaeef45
Update viper-toolchain version
Mar 4, 2023
82b0eb8
Implement some comments (untested)
Mar 5, 2023
a492472
Fix Z3 arguments
Mar 5, 2023
f50a367
Fix test and formatting error
Mar 5, 2023
a1e6d9f
Refactor / Fix according to code reviews
cedihegi Mar 5, 2023
b144843
Format and move old comment to right location
cedihegi Mar 5, 2023
aaa3ea5
Address reviews and add comments
cedihegi Mar 5, 2023
dc6ead0
Merge remote-tracking branch 'upstream/master'
Mar 6, 2023
1f0ae07
Improve displaying of generated extern spec block for trait
cedihegi Mar 7, 2023
e562bca
Fix some quantifier reporting weirdness
Mar 7, 2023
65c99d9
Make QI etc. also work for existential quantifiers
Mar 8, 2023
a299c14
Check if current package is primary package before throwing fake_error
cedihegi Mar 9, 2023
eb05efc
Separate trait bounds from generic args and handle bad case
cedihegi Mar 13, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
662 changes: 398 additions & 264 deletions Cargo.lock

Large diffs are not rendered by default.

38 changes: 36 additions & 2 deletions docs/dev-guide/src/config/flags.md
Original file line number Diff line number Diff line change
Expand Up @@ -55,18 +55,25 @@
| [`PRINT_DESUGARED_SPECS`](#print_desugared_specs) | `bool` | `false` | A |
| [`PRINT_HASH`](#print_hash) | `bool` | `false` | A |
| [`PRINT_TYPECKD_SPECS`](#print_typeckd_specs) | `bool` | `false` | A |
| [`QUERY_METHOD_SIGNATURE`](#query_method_signature) | `Option<String>` | `None` | A |
| [`QUIET`](#quiet) | `bool` | `false` | A* |
| [`REPORT_VIPER_MESSAGES`](#report_viper_messages) | `bool` | `false` | A |
| [`VERIFY_ONLY_DEFPATH`](#verify_only_defpath) | `Option<String>` | `None` | A |
| [`SERVER_ADDRESS`](#server_address) | `Option<String>` | `None` | A |
| [`SERVER_MAX_CONCURRENCY`](#server_max_concurrency) | `Option<usize>` | `None` | A |
| [`SERVER_MAX_STORED_VERIFIERS`](#server_max_stored_verifiers) | `Option<usize>` | `None` | A |
| [`SHOW_IDE_INFO`](#show_ide_info) | `bool` | `false` | A |
| [`SIMPLIFY_ENCODING`](#simplify_encoding) | `bool` | `true` | A |
| [`SKIP_UNSUPPORTED_FEATURES`](#skip_unsupported_features) | `bool` | `false` | A |
| [`SKIP_VERIFICATION`](#skip_verification) | `bool` | `false` | A |
| [`SMT_QI_BOUND_GLOBAL`](#smt_qi_bound_global) | `Option<u64>` | `None` | A |
[`SMT_QI_BOUND_GLOBAL_KIND`](#smt_qi_bound_global_kind) | `Option<u64>` | `None` | A |
| [`SMT_QI_BOUND_GLOBAL_KIND`](#smt_qi_bound_global_kind) | `Option<u64>` | `None` | A |
| [`SMT_QI_BOUND_TRACE`](#smt_qi_bound_trace) | `Option<u64>` | `None` | A |
| [`SMT_QI_BOUND_TRACE_KIND`](#smt_qi_bound_trace_kind) | `Option<u64>` | `None` | A |
| [`SMT_QI_IGNORE_BUILTIN`](#smt_qi_ignore_builtin) | `bool` | `true` | A |
| [`SMT_QI_EAGER_THRESHOLD`](#smt_qi_eager_threshold) | `u64` | `1000` | A |
| [`SMT_QI_IGNORE_BUILTIN`](#smt_qi_ignore_builtin) | `bool` | `true` | A |
| [`SMT_QI_PROFILE`](#smt_qi_profile) | `Option<bool>` | `None` | A |
| [`SMT_QI_PROFILE_FREQ`](#smt_qi_profile_freq) | `Option<u64>` | `None` | A |
| [`SMT_SOLVER_PATH`](#smt_solver_path) | `Option<String>` | `env::var("Z3_EXE")` | A |
| [`SMT_SOLVER_WRAPPER_PATH`](#smt_solver_wrapper_path) | `Option<String>` | `None` | A |
| [`SMT_UNIQUE_TRIGGERS_BOUND`](#smt_unique_triggers_bound) | `Option<u64>` | `None` | A |
Expand Down Expand Up @@ -351,12 +358,24 @@ When enabled, prints the hash of a verification request (the hash is used for ca

When enabled, prints the type-checked specifications.

## `QUERY_METHOD_SIGNATURE`

When set to a defpath, prusti will generate a template for an external specification for this method. The result is part of the CompilerInfo and will only be emitted if the `SHOW_IDE_INFO` flag is enabled too.

## `QUIET`

When enabled, user messages are not printed. Otherwise, messages output into `stderr`.

> **Note:** `cargo prusti` sets this flag with `DEFAULT_PRUSTI_QUIET=true`.

## `REPORT_VIPER_MESSAGES`

When enabled for both server and client, certain supported Viper messages will be reported to the user.

## `VERIFY_ONLY_DEFPATH`

When set to the defpath of a local method, prusti will only verify the specified method. A fake error will be generated to avoid caching of a success.

## `SERVER_ADDRESS`

When set to an address and port (e.g. `"127.0.0.1:2468"`), Prusti will connect to the given server and use it for its verification backend.
Expand All @@ -373,6 +392,10 @@ Maximum amount of instantiated Viper verifiers the server will keep around for r

> **Note:** This does _not_ limit how many verification requests the server handles concurrently, only the size of what is essentially its verifier cache.

## `SHOW_IDE_INFO`

When enabled, we emit various json data structures containing information about the program, its encoding, and the results of the verification. This flag intended for prusti-assistant (IDE).

## `SIMPLIFY_ENCODING`

When enabled, the encoded program is simplified before it is passed to the Viper backend.
Expand All @@ -381,6 +404,10 @@ When enabled, the encoded program is simplified before it is passed to the Viper

When enabled, features not supported by Prusti will be reported as warnings rather than errors.

## `SKIP_VERIFICATION`

When enabled, verification will be skipped. Opposed to `NO_VERIFY`, this flag will cause fake errors to stop the compiler from caching the result.

## `SMT_QI_BOUND_GLOBAL`

If not `None`, checks that the number of global quantifier instantiations reported by the SMT wrapper is smaller than the specified bound.
Expand Down Expand Up @@ -408,6 +435,13 @@ If not `None`, checks that the number of quantifier instantiations in each trace
## `SMT_QI_IGNORE_BUILTIN`

When enabled, ignores the built-in quantifiers in SMT quantifier instantiation bounds checking.
## `SMT_QI_PROFILE`

When enabled, the Z3 backend periodically (and on finish) reports the number of quantifier instantiations to Viper.

## `SMT_QI_PROFILE_FREQ`

Frequency of the quantifier instantiation reporting of Z3 (every X instantiations, a report is issued).

## `SMT_QI_EAGER_THRESHOLD`

Expand Down
7 changes: 4 additions & 3 deletions prusti-common/src/vir/program_normalization.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,9 @@
use crate::vir::{program::Program, Position};
use log::{debug, trace};
use rustc_hash::{FxHashMap, FxHashSet};
use viper::VerificationResult;
use viper::VerificationResultKind;

#[derive(Clone)]
pub enum NormalizationInfo {
LegacyProgram { original_position_ids: Vec<u64> },
LowProgram,
Expand Down Expand Up @@ -103,8 +104,8 @@ impl NormalizationInfo {
}

/// Denormalize a verification result.
pub fn denormalize_result(&self, result: &mut VerificationResult) {
if let VerificationResult::Failure(ref mut ver_errors) = result {
pub fn denormalize_result(&self, result: &mut VerificationResultKind) {
if let VerificationResultKind::Failure(ref mut ver_errors) = result {
ver_errors.iter_mut().for_each(|ver_error| {
if let Some(pos) = ver_error.pos_id.as_mut() {
self.denormalize_position_string(pos);
Expand Down
5 changes: 5 additions & 0 deletions prusti-interface/src/environment/diagnostic.rs
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,11 @@ impl<'tcx> EnvDiagnostic<'tcx> {
diagnostic.buffer(&mut self.warn_buffer.borrow_mut());
}

/// Emits a note
pub fn span_note<S: Into<MultiSpan> + Clone>(&self, sp: S, msg: &str) {
self.tcx.sess.span_note_without_error(sp, msg);
}

/// Returns true if an error has been emitted
pub fn has_errors(&self) -> bool {
self.tcx.sess.has_errors().is_some()
Expand Down
41 changes: 26 additions & 15 deletions prusti-interface/src/prusti_error.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ use prusti_rustc_interface::{errors::MultiSpan, span::Span};
/// `SpannedEncodingError` and similar types to something less confusing.)
#[derive(Clone, Debug, PartialEq, Eq)]
pub struct PrustiError {
kind: PrustiErrorKind,
kind: PrustiDiagnosticKind,
/// If `true`, it should not be reported to the user. We need this in cases
/// when the same error could be reported twice.
///
Expand All @@ -35,11 +35,12 @@ pub struct PrustiError {
}
/// Determines how a `PrustiError` is reported.
#[derive(Clone, Debug, PartialEq, Eq)]
pub enum PrustiErrorKind {
pub enum PrustiDiagnosticKind {
Error,
Warning,
/// A warning which is only shown if at least one error is emitted.
WarningOnError,
Message,
cedihegi marked this conversation as resolved.
Show resolved Hide resolved
}

impl PartialOrd for PrustiError {
Expand All @@ -60,7 +61,7 @@ impl PrustiError {
/// Private constructor. Use one of the following methods.
fn new(message: String, span: MultiSpan) -> Self {
PrustiError {
kind: PrustiErrorKind::Error,
kind: PrustiDiagnosticKind::Error,
is_disabled: false,
message,
span: Box::new(span),
Expand Down Expand Up @@ -114,7 +115,7 @@ impl PrustiError {
pub fn warning<S: ToString>(message: S, span: MultiSpan) -> Self {
check_message(message.to_string());
let mut err = PrustiError::new(format!("[Prusti: warning] {}", message.to_string()), span);
err.kind = PrustiErrorKind::Warning;
err.kind = PrustiDiagnosticKind::Warning;
err
}

Expand All @@ -123,7 +124,7 @@ impl PrustiError {
pub fn warning_on_error<S: ToString>(message: S, span: MultiSpan) -> Self {
check_message(message.to_string());
let mut err = PrustiError::new(format!("[Prusti: warning] {}", message.to_string()), span);
err.kind = PrustiErrorKind::WarningOnError;
err.kind = PrustiDiagnosticKind::WarningOnError;
err
}

Expand All @@ -146,13 +147,21 @@ impl PrustiError {
error
}

/// Report a message
pub fn message<S: ToString>(message: S, span: MultiSpan) -> Self {
check_message(message.to_string());
let mut msg = PrustiError::new(message.to_string(), span);
msg.kind = PrustiDiagnosticKind::Message;
msg
}

/// Set that this Prusti error should be reported as a warning to the user
pub fn set_warning(&mut self) {
self.kind = PrustiErrorKind::Warning;
self.kind = PrustiDiagnosticKind::Warning;
}

pub fn is_error(&self) -> bool {
matches!(self.kind, PrustiErrorKind::Error)
matches!(self.kind, PrustiDiagnosticKind::Error)
}

// FIXME: This flag is a temporary workaround for having duplicate errors
Expand Down Expand Up @@ -185,24 +194,26 @@ impl PrustiError {
pub fn emit(self, env_diagnostic: &EnvDiagnostic) {
assert!(!self.is_disabled);
match self.kind {
PrustiErrorKind::Error => env_diagnostic.span_err_with_help_and_notes(
*self.span,
&self.message,
&self.help,
&self.notes,
),
PrustiErrorKind::Warning => env_diagnostic.span_warn_with_help_and_notes(
PrustiDiagnosticKind::Error => env_diagnostic.span_err_with_help_and_notes(
*self.span,
&self.message,
&self.help,
&self.notes,
),
PrustiErrorKind::WarningOnError => env_diagnostic.span_warn_on_err_with_help_and_notes(
PrustiDiagnosticKind::Warning => env_diagnostic.span_warn_with_help_and_notes(
*self.span,
&self.message,
&self.help,
&self.notes,
),
PrustiDiagnosticKind::WarningOnError => env_diagnostic
.span_warn_on_err_with_help_and_notes(
*self.span,
&self.message,
&self.help,
&self.notes,
),
PrustiDiagnosticKind::Message => env_diagnostic.span_note(*self.span, &self.message),
};
}

Expand Down
12 changes: 10 additions & 2 deletions prusti-server/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ doctest = false
[dependencies]
log = { version = "0.4", features = ["release_max_level_info"] }
viper = { path = "../viper" }
viper-sys = { path = "../viper-sys" }
prusti-common = { path = "../prusti-common" }
prusti-utils = { path = "../prusti-utils" }
tracing = { path = "../tracing" }
Expand All @@ -28,11 +29,18 @@ bincode = "1.0"
url = "2.2.2"
num_cpus = "1.14"
serde = { version = "1.0", features = ["derive"] }
serde_json = { version = "1.0" }
tokio = "1.20"
jni = { version = "0.20", features = ["invocation"] }
# the tungstenite version used by warp 0.3
tokio-tungstenite = "0.13"
futures = "0.3.25"
futures-util = "0.3.25"
async-stream = "0.3.3"
once_cell = "1.17.0"
reqwest = { version = "0.11", default-features = false, features = ["json", "rustls-tls"] }
warp = "0.3"
tokio = "1.20"
rustc-hash = "1.1.0"
once_cell = "1.17.1"

[dev-dependencies]
lazy_static = "1.4.0"
Loading