mirror of
https://github.com/Myriad-Dreamin/tinymist.git
synced 2025-07-19 10:45:02 +00:00
fix: more rules to forbidden arg completion (#1493)
* fix: more rules to forbidden arg completion * fix: fix case * feat: revert one
This commit is contained in:
parent
a68399c92e
commit
774227d328
14 changed files with 145 additions and 15 deletions
|
@ -10,6 +10,7 @@ use lsp_types::InsertTextFormat;
|
|||
use once_cell::sync::Lazy;
|
||||
use regex::{Captures, Regex};
|
||||
use serde::{Deserialize, Serialize};
|
||||
use tinymist_analysis::syntax::bad_completion_cursor;
|
||||
use tinymist_derive::BindTyCtx;
|
||||
use tinymist_project::LspWorld;
|
||||
use tinymist_std::path::unix_slash;
|
||||
|
@ -174,13 +175,7 @@ impl<'a> CompletionCursor<'a> {
|
|||
let syntax_context = classify_context(leaf.clone(), Some(cursor));
|
||||
let surrounding_syntax = surrounding_syntax(&leaf);
|
||||
|
||||
// todo: don't match here?
|
||||
if matches!(syntax, Some(SyntaxClass::Callee(..)))
|
||||
&& matches!(syntax_context.as_ref(), Some(
|
||||
SyntaxContext::Element { container, .. } |
|
||||
SyntaxContext::Arg { args: container, .. } |
|
||||
SyntaxContext::Paren { container, .. }) if container.rightmost_leaf().map(|s| s.offset()) == Some(leaf.offset()))
|
||||
{
|
||||
if bad_completion_cursor(syntax.as_ref(), syntax_context.as_ref(), &leaf).is_some() {
|
||||
return None;
|
||||
}
|
||||
|
||||
|
|
|
@ -0,0 +1,2 @@
|
|||
/// contains: alignment
|
||||
#align()[/* range 0..1 */]
|
|
@ -0,0 +1,2 @@
|
|||
/// contains: alignment
|
||||
#align()[]/* range 0..1 */
|
|
@ -0,0 +1,4 @@
|
|||
/// contains: alignment
|
||||
#align()[
|
||||
|
||||
]/* range 0..1 */
|
|
@ -0,0 +1,4 @@
|
|||
/// contains: alignment
|
||||
#align()[/* range 0..1 */
|
||||
|
||||
]
|
|
@ -1,3 +1,3 @@
|
|||
/// contains: delta
|
||||
|
||||
#strong(/* range after 1..2 */[];
|
||||
#strong(/* range 0..1 */[];
|
||||
|
|
|
@ -1,3 +1,3 @@
|
|||
/// contains: delta
|
||||
|
||||
#strong(/* range after 1..2 */[]);
|
||||
#strong(/* range 0..1 */[]);
|
||||
|
|
|
@ -0,0 +1,31 @@
|
|||
---
|
||||
source: crates/tinymist-query/src/completion.rs
|
||||
description: Completion on / (33..34)
|
||||
expression: "JsonRepr::new_pure(results)"
|
||||
input_file: crates/tinymist-query/src/fixtures/completion/arg_range2.typ
|
||||
---
|
||||
[
|
||||
{
|
||||
"isIncomplete": false,
|
||||
"items": [
|
||||
{
|
||||
"kind": 15,
|
||||
"label": "alignment",
|
||||
"sortText": "000",
|
||||
"textEdit": {
|
||||
"newText": "${1:alignment}",
|
||||
"range": {
|
||||
"end": {
|
||||
"character": 9,
|
||||
"line": 1
|
||||
},
|
||||
"start": {
|
||||
"character": 9,
|
||||
"line": 1
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
|
@ -0,0 +1,9 @@
|
|||
---
|
||||
source: crates/tinymist-query/src/completion.rs
|
||||
description: Completion on / (34..35)
|
||||
expression: "JsonRepr::new_pure(results)"
|
||||
input_file: crates/tinymist-query/src/fixtures/completion/arg_range3.typ
|
||||
---
|
||||
[
|
||||
null
|
||||
]
|
|
@ -0,0 +1,9 @@
|
|||
---
|
||||
source: crates/tinymist-query/src/completion.rs
|
||||
description: Completion on / (36..37)
|
||||
expression: "JsonRepr::new_pure(results)"
|
||||
input_file: crates/tinymist-query/src/fixtures/completion/arg_range4.typ
|
||||
---
|
||||
[
|
||||
null
|
||||
]
|
|
@ -0,0 +1,31 @@
|
|||
---
|
||||
source: crates/tinymist-query/src/completion.rs
|
||||
description: Completion on / (33..34)
|
||||
expression: "JsonRepr::new_pure(results)"
|
||||
input_file: crates/tinymist-query/src/fixtures/completion/arg_range5.typ
|
||||
---
|
||||
[
|
||||
{
|
||||
"isIncomplete": false,
|
||||
"items": [
|
||||
{
|
||||
"kind": 15,
|
||||
"label": "alignment",
|
||||
"sortText": "000",
|
||||
"textEdit": {
|
||||
"newText": "${1:alignment}",
|
||||
"range": {
|
||||
"end": {
|
||||
"character": 9,
|
||||
"line": 1
|
||||
},
|
||||
"start": {
|
||||
"character": 9,
|
||||
"line": 1
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
|
@ -1,6 +1,6 @@
|
|||
---
|
||||
source: crates/tinymist-query/src/completion.rs
|
||||
description: "Completion on ] (52..53)"
|
||||
description: Completion on / (29..30)
|
||||
expression: "JsonRepr::new_pure(results)"
|
||||
input_file: crates/tinymist-query/src/fixtures/completion/bracket_strong_delta.typ
|
||||
---
|
||||
|
@ -19,11 +19,11 @@ input_file: crates/tinymist-query/src/fixtures/completion/bracket_strong_delta.t
|
|||
"newText": "delta: ${1:})",
|
||||
"range": {
|
||||
"end": {
|
||||
"character": 31,
|
||||
"character": 8,
|
||||
"line": 2
|
||||
},
|
||||
"start": {
|
||||
"character": 31,
|
||||
"character": 8,
|
||||
"line": 2
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
---
|
||||
source: crates/tinymist-query/src/completion.rs
|
||||
description: "Completion on ] (52..53)"
|
||||
description: Completion on / (29..30)
|
||||
expression: "JsonRepr::new_pure(results)"
|
||||
input_file: crates/tinymist-query/src/fixtures/completion/bracket_strong_delta2.typ
|
||||
---
|
||||
|
@ -19,11 +19,11 @@ input_file: crates/tinymist-query/src/fixtures/completion/bracket_strong_delta2.
|
|||
"newText": "delta: ${1:}",
|
||||
"range": {
|
||||
"end": {
|
||||
"character": 31,
|
||||
"character": 8,
|
||||
"line": 2
|
||||
},
|
||||
"start": {
|
||||
"character": 31,
|
||||
"character": 8,
|
||||
"line": 2
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue