mirror of
https://github.com/rust-lang/rust-analyzer
synced 2024-12-26 13:03:31 +00:00
Merge #11168
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:
commit
367cd5ce9b
3 changed files with 18 additions and 37 deletions
|
@ -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())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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!(),
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue