mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-14 06:03:58 +00:00
Add time based fuel to term search
This commit is contained in:
parent
c3ab435b54
commit
d253617bba
2 changed files with 36 additions and 8 deletions
|
@ -1,5 +1,7 @@
|
||||||
//! Term search
|
//! Term search
|
||||||
|
|
||||||
|
use std::time::{Duration, Instant};
|
||||||
|
|
||||||
use hir_def::type_ref::Mutability;
|
use hir_def::type_ref::Mutability;
|
||||||
use hir_ty::db::HirDatabase;
|
use hir_ty::db::HirDatabase;
|
||||||
use itertools::Itertools;
|
use itertools::Itertools;
|
||||||
|
@ -190,11 +192,11 @@ impl LookupTable {
|
||||||
}
|
}
|
||||||
None => {
|
None => {
|
||||||
self.data.insert(ty.clone(), AlternativeExprs::new(self.many_threshold, exprs));
|
self.data.insert(ty.clone(), AlternativeExprs::new(self.many_threshold, exprs));
|
||||||
|
for it in self.new_types.values_mut() {
|
||||||
|
it.push(ty.clone());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for it in self.new_types.values_mut() {
|
|
||||||
it.push(ty.clone());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Iterate all the reachable types
|
/// Iterate all the reachable types
|
||||||
|
@ -269,13 +271,20 @@ pub struct TermSearchConfig {
|
||||||
pub enable_borrowcheck: bool,
|
pub enable_borrowcheck: bool,
|
||||||
/// Indicate when to squash multiple trees to `Many` as there are too many to keep track
|
/// Indicate when to squash multiple trees to `Many` as there are too many to keep track
|
||||||
pub many_alternatives_threshold: usize,
|
pub many_alternatives_threshold: usize,
|
||||||
/// Depth of the search eg. number of cycles to run
|
/// Depth of the search i.e. number of cycles to run
|
||||||
pub depth: usize,
|
pub depth: usize,
|
||||||
|
/// Time fuel for term search
|
||||||
|
pub fuel: Option<Duration>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Default for TermSearchConfig {
|
impl Default for TermSearchConfig {
|
||||||
fn default() -> Self {
|
fn default() -> Self {
|
||||||
Self { enable_borrowcheck: true, many_alternatives_threshold: 1, depth: 6 }
|
Self {
|
||||||
|
enable_borrowcheck: true,
|
||||||
|
many_alternatives_threshold: 1,
|
||||||
|
depth: 5,
|
||||||
|
fuel: Some(Duration::from_millis(100)),
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -294,8 +303,7 @@ impl Default for TermSearchConfig {
|
||||||
/// transformation tactics. For example functions take as from set of types (arguments) to some
|
/// transformation tactics. For example functions take as from set of types (arguments) to some
|
||||||
/// type (return type). Other transformations include methods on type, type constructors and
|
/// type (return type). Other transformations include methods on type, type constructors and
|
||||||
/// projections to struct fields (field access).
|
/// projections to struct fields (field access).
|
||||||
/// 3. Once we manage to find path to type we are interested in we continue for single round to see
|
/// 3. If we run out of fuel (term search takes too long) we stop iterating.
|
||||||
/// if we can find more paths that take us to the `goal` type.
|
|
||||||
/// 4. Return all the paths (type trees) that take us to the `goal` type.
|
/// 4. Return all the paths (type trees) that take us to the `goal` type.
|
||||||
///
|
///
|
||||||
/// Note that there are usually more ways we can get to the `goal` type but some are discarded to
|
/// Note that there are usually more ways we can get to the `goal` type but some are discarded to
|
||||||
|
@ -311,6 +319,7 @@ pub fn term_search<DB: HirDatabase>(ctx: &TermSearchCtx<'_, DB>) -> Vec<Expr> {
|
||||||
});
|
});
|
||||||
|
|
||||||
let mut lookup = LookupTable::new(ctx.config.many_alternatives_threshold, ctx.goal.clone());
|
let mut lookup = LookupTable::new(ctx.config.many_alternatives_threshold, ctx.goal.clone());
|
||||||
|
let start = Instant::now();
|
||||||
|
|
||||||
// Try trivial tactic first, also populates lookup table
|
// Try trivial tactic first, also populates lookup table
|
||||||
let mut solutions: Vec<Expr> = tactics::trivial(ctx, &defs, &mut lookup).collect();
|
let mut solutions: Vec<Expr> = tactics::trivial(ctx, &defs, &mut lookup).collect();
|
||||||
|
@ -320,11 +329,29 @@ pub fn term_search<DB: HirDatabase>(ctx: &TermSearchCtx<'_, DB>) -> Vec<Expr> {
|
||||||
for _ in 0..ctx.config.depth {
|
for _ in 0..ctx.config.depth {
|
||||||
lookup.new_round();
|
lookup.new_round();
|
||||||
|
|
||||||
|
if ctx.config.fuel.is_some_and(|timeout| start.elapsed() > timeout) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
solutions.extend(tactics::type_constructor(ctx, &defs, &mut lookup));
|
solutions.extend(tactics::type_constructor(ctx, &defs, &mut lookup));
|
||||||
|
if ctx.config.fuel.is_some_and(|timeout| start.elapsed() > timeout) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
solutions.extend(tactics::free_function(ctx, &defs, &mut lookup));
|
solutions.extend(tactics::free_function(ctx, &defs, &mut lookup));
|
||||||
|
if ctx.config.fuel.is_some_and(|timeout| start.elapsed() > timeout) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
solutions.extend(tactics::impl_method(ctx, &defs, &mut lookup));
|
solutions.extend(tactics::impl_method(ctx, &defs, &mut lookup));
|
||||||
|
if ctx.config.fuel.is_some_and(|timeout| start.elapsed() > timeout) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
solutions.extend(tactics::struct_projection(ctx, &defs, &mut lookup));
|
solutions.extend(tactics::struct_projection(ctx, &defs, &mut lookup));
|
||||||
|
if ctx.config.fuel.is_some_and(|timeout| start.elapsed() > timeout) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
solutions.extend(tactics::impl_static_method(ctx, &defs, &mut lookup));
|
solutions.extend(tactics::impl_static_method(ctx, &defs, &mut lookup));
|
||||||
|
if ctx.config.fuel.is_some_and(|timeout| start.elapsed() > timeout) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
solutions.extend(tactics::make_tuple(ctx, &defs, &mut lookup));
|
solutions.extend(tactics::make_tuple(ctx, &defs, &mut lookup));
|
||||||
|
|
||||||
// Discard not interesting `ScopeDef`s for speedup
|
// Discard not interesting `ScopeDef`s for speedup
|
||||||
|
|
|
@ -353,7 +353,8 @@ pub(crate) fn complete_expr(acc: &mut Completions, ctx: &CompletionContext<'_>)
|
||||||
config: hir::term_search::TermSearchConfig {
|
config: hir::term_search::TermSearchConfig {
|
||||||
enable_borrowcheck: false,
|
enable_borrowcheck: false,
|
||||||
many_alternatives_threshold: 1,
|
many_alternatives_threshold: 1,
|
||||||
depth: 6,
|
depth: 3,
|
||||||
|
..Default::default()
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
let exprs = hir::term_search::term_search(&term_search_ctx);
|
let exprs = hir::term_search::term_search(&term_search_ctx);
|
||||||
|
|
Loading…
Reference in a new issue