mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-27 20:35:09 +00:00
Add test, remove printlns
This commit is contained in:
parent
c32529ddd0
commit
035db0fbb9
4 changed files with 53 additions and 3 deletions
|
@ -206,7 +206,6 @@ fn macro_expand_with_arg(
|
||||||
};
|
};
|
||||||
let (tt, err) = macro_rules.0.expand(db, lazy_id, ¯o_arg.0);
|
let (tt, err) = macro_rules.0.expand(db, lazy_id, ¯o_arg.0);
|
||||||
// Set a hard limit for the expanded tt
|
// Set a hard limit for the expanded tt
|
||||||
eprintln!("expansion size: {}", tt.count());
|
|
||||||
let count = tt.count();
|
let count = tt.count();
|
||||||
if count > 65536 {
|
if count > 65536 {
|
||||||
return (None, Some(format!("Total tokens count exceed limit : count = {}", count)));
|
return (None, Some(format!("Total tokens count exceed limit : count = {}", count)));
|
||||||
|
|
|
@ -905,6 +905,59 @@ mod tests {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn completes_in_simple_macro_without_closing_parens() {
|
||||||
|
assert_debug_snapshot!(
|
||||||
|
do_reference_completion(
|
||||||
|
r"
|
||||||
|
macro_rules! m { ($e:expr) => { $e } }
|
||||||
|
fn quux(x: i32) {
|
||||||
|
let y = 92;
|
||||||
|
m!(x<|>
|
||||||
|
}
|
||||||
|
"
|
||||||
|
),
|
||||||
|
@r###"
|
||||||
|
[
|
||||||
|
CompletionItem {
|
||||||
|
label: "m!",
|
||||||
|
source_range: [145; 146),
|
||||||
|
delete: [145; 146),
|
||||||
|
insert: "m!($0)",
|
||||||
|
kind: Macro,
|
||||||
|
detail: "macro_rules! m",
|
||||||
|
},
|
||||||
|
CompletionItem {
|
||||||
|
label: "quux(…)",
|
||||||
|
source_range: [145; 146),
|
||||||
|
delete: [145; 146),
|
||||||
|
insert: "quux(${1:x})$0",
|
||||||
|
kind: Function,
|
||||||
|
lookup: "quux",
|
||||||
|
detail: "fn quux(x: i32)",
|
||||||
|
trigger_call_info: true,
|
||||||
|
},
|
||||||
|
CompletionItem {
|
||||||
|
label: "x",
|
||||||
|
source_range: [145; 146),
|
||||||
|
delete: [145; 146),
|
||||||
|
insert: "x",
|
||||||
|
kind: Binding,
|
||||||
|
detail: "i32",
|
||||||
|
},
|
||||||
|
CompletionItem {
|
||||||
|
label: "y",
|
||||||
|
source_range: [145; 146),
|
||||||
|
delete: [145; 146),
|
||||||
|
insert: "y",
|
||||||
|
kind: Binding,
|
||||||
|
detail: "i32",
|
||||||
|
},
|
||||||
|
]
|
||||||
|
"###
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn completes_unresolved_uses() {
|
fn completes_unresolved_uses() {
|
||||||
assert_debug_snapshot!(
|
assert_debug_snapshot!(
|
||||||
|
|
|
@ -11,7 +11,6 @@ use rustc_hash::FxHashMap;
|
||||||
use crate::{ExpandError, ExpandResult};
|
use crate::{ExpandError, ExpandResult};
|
||||||
|
|
||||||
pub(crate) fn expand(rules: &crate::MacroRules, input: &tt::Subtree) -> ExpandResult<tt::Subtree> {
|
pub(crate) fn expand(rules: &crate::MacroRules, input: &tt::Subtree) -> ExpandResult<tt::Subtree> {
|
||||||
eprintln!("expanding input: {:?}", input);
|
|
||||||
let (mut result, mut unmatched_tokens, mut unmatched_patterns, mut err) = (
|
let (mut result, mut unmatched_tokens, mut unmatched_patterns, mut err) = (
|
||||||
tt::Subtree::default(),
|
tt::Subtree::default(),
|
||||||
usize::max_value(),
|
usize::max_value(),
|
||||||
|
|
|
@ -73,7 +73,6 @@ pub fn token_tree_to_syntax_node(
|
||||||
tt: &tt::Subtree,
|
tt: &tt::Subtree,
|
||||||
fragment_kind: FragmentKind,
|
fragment_kind: FragmentKind,
|
||||||
) -> Result<(Parse<SyntaxNode>, TokenMap), ExpandError> {
|
) -> Result<(Parse<SyntaxNode>, TokenMap), ExpandError> {
|
||||||
eprintln!("token_tree_to_syntax_node {:?} as {:?}", tt, fragment_kind);
|
|
||||||
let tmp;
|
let tmp;
|
||||||
let tokens = match tt {
|
let tokens = match tt {
|
||||||
tt::Subtree { delimiter: None, token_trees } => token_trees.as_slice(),
|
tt::Subtree { delimiter: None, token_trees } => token_trees.as_slice(),
|
||||||
|
|
Loading…
Reference in a new issue