11168: minor: drop dead code r=matklad a=matklad

bors r+
🤖

Co-authored-by: Aleksey Kladov <aleksey.kladov@gmail.com>
This commit is contained in:
bors[bot] 2022-01-02 16:08:23 +00:00 committed by GitHub
commit 367cd5ce9b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 18 additions and 37 deletions

View file

@ -215,6 +215,8 @@ fn parse_or_expand(db: &dyn AstDatabase, file_id: HirFileId) -> Option<SyntaxNod
match file_id.0 { match file_id.0 {
HirFileIdRepr::FileId(file_id) => Some(db.parse(file_id).tree().syntax().clone()), HirFileIdRepr::FileId(file_id) => Some(db.parse(file_id).tree().syntax().clone()),
HirFileIdRepr::MacroFile(macro_file) => { HirFileIdRepr::MacroFile(macro_file) => {
// FIXME: Note how we convert from `Parse` to `SyntaxNode` here,
// forgetting about parse errors.
db.parse_macro_expansion(macro_file).value.map(|(it, _)| it.syntax_node()) db.parse_macro_expansion(macro_file).value.map(|(it, _)| it.syntax_node())
} }
} }

View file

@ -1,7 +1,7 @@
//! Conversions between [`SyntaxNode`] and [`tt::TokenTree`]. //! Conversions between [`SyntaxNode`] and [`tt::TokenTree`].
use rustc_hash::{FxHashMap, FxHashSet}; use rustc_hash::{FxHashMap, FxHashSet};
use stdx::{never, non_empty_vec::NonEmptyVec}; use stdx::non_empty_vec::NonEmptyVec;
use syntax::{ use syntax::{
ast::{self, make::tokens::doc_comment}, ast::{self, make::tokens::doc_comment},
AstToken, Parse, PreorderWithTokens, SmolStr, SyntaxElement, SyntaxKind, AstToken, Parse, PreorderWithTokens, SmolStr, SyntaxElement, SyntaxKind,
@ -66,10 +66,6 @@ pub fn token_tree_to_syntax_node(
parser::Step::Error { msg } => tree_sink.error(msg.to_string()), parser::Step::Error { msg } => tree_sink.error(msg.to_string()),
} }
} }
if never!(tree_sink.roots.len() != 1) {
return Err(ExpandError::ConversionError);
}
//FIXME: would be cool to report errors
let (parse, range_map) = tree_sink.finish(); let (parse, range_map) = tree_sink.finish();
Ok((parse, range_map)) Ok((parse, range_map))
} }
@ -284,7 +280,7 @@ fn convert_tokens<C: TokenConvertor>(conv: &mut C) -> tt::Subtree {
parent.subtree.token_trees.extend(entry.subtree.token_trees); parent.subtree.token_trees.extend(entry.subtree.token_trees);
} }
let subtree = stack.into_first().subtree; let subtree = stack.into_last().subtree;
if let [tt::TokenTree::Subtree(first)] = &*subtree.token_trees { if let [tt::TokenTree::Subtree(first)] = &*subtree.token_trees {
first.clone() first.clone()
} else { } else {
@ -614,10 +610,6 @@ struct TtTreeSink<'a> {
text_pos: TextSize, text_pos: TextSize,
inner: SyntaxTreeBuilder, inner: SyntaxTreeBuilder,
token_map: TokenMap, token_map: TokenMap,
// Number of roots
// Use for detect ill-form tree which is not single root
roots: smallvec::SmallVec<[usize; 1]>,
} }
impl<'a> TtTreeSink<'a> { impl<'a> TtTreeSink<'a> {
@ -628,7 +620,6 @@ impl<'a> TtTreeSink<'a> {
open_delims: FxHashMap::default(), open_delims: FxHashMap::default(),
text_pos: 0.into(), text_pos: 0.into(),
inner: SyntaxTreeBuilder::default(), inner: SyntaxTreeBuilder::default(),
roots: smallvec::SmallVec::new(),
token_map: TokenMap::default(), token_map: TokenMap::default(),
} }
} }
@ -733,16 +724,10 @@ impl<'a> TtTreeSink<'a> {
fn start_node(&mut self, kind: SyntaxKind) { fn start_node(&mut self, kind: SyntaxKind) {
self.inner.start_node(kind); self.inner.start_node(kind);
match self.roots.last_mut() {
None | Some(0) => self.roots.push(1),
Some(n) => *n += 1,
};
} }
fn finish_node(&mut self) { fn finish_node(&mut self) {
self.inner.finish_node(); self.inner.finish_node();
*self.roots.last_mut().unwrap() -= 1;
} }
fn error(&mut self, error: String) { fn error(&mut self, error: String) {

View file

@ -1,45 +1,39 @@
//! A [`Vec`] that is guaranteed to at least contain one element. //! See [`NonEmptyVec`].
pub struct NonEmptyVec<T>(Vec<T>); /// A [`Vec`] that is guaranteed to at least contain one element.
pub struct NonEmptyVec<T> {
first: T,
rest: Vec<T>,
}
impl<T> NonEmptyVec<T> { impl<T> NonEmptyVec<T> {
#[inline] #[inline]
pub fn new(initial: T) -> Self { pub fn new(first: T) -> Self {
NonEmptyVec(vec![initial]) NonEmptyVec { first, rest: Vec::new() }
} }
#[inline] #[inline]
pub fn last_mut(&mut self) -> &mut T { pub fn last_mut(&mut self) -> &mut T {
match self.0.last_mut() { self.rest.last_mut().unwrap_or(&mut self.first)
Some(it) => it,
None => unreachable!(),
}
} }
#[inline] #[inline]
pub fn pop(&mut self) -> Option<T> { pub fn pop(&mut self) -> Option<T> {
if self.0.len() <= 1 { self.rest.pop()
None
} else {
self.0.pop()
}
} }
#[inline] #[inline]
pub fn push(&mut self, value: T) { pub fn push(&mut self, value: T) {
self.0.push(value) self.rest.push(value)
} }
#[inline] #[inline]
pub fn len(&self) -> usize { pub fn len(&self) -> usize {
self.0.len() 1 + self.rest.len()
} }
#[inline] #[inline]
pub fn into_first(mut self) -> T { pub fn into_last(mut self) -> T {
match self.0.pop() { self.rest.pop().unwrap_or(self.first)
Some(it) => it,
None => unreachable!(),
}
} }
} }