Get tests working

This commit is contained in:
Florian Diebold 2020-03-15 11:17:13 +01:00
parent 0f3a54dd4d
commit c32529ddd0
5 changed files with 19 additions and 7 deletions

View file

@ -720,7 +720,18 @@ mod tests {
} }
", ",
), ),
@r###"[]"### @r###"
[
CompletionItem {
label: "the_field",
source_range: [156; 156),
delete: [156; 156),
insert: "the_field",
kind: Field,
detail: "u32",
},
]
"###
); );
} }

View file

@ -135,7 +135,7 @@ impl<'a> CompletionContext<'a> {
), ),
) { ) {
let new_offset = hypothetical_expansion.1.text_range().start(); let new_offset = hypothetical_expansion.1.text_range().start();
if new_offset >= actual_expansion.text_range().end() { if new_offset > actual_expansion.text_range().end() {
break; break;
} }
original_file = actual_expansion; original_file = actual_expansion;

View file

@ -11,6 +11,7 @@ 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(),
@ -39,9 +40,8 @@ fn expand_rule(
rule: &crate::Rule, rule: &crate::Rule,
input: &tt::Subtree, input: &tt::Subtree,
) -> ExpandResult<(tt::Subtree, usize, usize)> { ) -> ExpandResult<(tt::Subtree, usize, usize)> {
dbg!(&rule.lhs); let (match_result, bindings_err) = matcher::match_(&rule.lhs, input);
let (match_result, bindings_err) = dbg!(matcher::match_(&rule.lhs, input)); let (res, transcribe_err) = transcriber::transcribe(&rule.rhs, &match_result.bindings);
let (res, transcribe_err) = dbg!(transcriber::transcribe(&rule.rhs, &match_result.bindings));
( (
(res, match_result.unmatched_tokens, match_result.unmatched_patterns), (res, match_result.unmatched_tokens, match_result.unmatched_patterns),
bindings_err.or(transcribe_err), bindings_err.or(transcribe_err),

View file

@ -73,6 +73,7 @@ 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(),

View file

@ -565,10 +565,10 @@ fn meta_var_expr(p: &mut Parser) -> CompletedMarker {
it it
} }
_ => { _ => {
while !p.at(R_DOLLAR) { while !p.at(EOF) && !p.at(R_DOLLAR) {
p.bump_any() p.bump_any()
} }
p.bump(R_DOLLAR); p.eat(R_DOLLAR);
m.complete(p, ERROR) m.complete(p, ERROR)
} }
} }