mirror of
https://github.com/Myriad-Dreamin/tinymist.git
synced 2025-11-23 12:46:43 +00:00
feat: implement expression checker (#714)
* feat: implements expression checker * dev: resolve information * dev: delete def_use * stage * stage * stage * stage concurrent * stage concurrent * dev: better concurrency * dev: final constant evaluation improvement * dev: change reference site * dev: handle comments * dev: remove indirect import structure * dev: adjust linked_def impl * dev: finalize goto definition impl * dev: replace all old import and def_use analyses with expr analysis * dev: update expr_of snapshots * dev: split def/expr, refactor definition * dev: more consistent definition solver * dev: rename definition crate * dev: references work again * dev: resolve root decl * dev: resolve root decl * dev: resolve global definitions * dev: resolve tokens with world * feat: render semantic tokens with expression information * dev: loop detection * dev: recover type checking * dev: recover more type checking * dev: refactor analysis context * fix: process case of spread left * dev: label inference * dev: recover more signature checking * dev: recover more ident reference checking * dev: pass all tests * Revert "dev: dirty changes" This reverts commit 9ae2dacd0c96851e088feea76c61c184a1cf9722. * test: update snapshot * fix: bad cached signatures * fix: slash problem
This commit is contained in:
parent
136b162360
commit
81ebc8a635
173 changed files with 5529 additions and 4370 deletions
|
|
@ -1,7 +1,5 @@
|
|||
use std::ops::Range;
|
||||
|
||||
use log::debug;
|
||||
|
||||
use crate::{prelude::*, syntax::DerefTarget, SemanticRequest};
|
||||
|
||||
/// The [`textDocument/declaration`] request asks the server for the declaration
|
||||
|
|
@ -32,35 +30,15 @@ pub struct GotoDeclarationRequest {
|
|||
impl SemanticRequest for GotoDeclarationRequest {
|
||||
type Response = GotoDeclarationResponse;
|
||||
|
||||
fn request(self, ctx: &mut AnalysisContext) -> Option<Self::Response> {
|
||||
let source = ctx.source_by_path(&self.path).ok()?;
|
||||
let deref_target = ctx.deref_syntax_at(&source, self.position, 1)?;
|
||||
let origin_selection_range = ctx.to_lsp_range(deref_target.node().range(), &source);
|
||||
|
||||
let def_use = ctx.def_use(source.clone())?;
|
||||
let ref_spans = find_declarations(ctx, def_use, deref_target)?;
|
||||
|
||||
let mut links = vec![];
|
||||
for ref_range in ref_spans {
|
||||
let uri = ctx.uri_for_id(source.id()).ok()?;
|
||||
let range = ctx.to_lsp_range(ref_range, &source);
|
||||
|
||||
links.push(LocationLink {
|
||||
origin_selection_range: Some(origin_selection_range),
|
||||
target_uri: uri,
|
||||
target_range: range,
|
||||
target_selection_range: range,
|
||||
});
|
||||
}
|
||||
|
||||
debug!("goto_declaration: {links:?}");
|
||||
Some(GotoDeclarationResponse::Link(links))
|
||||
fn request(self, _ctx: &mut AnalysisContext) -> Option<Self::Response> {
|
||||
let _ = find_declarations;
|
||||
todo!()
|
||||
}
|
||||
}
|
||||
|
||||
fn find_declarations(
|
||||
_ctx: &AnalysisContext,
|
||||
_def_use: Arc<crate::analysis::DefUseInfo>,
|
||||
_expr_info: Arc<crate::syntax::ExprInfo>,
|
||||
_deref_target: DerefTarget<'_>,
|
||||
) -> Option<Vec<Range<usize>>> {
|
||||
todo!()
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue