mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-25 19:35:06 +00:00
Simplify
This commit is contained in:
parent
3987bf5d6f
commit
9c39363ada
9 changed files with 24 additions and 33 deletions
|
@ -218,7 +218,7 @@ impl ChangeFixture {
|
|||
);
|
||||
roots.push(SourceRoot::new_library(fs));
|
||||
|
||||
change.change_file(proc_lib_file, Some(Arc::new(String::from(source))));
|
||||
change.change_file(proc_lib_file, Some(Arc::new(source)));
|
||||
|
||||
let all_crates = crate_graph.crates_in_topological_order();
|
||||
|
||||
|
@ -275,7 +275,7 @@ pub fn input_replace(attr: TokenStream, _item: TokenStream) -> TokenStream {
|
|||
expander: Arc::new(AttributeInputReplaceProcMacroExpander),
|
||||
},
|
||||
])
|
||||
.filter(|pm| proc_macros.iter().any(|name| name == &pm.name))
|
||||
.filter(|pm| proc_macros.iter().any(|name| name == pm.name))
|
||||
.collect();
|
||||
(proc_macros, source.into())
|
||||
}
|
||||
|
|
|
@ -307,17 +307,12 @@ impl<'a> TyLoweringContext<'a> {
|
|||
let mut expander = self.expander.borrow_mut();
|
||||
if expander.is_some() {
|
||||
(Some(expander), false)
|
||||
} else if let Some(module_id) = self.resolver.module() {
|
||||
*expander =
|
||||
Some(Expander::new(self.db.upcast(), macro_call.file_id, module_id));
|
||||
(Some(expander), true)
|
||||
} else {
|
||||
if let Some(module_id) = self.resolver.module() {
|
||||
*expander = Some(Expander::new(
|
||||
self.db.upcast(),
|
||||
macro_call.file_id,
|
||||
module_id,
|
||||
));
|
||||
(Some(expander), true)
|
||||
} else {
|
||||
(None, false)
|
||||
}
|
||||
(None, false)
|
||||
}
|
||||
};
|
||||
let ty = if let Some(mut expander) = expander {
|
||||
|
|
|
@ -172,7 +172,7 @@ impl<'db> MatchFinder<'db> {
|
|||
for m in self.matches().matches {
|
||||
matches_by_file
|
||||
.entry(m.range.file_id)
|
||||
.or_insert_with(|| SsrMatches::default())
|
||||
.or_insert_with(SsrMatches::default)
|
||||
.matches
|
||||
.push(m);
|
||||
}
|
||||
|
@ -331,7 +331,7 @@ impl SsrMatches {
|
|||
fn flatten_into(self, out: &mut SsrMatches) {
|
||||
for mut m in self.matches {
|
||||
for p in m.placeholder_values.values_mut() {
|
||||
std::mem::replace(&mut p.inner_matches, SsrMatches::default()).flatten_into(out);
|
||||
std::mem::take(&mut p.inner_matches).flatten_into(out);
|
||||
}
|
||||
out.matches.push(m);
|
||||
}
|
||||
|
|
|
@ -462,7 +462,7 @@ impl<'db, 'sema> Matcher<'db, 'sema> {
|
|||
let mut last_matched_token = child;
|
||||
// Read code tokens util we reach one equal to the next token from our pattern
|
||||
// or we reach the end of the token tree.
|
||||
while let Some(next) = children.next() {
|
||||
for next in &mut children {
|
||||
match &next {
|
||||
SyntaxElement::Token(t) => {
|
||||
if Some(t.to_string()) == next_pattern_token {
|
||||
|
@ -763,7 +763,7 @@ impl Iterator for PatternIterator {
|
|||
type Item = SyntaxElement;
|
||||
|
||||
fn next(&mut self) -> Option<SyntaxElement> {
|
||||
while let Some(element) = self.iter.next() {
|
||||
for element in &mut self.iter {
|
||||
if !element.kind().is_trivia() {
|
||||
return Some(element);
|
||||
}
|
||||
|
|
|
@ -65,7 +65,7 @@ fn try_add_sub_match(m: Match, existing: &mut Match, sema: &hir::Semantics<ide_d
|
|||
// will have 0 and a few will have 1. More than that should hopefully be
|
||||
// exceptional.
|
||||
let mut collector = MatchCollector::default();
|
||||
for m in std::mem::replace(&mut p.inner_matches.matches, Vec::new()) {
|
||||
for m in std::mem::take(&mut p.inner_matches.matches) {
|
||||
collector.matches_by_node.insert(m.matched_node.clone(), m);
|
||||
}
|
||||
collector.add_match(m, sema);
|
||||
|
|
|
@ -243,10 +243,10 @@ impl<'db> ResolutionScope<'db> {
|
|||
use syntax::ast::AstNode;
|
||||
if let Some(path) = ast::Path::cast(path.clone()) {
|
||||
if let Some(qualifier) = path.qualifier() {
|
||||
if let Some(resolved_qualifier) = self.resolve_path(&qualifier) {
|
||||
if let hir::PathResolution::Def(hir::ModuleDef::Adt(adt)) = resolved_qualifier {
|
||||
return Some(adt.ty(self.scope.db));
|
||||
}
|
||||
if let Some(hir::PathResolution::Def(hir::ModuleDef::Adt(adt))) =
|
||||
self.resolve_path(&qualifier)
|
||||
{
|
||||
return Some(adt.ty(self.scope.db));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -80,7 +80,7 @@ impl<'db> MatchFinder<'db> {
|
|||
if let Some(path) =
|
||||
self.sema.find_node_at_offset_with_descend::<ast::Path>(file.syntax(), offset)
|
||||
{
|
||||
self.sema.ancestors_with_macros(path.syntax().clone()).skip(depth).next()
|
||||
self.sema.ancestors_with_macros(path.syntax().clone()).nth(depth)
|
||||
} else if let Some(path) =
|
||||
self.sema.find_node_at_offset_with_descend::<ast::MethodCallExpr>(file.syntax(), offset)
|
||||
{
|
||||
|
@ -96,8 +96,7 @@ impl<'db> MatchFinder<'db> {
|
|||
}
|
||||
self.sema
|
||||
.ancestors_with_macros(path.syntax().clone())
|
||||
.skip(depth - PATH_DEPTH_IN_CALL_EXPR)
|
||||
.next()
|
||||
.nth(depth - PATH_DEPTH_IN_CALL_EXPR)
|
||||
} else {
|
||||
None
|
||||
}
|
||||
|
|
|
@ -246,7 +246,7 @@ impl<'a> Writer<'a> {
|
|||
|
||||
fn enqueue(&mut self, subtree: &'a tt::Subtree) -> u32 {
|
||||
let idx = self.subtree.len();
|
||||
let delimiter_id = subtree.delimiter.map(|it| it.id).unwrap_or(TokenId::unspecified());
|
||||
let delimiter_id = subtree.delimiter.map(|it| it.id).unwrap_or_else(TokenId::unspecified);
|
||||
let delimiter_kind = subtree.delimiter.map(|it| it.kind);
|
||||
self.subtree.push(SubtreeRepr { id: delimiter_id, kind: delimiter_kind, tt: [!0, !0] });
|
||||
self.work.push_back((idx, subtree));
|
||||
|
@ -320,7 +320,7 @@ impl Reader {
|
|||
})
|
||||
.collect(),
|
||||
};
|
||||
res[i] = Some(s.into())
|
||||
res[i] = Some(s)
|
||||
}
|
||||
|
||||
res[0].take().unwrap()
|
||||
|
|
|
@ -211,13 +211,10 @@ fn validate_numeric_name(name_ref: Option<ast::NameRef>, errors: &mut Vec<Syntax
|
|||
}
|
||||
|
||||
fn validate_visibility(vis: ast::Visibility, errors: &mut Vec<SyntaxError>) {
|
||||
if vis.in_token().is_none() {
|
||||
if vis.path().and_then(|p| p.as_single_name_ref()).and_then(|n| n.ident_token()).is_some() {
|
||||
errors.push(SyntaxError::new(
|
||||
"incorrect visibility restriction",
|
||||
vis.syntax.text_range(),
|
||||
));
|
||||
}
|
||||
let path_without_in_token = vis.in_token().is_none()
|
||||
&& vis.path().and_then(|p| p.as_single_name_ref()).and_then(|n| n.ident_token()).is_some();
|
||||
if path_without_in_token {
|
||||
errors.push(SyntaxError::new("incorrect visibility restriction", vis.syntax.text_range()));
|
||||
}
|
||||
let parent = match vis.syntax().parent() {
|
||||
Some(it) => it,
|
||||
|
|
Loading…
Reference in a new issue