diff --git a/kclvm/tools/src/LSP/src/analysis.rs b/kclvm/tools/src/LSP/src/analysis.rs index ac06ca6ba..67df4039c 100644 --- a/kclvm/tools/src/LSP/src/analysis.rs +++ b/kclvm/tools/src/LSP/src/analysis.rs @@ -1,14 +1,9 @@ use crate::db::AnalysisDatabase; +use parking_lot::RwLock; use ra_ap_vfs::FileId; -use std::collections::HashMap; +use std::{collections::HashMap, sync::Arc}; #[derive(Default)] pub struct Analysis { - pub db: HashMap, -} - -impl Analysis { - pub fn set_db(&mut self, id: FileId, db: AnalysisDatabase) { - self.db.insert(id, db); - } + pub db: Arc>>, } diff --git a/kclvm/tools/src/LSP/src/completion.rs b/kclvm/tools/src/LSP/src/completion.rs index bfbf91e74..481f4d29c 100644 --- a/kclvm/tools/src/LSP/src/completion.rs +++ b/kclvm/tools/src/LSP/src/completion.rs @@ -30,7 +30,6 @@ use kclvm_sema::core::global_state::GlobalState; use kclvm_error::Position as KCLPos; use kclvm_sema::builtin::{STANDARD_SYSTEM_MODULES, STRING_MEMBER_FUNCTIONS}; use kclvm_sema::resolver::doc::{parse_doc_string, Doc}; -use kclvm_sema::resolver::scope::ProgramScope; use kclvm_sema::ty::{FunctionType, SchemaType, Type}; use lsp_types::{CompletionItem, CompletionItemKind}; @@ -78,20 +77,19 @@ pub(crate) fn completion( trigger_character: Option, program: &Program, pos: &KCLPos, - prog_scope: &ProgramScope, gs: &GlobalState, ) -> Option { match trigger_character { Some(c) => match c { - '.' => completion_dot(program, pos, prog_scope, gs), + '.' => completion_dot(program, pos, gs), '=' | ':' => completion_assign(pos, gs), - '\n' => completion_newline(program, pos, prog_scope, gs), + '\n' => completion_newline(program, pos, gs), _ => None, }, None => { let mut completions: IndexSet = IndexSet::new(); // Complete builtin pkgs if in import stmt - completions.extend(completion_import_builtin_pkg(program, pos, prog_scope)); + completions.extend(completion_import_builtin_pkg(program, pos)); if !completions.is_empty() { return Some(into_completion_items(&completions).into()); } @@ -114,29 +112,31 @@ pub(crate) fn completion( Some(def) => { let sema_info = def.get_sema_info(); let name = def.get_name(); - let ty = sema_info.ty.clone().unwrap(); - - match symbol_ref.get_kind() { - kclvm_sema::core::symbol::SymbolKind::Schema => { - let schema_ty = ty.into_schema_type(); - completions.insert(schema_ty_completion_item(&schema_ty)); - } - kclvm_sema::core::symbol::SymbolKind::Package => { - completions.insert(KCLCompletionItem { - label: name, - detail: None, - documentation: None, - kind: Some(KCLCompletionItemKind::Module), - }); - } - _ => { - completions.insert(KCLCompletionItem { - label: name, - detail: None, - documentation: None, - kind: None, - }); - } + match &sema_info.ty { + Some(ty) => match symbol_ref.get_kind() { + kclvm_sema::core::symbol::SymbolKind::Schema => { + let schema_ty = ty.into_schema_type(); + completions + .insert(schema_ty_completion_item(&schema_ty)); + } + kclvm_sema::core::symbol::SymbolKind::Package => { + completions.insert(KCLCompletionItem { + label: name, + detail: Some(ty.ty_str()), + documentation: sema_info.doc.clone(), + kind: Some(KCLCompletionItemKind::Module), + }); + } + _ => { + completions.insert(KCLCompletionItem { + label: name, + detail: Some(ty.ty_str()), + documentation: sema_info.doc.clone(), + kind: None, + }); + } + }, + None => {} } } None => {} @@ -153,7 +153,6 @@ pub(crate) fn completion( fn completion_dot( program: &Program, pos: &KCLPos, - prog_scope: &ProgramScope, gs: &GlobalState, ) -> Option { let mut items: IndexSet = IndexSet::new(); @@ -166,7 +165,7 @@ fn completion_dot( if let Some(stmt) = program.pos_to_stmt(&pre_pos) { match stmt.node { - Stmt::Import(stmt) => return completion_import(&stmt, &pre_pos, prog_scope, program), + Stmt::Import(stmt) => return completion_import(&stmt, &pre_pos, program), _ => { // Todo: string lit has not been processed using the new semantic model and need to handle here. let (expr, _) = inner_most_expr_in_stmt(&stmt.node, &pre_pos, None); @@ -310,7 +309,6 @@ fn completion_assign(pos: &KCLPos, gs: &GlobalState) -> Option Option { let mut completions: IndexSet = IndexSet::new(); @@ -373,11 +371,7 @@ fn completion_newline( Some(into_completion_items(&completions).into()) } -fn completion_import_builtin_pkg( - program: &Program, - pos: &KCLPos, - _prog_scope: &ProgramScope, -) -> IndexSet { +fn completion_import_builtin_pkg(program: &Program, pos: &KCLPos) -> IndexSet { let mut completions: IndexSet = IndexSet::new(); // completion position not contained in import stmt // import @@ -457,7 +451,6 @@ fn schema_ty_completion_item(schema_ty: &SchemaType) -> KCLCompletionItem { fn completion_import( stmt: &ImportStmt, _pos: &KCLPos, - _prog_scope: &ProgramScope, program: &Program, ) -> Option { let mut items: IndexSet = IndexSet::new(); @@ -591,7 +584,7 @@ mod tests { #[test] #[bench_test] fn var_completion_test() { - let (file, program, prog_scope, _, gs) = + let (file, program, _, _, gs) = compile_test_file("src/test_data/completion_test/dot/completion.k"); // test completion for var @@ -601,7 +594,7 @@ mod tests { column: Some(1), }; - let got = completion(None, &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(None, &program, &pos, &gs).unwrap(); let mut got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -623,7 +616,7 @@ mod tests { column: Some(4), }; - let got = completion(None, &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(None, &program, &pos, &gs).unwrap(); let mut got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -638,7 +631,7 @@ mod tests { #[test] #[bench_test] fn dot_completion_test() { - let (file, program, prog_scope, _, gs) = + let (file, program, _, _, gs) = compile_test_file("src/test_data/completion_test/dot/completion.k"); // test completion for schema attr @@ -648,7 +641,7 @@ mod tests { column: Some(7), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -664,7 +657,7 @@ mod tests { }; // test completion for str builtin function - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -682,7 +675,7 @@ mod tests { column: Some(12), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -698,7 +691,7 @@ mod tests { column: Some(12), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -712,7 +705,7 @@ mod tests { line: 19, column: Some(5), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -730,7 +723,7 @@ mod tests { column: Some(4), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -748,7 +741,7 @@ mod tests { column: Some(11), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -761,7 +754,7 @@ mod tests { #[test] #[bench_test] fn dot_completion_test_without_dot() { - let (file, program, prog_scope, _, gs) = + let (file, program, _, _, gs) = compile_test_file("src/test_data/completion_test/without_dot/completion.k"); // test completion for schema attr @@ -771,7 +764,7 @@ mod tests { column: Some(7), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -787,7 +780,7 @@ mod tests { }; // test completion for str builtin function - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -805,7 +798,7 @@ mod tests { column: Some(12), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -821,7 +814,7 @@ mod tests { column: Some(12), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -835,7 +828,7 @@ mod tests { line: 19, column: Some(5), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -853,7 +846,7 @@ mod tests { column: Some(4), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -871,7 +864,7 @@ mod tests { column: Some(11), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -884,7 +877,7 @@ mod tests { #[test] #[bench_test] fn import_builtin_package() { - let (file, program, prog_scope, _, gs) = + let (file, program, _, _, gs) = compile_test_file("src/test_data/completion_test/import/builtin_pkg.k"); let mut items: IndexSet = IndexSet::new(); @@ -895,7 +888,7 @@ mod tests { column: Some(8), }; - let got = completion(None, &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(None, &program, &pos, &gs).unwrap(); let _got_labels: Vec = match &got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -930,7 +923,7 @@ mod tests { #[test] #[bench_test] fn attr_value_completion() { - let (file, program, prog_scope, _, gs) = + let (file, program, _, _, gs) = compile_test_file("src/test_data/completion_test/assign/completion.k"); let pos = KCLPos { @@ -939,7 +932,7 @@ mod tests { column: Some(6), }; - let got = completion(Some(':'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some(':'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -952,7 +945,7 @@ mod tests { line: 16, column: Some(6), }; - let got = completion(Some(':'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some(':'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -965,7 +958,7 @@ mod tests { line: 18, column: Some(6), }; - let got = completion(Some(':'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some(':'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -978,7 +971,7 @@ mod tests { line: 20, column: Some(6), }; - let got = completion(Some(':'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some(':'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -991,7 +984,7 @@ mod tests { line: 22, column: Some(6), }; - let got = completion(Some(':'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some(':'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -1004,7 +997,7 @@ mod tests { line: 24, column: Some(6), }; - let got = completion(Some(':'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some(':'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -1017,7 +1010,7 @@ mod tests { line: 26, column: Some(6), }; - let got = completion(Some(':'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some(':'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -1029,7 +1022,7 @@ mod tests { #[test] #[bench_test] fn schema_sig_completion() { - let (file, program, prog_scope, _, gs) = + let (file, program, _, _, gs) = compile_test_file("src/test_data/completion_test/schema/schema.k"); // test completion for builtin packages @@ -1039,7 +1032,7 @@ mod tests { column: Some(5), }; - let mut got = completion(None, &program, &pos, &prog_scope, &gs).unwrap(); + let mut got = completion(None, &program, &pos, &gs).unwrap(); match &mut got { CompletionResponse::Array(arr) => { assert_eq!( @@ -1062,7 +1055,7 @@ mod tests { #[test] fn schema_attr_newline_completion() { - let (file, program, prog_scope, _, gs) = + let (file, program, _, _, gs) = compile_test_file("src/test_data/completion_test/newline/newline.k"); // test completion for builtin packages @@ -1072,7 +1065,7 @@ mod tests { column: Some(4), }; - let mut got = completion(Some('\n'), &program, &pos, &prog_scope, &gs).unwrap(); + let mut got = completion(Some('\n'), &program, &pos, &gs).unwrap(); match &mut got { CompletionResponse::Array(arr) => { arr.sort_by(|a, b| a.label.cmp(&b.label)); @@ -1093,7 +1086,7 @@ mod tests { #[test] fn schema_docstring_newline_completion() { - let (file, program, prog_scope, _, gs) = + let (file, program, _, _, gs) = compile_test_file("src/test_data/completion_test/newline/docstring_newline.k"); // test completion for builtin packages @@ -1103,7 +1096,7 @@ mod tests { column: Some(4), }; - let mut got = completion(Some('\n'), &program, &pos, &prog_scope, &gs).unwrap(); + let mut got = completion(Some('\n'), &program, &pos, &gs).unwrap(); match &mut got { CompletionResponse::Array(arr) => { arr.sort_by(|a, b| a.label.cmp(&b.label)); @@ -1124,7 +1117,7 @@ mod tests { #[test] fn str_dot_completion() { - let (file, program, prog_scope, _, gs) = + let (file, program, _, _, gs) = compile_test_file("src/test_data/completion_test/dot/lit_str/lit_str.k"); // test complete str functions when at the end of literal str @@ -1134,7 +1127,7 @@ mod tests { column: Some(10), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -1152,7 +1145,7 @@ mod tests { column: Some(6), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -1166,7 +1159,7 @@ mod tests { column: Some(5), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); match got { CompletionResponse::Array(arr) => assert!(arr.is_empty()), CompletionResponse::List(_) => panic!("test failed"), @@ -1179,7 +1172,7 @@ mod tests { column: Some(8), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); match got { CompletionResponse::Array(arr) => assert!(arr.is_empty()), CompletionResponse::List(_) => panic!("test failed"), diff --git a/kclvm/tools/src/LSP/src/db.rs b/kclvm/tools/src/LSP/src/db.rs index 4dc2f3688..b2bce8fa1 100644 --- a/kclvm/tools/src/LSP/src/db.rs +++ b/kclvm/tools/src/LSP/src/db.rs @@ -1,13 +1,12 @@ use indexmap::IndexSet; use kclvm_ast::ast::Program; use kclvm_error::Diagnostic; -use kclvm_sema::{core::global_state::GlobalState, resolver::scope::ProgramScope}; +use kclvm_sema::core::global_state::GlobalState; /// Holds the result of the compile #[derive(Default, Clone)] pub struct AnalysisDatabase { pub prog: Program, - pub scope: ProgramScope, pub diags: IndexSet, pub gs: GlobalState, } diff --git a/kclvm/tools/src/LSP/src/find_refs.rs b/kclvm/tools/src/LSP/src/find_refs.rs index fbd4865a9..2a57390b5 100644 --- a/kclvm/tools/src/LSP/src/find_refs.rs +++ b/kclvm/tools/src/LSP/src/find_refs.rs @@ -7,7 +7,6 @@ use kclvm_ast::ast::Program; use kclvm_error::Position as KCLPos; use kclvm_parser::KCLModuleCache; use kclvm_sema::core::global_state::GlobalState; -use kclvm_sema::resolver::scope::ProgramScope; use lsp_types::{Location, Url}; use parking_lot::RwLock; use ra_ap_vfs::Vfs; @@ -18,7 +17,6 @@ pub(crate) fn find_refs Result<(), anyhow::Error>>( _program: &Program, kcl_pos: &KCLPos, include_declaration: bool, - _prog_scope: &ProgramScope, word_index_map: Arc>>>>, vfs: Option>>, logger: F, @@ -86,15 +84,13 @@ pub(crate) fn find_refs_from_def Result<(), anyhow::Error>>( }, vfs.clone(), ) { - Ok((prog, scope, _, gs)) => { + Ok((prog, _, _, gs)) => { let ref_pos = kcl_pos(&file_path, ref_loc.range.start); if *ref_loc == def_loc && !include_declaration { return false; } // find def from the ref_pos - if let Some(real_def) = - goto_definition_with_gs(&prog, &ref_pos, &scope, &gs) - { + if let Some(real_def) = goto_definition_with_gs(&prog, &ref_pos, &gs) { match real_def { lsp_types::GotoDefinitionResponse::Scalar(real_def_loc) => { real_def_loc == def_loc diff --git a/kclvm/tools/src/LSP/src/goto_def.rs b/kclvm/tools/src/LSP/src/goto_def.rs index dc34f715d..7cc5d310a 100644 --- a/kclvm/tools/src/LSP/src/goto_def.rs +++ b/kclvm/tools/src/LSP/src/goto_def.rs @@ -13,14 +13,12 @@ use kclvm_ast::ast::Program; use kclvm_error::Position as KCLPos; use kclvm_sema::core::global_state::GlobalState; use kclvm_sema::core::symbol::SymbolRef; -use kclvm_sema::resolver::scope::ProgramScope; use lsp_types::GotoDefinitionResponse; // Navigates to the definition of an identifier. pub(crate) fn goto_definition_with_gs( _program: &Program, kcl_pos: &KCLPos, - _prog_scope: &ProgramScope, gs: &GlobalState, ) -> Option { let mut res = IndexSet::new(); @@ -110,15 +108,14 @@ mod tests { #[bench_test] fn goto_import_pkg_test() { let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let pos = KCLPos { filename: file, line: 1, column: Some(10), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); let mut expected_files = IndexSet::new(); let path_str = path.to_str().unwrap(); @@ -148,8 +145,7 @@ mod tests { fn goto_import_file_test() { let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let mut expected_path = path; expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); @@ -160,7 +156,7 @@ mod tests { line: 2, column: Some(10), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); match res.unwrap() { lsp_types::GotoDefinitionResponse::Scalar(loc) => { let got_path = loc.uri.path(); @@ -177,8 +173,7 @@ mod tests { fn goto_pkg_prefix_def_test() { let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); // test goto pkg prefix def: p = pkg.Person { <- pkg let pos = KCLPos { @@ -186,7 +181,7 @@ mod tests { line: 4, column: Some(7), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); let mut expected_files = IndexSet::new(); let path_str = path.to_str().unwrap(); let test_files = [ @@ -215,8 +210,7 @@ mod tests { fn goto_schema_def_test() { let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let mut expected_path = path; expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); @@ -228,7 +222,7 @@ mod tests { column: Some(11), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res( res, (&expected_path.to_str().unwrap().to_string(), 0, 7, 0, 13), @@ -240,8 +234,7 @@ mod tests { fn goto_var_def_in_config_and_config_if_test() { let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let mut expected_path = path; expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); @@ -251,7 +244,7 @@ mod tests { line: 67, column: Some(36), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res(res, (&file, 65, 11, 65, 14)); let pos = KCLPos { @@ -260,7 +253,7 @@ mod tests { column: Some(44), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res(res, (&file, 65, 16, 65, 21)); let pos = KCLPos { filename: file.clone(), @@ -268,7 +261,7 @@ mod tests { column: Some(11), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res(res, (&file, 69, 6, 69, 10)); let pos = KCLPos { filename: file.clone(), @@ -276,7 +269,7 @@ mod tests { column: Some(10), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res(res, (&file, 69, 6, 69, 10)); } @@ -285,8 +278,7 @@ mod tests { fn goto_var_def_in_dict_comp_test() { let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let mut expected_path = path; expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); @@ -297,7 +289,7 @@ mod tests { column: Some(68), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res(res, (&file, 76, 143, 76, 145)); let pos = KCLPos { @@ -306,7 +298,7 @@ mod tests { column: Some(61), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res(res, (&file, 76, 143, 76, 145)); } @@ -315,8 +307,7 @@ mod tests { fn goto_schema_attr_def_test() { let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, program, prog_scope, _m, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let mut expected_path = path; expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); @@ -328,7 +319,7 @@ mod tests { column: Some(7), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res( res, (&expected_path.to_str().unwrap().to_string(), 4, 4, 4, 8), @@ -340,8 +331,7 @@ mod tests { fn goto_schema_attr_def_test1() { let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let mut expected_path = path; expected_path.push("src/test_data/goto_def_test/goto_def.k"); @@ -353,7 +343,7 @@ mod tests { column: Some(12), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res( res, (&expected_path.to_str().unwrap().to_string(), 18, 4, 18, 8), @@ -365,8 +355,7 @@ mod tests { fn test_goto_identifier_names() { let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let mut expected_path = path; expected_path.push("src/test_data/goto_def_test/goto_def.k"); @@ -378,7 +367,7 @@ mod tests { column: Some(5), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res( res, (&expected_path.to_str().unwrap().to_string(), 23, 0, 23, 2), @@ -391,7 +380,7 @@ mod tests { column: Some(8), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res( res, (&expected_path.to_str().unwrap().to_string(), 21, 1, 21, 2), @@ -404,7 +393,7 @@ mod tests { column: Some(12), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res( res, (&expected_path.to_str().unwrap().to_string(), 18, 4, 18, 8), @@ -414,8 +403,7 @@ mod tests { #[test] #[bench_test] fn goto_identifier_def_test() { - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); // test goto identifier definition: p1 = p let pos = KCLPos { @@ -424,7 +412,7 @@ mod tests { column: Some(6), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res(res, (&file, 3, 0, 3, 1)); } @@ -433,8 +421,7 @@ mod tests { fn goto_assign_type_test() { let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let mut expected_path = path; expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); @@ -446,7 +433,7 @@ mod tests { column: Some(17), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res(res, (&file, 33, 7, 33, 15)); } @@ -456,8 +443,7 @@ mod tests { // test goto schema attr type definition: p1: pkg.Person let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let mut expected_path = path; expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); @@ -468,7 +454,7 @@ mod tests { column: Some(15), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res( res, (&expected_path.to_str().unwrap().to_string(), 0, 7, 0, 13), @@ -481,8 +467,7 @@ mod tests { // test goto schema attr type definition: p2: [pkg.Person] let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let mut expected_path = path; expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); @@ -492,7 +477,7 @@ mod tests { line: 13, column: Some(15), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res( res, (&expected_path.to_str().unwrap().to_string(), 0, 7, 0, 13), @@ -505,8 +490,7 @@ mod tests { // test goto schema attr type definition: p3: {str: pkg.Person} let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let mut expected_path = path; expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); @@ -516,7 +500,7 @@ mod tests { line: 14, column: Some(22), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res( res, (&expected_path.to_str().unwrap().to_string(), 0, 7, 0, 13), @@ -529,8 +513,7 @@ mod tests { // test goto schema attr type definition(Person): p4: pkg.Person | pkg.Person1 let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let mut expected_path = path; expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); @@ -541,7 +524,7 @@ mod tests { column: Some(17), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res( res, (&expected_path.to_str().unwrap().to_string(), 0, 7, 0, 13), @@ -554,8 +537,7 @@ mod tests { // test goto schema attr type definition(Person1): p4: pkg.Person | pkg.Person1 let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let mut expected_path = path; expected_path.push("src/test_data/goto_def_test/pkg/schema_def1.k"); @@ -565,7 +547,7 @@ mod tests { line: 15, column: Some(28), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res( res, (&expected_path.to_str().unwrap().to_string(), 0, 7, 0, 14), @@ -577,8 +559,7 @@ mod tests { fn goto_local_var_def_test() { let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let mut expected_path = path; expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); @@ -590,7 +571,7 @@ mod tests { column: Some(11), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res(res, (&file, 43, 4, 43, 9)); let pos = KCLPos { @@ -599,7 +580,7 @@ mod tests { column: Some(11), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res(res, (&file, 43, 4, 43, 9)); let pos = KCLPos { @@ -608,15 +589,14 @@ mod tests { column: Some(11), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res(res, (&file, 43, 4, 43, 9)); } #[test] #[bench_test] fn complex_select_goto_def() { - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let pos = KCLPos { filename: file.clone(), @@ -624,15 +604,14 @@ mod tests { column: Some(22), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res(res, (&file, 43, 4, 43, 9)); } #[test] #[bench_test] fn schema_attribute_def_goto_def() { - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let pos = KCLPos { filename: file.clone(), @@ -640,15 +619,14 @@ mod tests { column: Some(5), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res(res, (&file, 18, 4, 18, 8)); } #[test] #[bench_test] fn config_desuger_def_goto_def() { - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let pos = KCLPos { filename: file.clone(), @@ -656,15 +634,14 @@ mod tests { column: Some(9), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res(res, (&file, 18, 4, 18, 8)); } #[test] #[bench_test] fn lambda_param_goto_def() { - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let pos = KCLPos { filename: file.clone(), @@ -672,7 +649,7 @@ mod tests { column: Some(4), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res(res, (&file, 84, 14, 84, 15)); let pos = KCLPos { @@ -681,7 +658,7 @@ mod tests { column: Some(8), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); compare_goto_res(res, (&file, 84, 22, 84, 23)); } } diff --git a/kclvm/tools/src/LSP/src/hover.rs b/kclvm/tools/src/LSP/src/hover.rs index e81c880cd..6e9fb78f1 100644 --- a/kclvm/tools/src/LSP/src/hover.rs +++ b/kclvm/tools/src/LSP/src/hover.rs @@ -2,7 +2,6 @@ use kclvm_ast::ast::Program; use kclvm_error::Position as KCLPos; use kclvm_sema::{ core::global_state::GlobalState, - resolver::scope::ProgramScope, ty::{FunctionType, SchemaType}, }; use lsp_types::{Hover, HoverContents, MarkedString}; @@ -14,7 +13,6 @@ use crate::goto_def::find_def_with_gs; pub(crate) fn hover( _program: &Program, kcl_pos: &KCLPos, - _prog_scope: &ProgramScope, gs: &GlobalState, ) -> Option { let mut docs: Vec = vec![]; @@ -173,8 +171,7 @@ mod tests { fn schema_doc_hover_test() { let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/goto_def_test/goto_def.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); let mut expected_path = path; expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); @@ -185,7 +182,7 @@ mod tests { line: 4, column: Some(11), }; - let got = hover(&program, &pos, &prog_scope, &gs).unwrap(); + let got = hover(&program, &pos, &gs).unwrap(); match got.contents { lsp_types::HoverContents::Array(vec) => { if let MarkedString::String(s) = vec[0].clone() { @@ -205,7 +202,7 @@ mod tests { line: 5, column: Some(7), }; - let got = hover(&program, &pos, &prog_scope, &gs).unwrap(); + let got = hover(&program, &pos, &gs).unwrap(); match got.contents { lsp_types::HoverContents::Scalar(marked_string) => { if let MarkedString::String(s) = marked_string { @@ -219,15 +216,14 @@ mod tests { #[test] #[bench_test] fn schema_doc_hover_test1() { - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/hover_test/hover.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/hover_test/hover.k"); let pos = KCLPos { filename: file.clone(), line: 16, column: Some(8), }; - let got = hover(&program, &pos, &prog_scope, &gs).unwrap(); + let got = hover(&program, &pos, &gs).unwrap(); match got.contents { lsp_types::HoverContents::Array(vec) => { @@ -248,15 +244,14 @@ mod tests { #[test] #[bench_test] fn schema_attr_hover_test() { - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/hover_test/hover.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/hover_test/hover.k"); let pos = KCLPos { filename: file.clone(), line: 17, column: Some(7), }; - let got = hover(&program, &pos, &prog_scope, &gs).unwrap(); + let got = hover(&program, &pos, &gs).unwrap(); match got.contents { lsp_types::HoverContents::Array(vec) => { @@ -275,7 +270,7 @@ mod tests { line: 18, column: Some(7), }; - let got = hover(&program, &pos, &prog_scope, &gs).unwrap(); + let got = hover(&program, &pos, &gs).unwrap(); match got.contents { lsp_types::HoverContents::Array(vec) => { @@ -293,15 +288,14 @@ mod tests { #[test] #[bench_test] fn func_def_hover() { - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/hover_test/hover.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/hover_test/hover.k"); let pos = KCLPos { filename: file.clone(), line: 22, column: Some(18), }; - let got = hover(&program, &pos, &prog_scope, &gs).unwrap(); + let got = hover(&program, &pos, &gs).unwrap(); match got.contents { lsp_types::HoverContents::Array(vec) => { @@ -324,7 +318,7 @@ mod tests { line: 23, column: Some(14), }; - let got = hover(&program, &pos, &prog_scope, &gs).unwrap(); + let got = hover(&program, &pos, &gs).unwrap(); match got.contents { lsp_types::HoverContents::Array(vec) => { @@ -347,7 +341,7 @@ mod tests { line: 25, column: Some(4), }; - let got = hover(&program, &pos, &prog_scope, &gs).unwrap(); + let got = hover(&program, &pos, &gs).unwrap(); match got.contents { lsp_types::HoverContents::Array(vec) => { @@ -366,14 +360,13 @@ mod tests { #[test] #[bench_test] fn complex_select_hover() { - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/hover_test/fib.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/hover_test/fib.k"); let pos = KCLPos { filename: file.clone(), line: 14, column: Some(22), }; - let got = hover(&program, &pos, &prog_scope, &gs).unwrap(); + let got = hover(&program, &pos, &gs).unwrap(); match got.contents { lsp_types::HoverContents::Scalar(marked_string) => { if let MarkedString::String(s) = marked_string { @@ -387,14 +380,14 @@ mod tests { #[test] #[bench_test] fn assignment_ty_in_lambda_hover() { - let (file, program, prog_scope, _, gs) = + let (file, program, _, _, gs) = compile_test_file("src/test_data/hover_test/ty_in_lambda.k"); let pos = KCLPos { filename: file.clone(), line: 3, column: Some(8), }; - let got = hover(&program, &pos, &prog_scope, &gs).unwrap(); + let got = hover(&program, &pos, &gs).unwrap(); match got.contents { lsp_types::HoverContents::Scalar(marked_string) => { if let MarkedString::String(s) = marked_string { @@ -408,14 +401,13 @@ mod tests { #[test] #[bench_test] fn str_var_func_hover() { - let (file, program, prog_scope, _, gs) = - compile_test_file("src/test_data/hover_test/hover.k"); + let (file, program, _, _, gs) = compile_test_file("src/test_data/hover_test/hover.k"); let pos = KCLPos { filename: file.clone(), line: 28, column: Some(12), }; - let got = hover(&program, &pos, &prog_scope, &gs).unwrap(); + let got = hover(&program, &pos, &gs).unwrap(); match got.contents { lsp_types::HoverContents::Array(vec) => { assert_eq!(vec.len(), 3); diff --git a/kclvm/tools/src/LSP/src/request.rs b/kclvm/tools/src/LSP/src/request.rs index 743525ffc..dccc0186c 100644 --- a/kclvm/tools/src/LSP/src/request.rs +++ b/kclvm/tools/src/LSP/src/request.rs @@ -1,6 +1,7 @@ -use anyhow::{anyhow, Ok}; +use anyhow::anyhow; use crossbeam_channel::Sender; +use kclvm_config::modfile::KCL_FILE_SUFFIX; use kclvm_sema::info::is_valid_kcl_name; use lsp_types::{Location, TextEdit}; use ra_ap_vfs::VfsPath; @@ -68,6 +69,7 @@ impl LanguageServerSnapshot { let res = self.vfs.read().file_id(path).is_some() && self .db + .read() .get(&self.vfs.read().file_id(path).unwrap()) .is_some(); if !res { @@ -76,10 +78,10 @@ impl LanguageServerSnapshot { res } - pub(crate) fn get_db(&self, path: &VfsPath) -> anyhow::Result<&AnalysisDatabase> { + pub(crate) fn get_db(&self, path: &VfsPath) -> anyhow::Result { match self.vfs.read().file_id(path) { - Some(id) => match self.db.get(&id) { - Some(db) => Ok(db), + Some(id) => match self.db.read().get(&id) { + Some(db) => Ok(db.clone()), None => Err(anyhow::anyhow!(format!( "Path {path} AnalysisDatabase not found" ))), @@ -148,7 +150,7 @@ pub(crate) fn handle_goto_definition( } let db = snapshot.get_db(&path.clone().into())?; let kcl_pos = kcl_pos(&file, params.text_document_position_params.position); - let res = goto_definition_with_gs(&db.prog, &kcl_pos, &db.scope, &db.gs); + let res = goto_definition_with_gs(&db.prog, &kcl_pos, &db.gs); if res.is_none() { log_message("Definition item not found".to_string(), &sender)?; } @@ -175,7 +177,6 @@ pub(crate) fn handle_reference( &db.prog, &pos, include_declaration, - &db.scope, snapshot.word_index_map.clone(), Some(snapshot.vfs.clone()), log, @@ -202,22 +203,39 @@ pub(crate) fn handle_completion( return Ok(None); } - let db = parse_param_and_compile( - Param { - file: file.clone(), - module_cache: snapshot.module_cache.clone(), - }, - Some(snapshot.vfs.clone()), - ) - .unwrap(); - let kcl_pos = kcl_pos(&file, params.text_document_position.position); let completion_trigger_character = params .context .and_then(|ctx| ctx.trigger_character) .and_then(|s| s.chars().next()); + let (prog, gs) = match completion_trigger_character { + // Some trigger characters need to re-compile + Some(ch) => match ch { + '=' | ':' => { + match parse_param_and_compile( + Param { + file: file.clone(), + module_cache: snapshot.module_cache.clone(), + }, + Some(snapshot.vfs.clone()), + ) { + Ok((prog, _, _, gs)) => (prog, gs), + Err(_) => return Ok(None), + } + } + _ => { + let db = snapshot.get_db(&path.clone().into())?; + (db.prog, db.gs) + } + }, - let res = completion(completion_trigger_character, &db.0, &kcl_pos, &db.1, &db.3); + None => { + let db = snapshot.get_db(&path.clone().into())?; + (db.prog, db.gs) + } + }; + + let res = completion(completion_trigger_character, &prog, &kcl_pos, &gs); if res.is_none() { log_message("Completion item not found".to_string(), &sender)?; @@ -238,7 +256,7 @@ pub(crate) fn handle_hover( } let db = snapshot.get_db(&path.clone().into())?; let kcl_pos = kcl_pos(&file, params.text_document_position_params.position); - let res = hover::hover(&db.prog, &kcl_pos, &db.scope, &db.gs); + let res = hover::hover(&db.prog, &kcl_pos, &db.gs); if res.is_none() { log_message("Hover definition not found".to_string(), &sender)?; } @@ -253,15 +271,28 @@ pub(crate) fn handle_document_symbol( ) -> anyhow::Result> { let file = file_path_from_url(¶ms.text_document.uri)?; let path = from_lsp::abs_path(¶ms.text_document.uri)?; - if !snapshot.verify_request_path(&path.clone().into(), &sender) { + if !snapshot.verify_request_path(&path.clone().into(), &sender) + && !file.ends_with(KCL_FILE_SUFFIX) + { return Ok(None); } - let db = snapshot.get_db(&path.clone().into())?; - let res = document_symbol(&file, &db.gs); - if res.is_none() { - log_message(format!("File {file} Document symbol not found"), &sender)?; + + match parse_param_and_compile( + Param { + file: file.clone(), + module_cache: snapshot.module_cache.clone(), + }, + Some(snapshot.vfs.clone()), + ) { + Ok((_, _, _, gs)) => { + let res = document_symbol(&file, &gs); + if res.is_none() { + log_message(format!("File {file} Document symbol not found"), &sender)?; + } + Ok(res) + } + Err(_) => return Ok(None), } - Ok(res) } /// Called when a `textDocument/rename` request was received. @@ -289,7 +320,6 @@ pub(crate) fn handle_rename( &db.prog, &kcl_pos, true, - &db.scope, snapshot.word_index_map.clone(), Some(snapshot.vfs.clone()), log, diff --git a/kclvm/tools/src/LSP/src/state.rs b/kclvm/tools/src/LSP/src/state.rs index e2ab329a1..8c00b5708 100644 --- a/kclvm/tools/src/LSP/src/state.rs +++ b/kclvm/tools/src/LSP/src/state.rs @@ -87,7 +87,7 @@ pub(crate) struct LanguageServerSnapshot { /// The virtual filesystem that holds all the file contents pub vfs: Arc>, /// Holds the state of the analysis process - pub db: HashMap, + pub db: Arc>>, /// Documents that are currently kept in memory from the client pub opened_files: IndexSet, /// The word index map @@ -165,27 +165,18 @@ impl LanguageServerState { // 1. Process the incoming event match event { Event::Task(task) => self.handle_task(task)?, - Event::Lsp(msg) => match msg { - lsp_server::Message::Request(req) => self.on_request(req, start_time)?, - lsp_server::Message::Notification(not) => self.on_notification(not)?, - // lsp_server::Message::Response(resp) => self.complete_request(resp), - _ => {} - }, + Event::Lsp(msg) => { + match msg { + lsp_server::Message::Request(req) => self.on_request(req, start_time)?, + lsp_server::Message::Notification(not) => self.on_notification(not)?, + // lsp_server::Message::Response(resp) => self.complete_request(resp), + _ => {} + } + } }; // 2. Process changes - let state_changed: bool = self.process_vfs_changes(); - - // 3. Handle Diagnostics - if state_changed { - let mut snapshot = self.snapshot(); - let task_sender = self.task_sender.clone(); - // Spawn the diagnostics in the threadpool - self.thread_pool.execute(move || { - let _result = handle_diagnostics(snapshot, task_sender); - }); - } - + self.process_vfs_changes(); Ok(()) } @@ -208,28 +199,57 @@ impl LanguageServerState { let start = Instant::now(); match get_file_name(vfs, file.file_id) { Ok(filename) => { - match parse_param_and_compile( - Param { - file: filename.clone(), - module_cache: self.module_cache.clone(), - }, - Some(self.vfs.clone()), - ) { - Ok((prog, scope, diags, gs)) => { - let end = start.elapsed(); - self.log_message(format!("compile time: {:?}s", end.as_secs_f32())); - self.analysis.set_db( - file.file_id, - AnalysisDatabase { - prog, - scope, - diags, - gs, - }, - ); + self.thread_pool.execute({ + let mut snapshot = self.snapshot(); + let sender = self.task_sender.clone(); + let module_cache = self.module_cache.clone(); + move || match url(&snapshot, file.file_id) { + Ok(uri) => { + match parse_param_and_compile( + Param { + file: filename.clone(), + module_cache, + }, + Some(snapshot.vfs), + ) { + Ok((prog, _, diags, gs)) => { + let mut db = snapshot.db.write(); + db.insert( + file.file_id, + AnalysisDatabase { + prog, + diags: diags.clone(), + gs, + }, + ); + + let diagnostics = diags + .iter() + .flat_map(|diag| { + kcl_diag_to_lsp_diags(diag, filename.as_str()) + }) + .collect::>(); + sender.send(Task::Notify(lsp_server::Notification { + method: PublishDiagnostics::METHOD.to_owned(), + params: to_json(PublishDiagnosticsParams { + uri, + diagnostics, + version: None, + }) + .unwrap(), + })); + } + Err(_) => {} + } + } + Err(_) => { + log_message( + format!("Interal bug: not a valid file:{:?}", filename), + &sender, + ); + } } - Err(_) => self.log_message(format!("{filename} compilation failed")), - } + }); } Err(_) => { self.log_message(format!("{:?} not found", file.file_id)); @@ -302,37 +322,6 @@ impl LanguageServerState { } } -fn handle_diagnostics( - snapshot: LanguageServerSnapshot, - sender: Sender, -) -> anyhow::Result<()> { - for file_id in &snapshot.opened_files { - let vfs = snapshot.vfs.read(); - let filename = get_file_name(vfs, *file_id)?; - let uri = url(&snapshot, *file_id)?; - - match snapshot.db.get(file_id) { - Some(db) => { - let diagnostics = db - .diags - .iter() - .flat_map(|diag| kcl_diag_to_lsp_diags(diag, filename.as_str())) - .collect::>(); - sender.send(Task::Notify(lsp_server::Notification { - method: PublishDiagnostics::METHOD.to_owned(), - params: to_json(PublishDiagnosticsParams { - uri, - diagnostics, - version: None, - })?, - }))?; - } - None => continue, - } - } - Ok(()) -} - pub(crate) fn log_message(message: String, sender: &Sender) -> anyhow::Result<()> { let typ = lsp_types::MessageType::INFO; sender.send(Task::Notify(lsp_server::Notification::new( diff --git a/kclvm/tools/src/LSP/src/tests.rs b/kclvm/tools/src/LSP/src/tests.rs index c8e10bc1c..4881d8326 100644 --- a/kclvm/tools/src/LSP/src/tests.rs +++ b/kclvm/tools/src/LSP/src/tests.rs @@ -408,7 +408,7 @@ fn complete_import_external_file_test() { .output() .unwrap(); - let (program, prog_scope, _, gs) = parse_param_and_compile( + let (program, _, _, gs) = parse_param_and_compile( Param { file: path.to_string(), module_cache: None, @@ -422,7 +422,7 @@ fn complete_import_external_file_test() { line: 1, column: Some(11), }; - let res = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let res = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match &res { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), @@ -466,7 +466,7 @@ fn goto_import_external_file_test() { .output() .unwrap(); - let (program, prog_scope, diags, gs) = parse_param_and_compile( + let (program, _, diags, gs) = parse_param_and_compile( Param { file: path.to_string(), module_cache: None, @@ -483,7 +483,7 @@ fn goto_import_external_file_test() { line: 1, column: Some(15), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); assert!(res.is_some()); } @@ -843,6 +843,7 @@ fn goto_def_test() { }, ); + thread::sleep(Duration::from_secs(1)); let id = server.next_request_id.get(); server.next_request_id.set(id.wrapping_add(1)); @@ -899,6 +900,7 @@ fn complete_test() { }, }, ); + thread::sleep(Duration::from_secs(1)); let id = server.next_request_id.get(); server.next_request_id.set(id.wrapping_add(1)); @@ -967,6 +969,7 @@ fn hover_test() { }, }, ); + thread::sleep(Duration::from_secs(1)); let id = server.next_request_id.get(); server.next_request_id.set(id.wrapping_add(1)); @@ -1024,6 +1027,7 @@ fn hover_assign_in_lambda_test() { }, }, ); + thread::sleep(Duration::from_secs(1)); let id = server.next_request_id.get(); server.next_request_id.set(id.wrapping_add(1)); @@ -1131,7 +1135,7 @@ fn konfig_goto_def_test_base() { let mut base_path = konfig_path.clone(); base_path.push("appops/nginx-example/base/base.k"); let base_path_str = base_path.to_str().unwrap().to_string(); - let (program, prog_scope, _, gs) = parse_param_and_compile( + let (program, _, _, gs) = parse_param_and_compile( Param { file: base_path_str.clone(), module_cache: None, @@ -1146,7 +1150,7 @@ fn konfig_goto_def_test_base() { line: 7, column: Some(30), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); let mut expected_path = konfig_path.clone(); expected_path.push("base/pkg/kusion_models/kube/frontend/server.k"); compare_goto_res( @@ -1160,7 +1164,7 @@ fn konfig_goto_def_test_base() { line: 9, column: Some(32), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); let mut expected_path = konfig_path.clone(); expected_path.push("base/pkg/kusion_models/kube/frontend/container/container.k"); compare_goto_res( @@ -1174,7 +1178,7 @@ fn konfig_goto_def_test_base() { line: 9, column: Some(9), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); let mut expected_path = konfig_path.clone(); expected_path.push("base/pkg/kusion_models/kube/frontend/server.k"); compare_goto_res( @@ -1194,7 +1198,7 @@ fn konfig_goto_def_test_base() { line: 10, column: Some(10), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); let mut expected_path = konfig_path.clone(); expected_path.push("base/pkg/kusion_models/kube/frontend/container/container.k"); compare_goto_res( @@ -1208,7 +1212,7 @@ fn konfig_goto_def_test_base() { line: 2, column: Some(49), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); let mut expected_path = konfig_path.clone(); expected_path.push("base/pkg/kusion_models/kube/frontend/service/service.k"); compare_goto_res( @@ -1223,7 +1227,7 @@ fn konfig_goto_def_test_main() { let mut main_path = konfig_path.clone(); main_path.push("appops/nginx-example/dev/main.k"); let main_path_str = main_path.to_str().unwrap().to_string(); - let (program, prog_scope, _, gs) = parse_param_and_compile( + let (program, _, _, gs) = parse_param_and_compile( Param { file: main_path_str.clone(), module_cache: None, @@ -1238,7 +1242,7 @@ fn konfig_goto_def_test_main() { line: 6, column: Some(31), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); let mut expected_path = konfig_path.clone(); expected_path.push("base/pkg/kusion_models/kube/frontend/server.k"); compare_goto_res( @@ -1252,7 +1256,7 @@ fn konfig_goto_def_test_main() { line: 7, column: Some(14), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); let mut expected_path = konfig_path.clone(); expected_path.push("base/pkg/kusion_models/kube/frontend/server.k"); compare_goto_res( @@ -1272,7 +1276,7 @@ fn konfig_goto_def_test_main() { line: 2, column: Some(61), }; - let res = goto_definition_with_gs(&program, &pos, &prog_scope, &gs); + let res = goto_definition_with_gs(&program, &pos, &gs); let mut expected_path = konfig_path.clone(); expected_path.push("base/pkg/kusion_models/kube/templates/resource.k"); compare_goto_res( @@ -1287,7 +1291,7 @@ fn konfig_completion_test_main() { let mut main_path = konfig_path.clone(); main_path.push("appops/nginx-example/dev/main.k"); let main_path_str = main_path.to_str().unwrap().to_string(); - let (program, prog_scope, _, gs) = parse_param_and_compile( + let (program, _, _, gs) = parse_param_and_compile( Param { file: main_path_str.clone(), module_cache: None, @@ -1302,7 +1306,7 @@ fn konfig_completion_test_main() { line: 6, column: Some(27), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -1320,7 +1324,7 @@ fn konfig_completion_test_main() { line: 7, column: Some(4), }; - let got = completion(None, &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(None, &program, &pos, &gs).unwrap(); let mut got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -1403,7 +1407,7 @@ fn konfig_completion_test_main() { line: 1, column: Some(35), }; - let got = completion(Some('.'), &program, &pos, &prog_scope, &gs).unwrap(); + let got = completion(Some('.'), &program, &pos, &gs).unwrap(); let mut got_labels: Vec = match got { CompletionResponse::Array(arr) => arr.iter().map(|item| item.label.clone()).collect(), CompletionResponse::List(_) => panic!("test failed"), @@ -1434,7 +1438,7 @@ fn konfig_hover_test_main() { let mut main_path = konfig_path.clone(); main_path.push("appops/nginx-example/dev/main.k"); let main_path_str = main_path.to_str().unwrap().to_string(); - let (program, prog_scope, _, gs) = parse_param_and_compile( + let (program, _, _, gs) = parse_param_and_compile( Param { file: main_path_str.clone(), module_cache: None, @@ -1449,7 +1453,7 @@ fn konfig_hover_test_main() { line: 6, column: Some(32), }; - let got = hover(&program, &pos, &prog_scope, &gs).unwrap(); + let got = hover(&program, &pos, &gs).unwrap(); match got.contents { HoverContents::Array(arr) => { let expect: Vec = ["base.pkg.kusion_models.kube.frontend\n\nschema Server", @@ -1469,7 +1473,7 @@ fn konfig_hover_test_main() { line: 7, column: Some(15), }; - let got = hover(&program, &pos, &prog_scope, &gs).unwrap(); + let got = hover(&program, &pos, &gs).unwrap(); match got.contents { HoverContents::Array(arr) => { let expect: Vec = [ @@ -1490,7 +1494,7 @@ fn konfig_hover_test_main() { line: 6, column: Some(3), }; - let got = hover(&program, &pos, &prog_scope, &gs).unwrap(); + let got = hover(&program, &pos, &gs).unwrap(); match got.contents { HoverContents::Scalar(s) => { assert_eq!( @@ -1582,6 +1586,8 @@ fn find_refs_test() { }, ); + thread::sleep(Duration::from_secs(1)); + let id = server.next_request_id.get(); server.next_request_id.set(id.wrapping_add(1)); @@ -1674,6 +1680,7 @@ fn find_refs_with_file_change_test() { }, }, ); + // Mock change file content server.notification::( lsp_types::DidChangeTextDocumentParams { @@ -1701,6 +1708,7 @@ p2 = Person { }], }, ); + thread::sleep(Duration::from_secs(1)); let id = server.next_request_id.get(); server.next_request_id.set(id.wrapping_add(1)); // Mock trigger find references @@ -1781,6 +1789,7 @@ fn rename_test() { }, }, ); + thread::sleep(Duration::from_secs(1)); let id = server.next_request_id.get(); server.next_request_id.set(id.wrapping_add(1));