mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-26 11:55:04 +00:00
Fix new nightly lints
This commit is contained in:
parent
232432411e
commit
6c23f25e7f
24 changed files with 81 additions and 51 deletions
|
@ -34,7 +34,7 @@ impl<'a> OuterImplTraitGuard<'a> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> Drop for OuterImplTraitGuard<'a> {
|
impl Drop for OuterImplTraitGuard<'_> {
|
||||||
fn drop(&mut self) {
|
fn drop(&mut self) {
|
||||||
self.ctx.outer_impl_trait.replace(self.old);
|
self.ctx.outer_impl_trait.replace(self.old);
|
||||||
}
|
}
|
||||||
|
|
|
@ -227,7 +227,7 @@ pub(crate) fn dump_syntax_contexts(db: &dyn ExpandDatabase) -> String {
|
||||||
&'a SyntaxContextData,
|
&'a SyntaxContextData,
|
||||||
);
|
);
|
||||||
|
|
||||||
impl<'a> std::fmt::Debug for SyntaxContextDebug<'a> {
|
impl std::fmt::Debug for SyntaxContextDebug<'_> {
|
||||||
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
||||||
fancy_debug(self.2, self.1, self.0, f)
|
fancy_debug(self.2, self.1, self.0, f)
|
||||||
}
|
}
|
||||||
|
|
|
@ -114,7 +114,7 @@ impl<'table, 'db> Autoderef<'table, 'db, usize> {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[allow(private_bounds)]
|
#[allow(private_bounds)]
|
||||||
impl<'table, 'db, T: TrackAutoderefSteps> Autoderef<'table, 'db, T> {
|
impl<T: TrackAutoderefSteps> Autoderef<'_, '_, T> {
|
||||||
pub(crate) fn step_count(&self) -> usize {
|
pub(crate) fn step_count(&self) -> usize {
|
||||||
self.steps.len()
|
self.steps.len()
|
||||||
}
|
}
|
||||||
|
|
|
@ -521,7 +521,7 @@ impl chalk_solve::RustIrDatabase<Interner> for ChalkContext<'_> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> ChalkContext<'a> {
|
impl ChalkContext<'_> {
|
||||||
fn edition(&self) -> Edition {
|
fn edition(&self) -> Edition {
|
||||||
self.db.crate_graph()[self.krate].edition
|
self.db.crate_graph()[self.krate].edition
|
||||||
}
|
}
|
||||||
|
|
|
@ -519,7 +519,7 @@ impl<'db> PatCx for MatchCheckCtx<'db> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'db> fmt::Debug for MatchCheckCtx<'db> {
|
impl fmt::Debug for MatchCheckCtx<'_> {
|
||||||
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
||||||
f.debug_struct("MatchCheckCtx").finish()
|
f.debug_struct("MatchCheckCtx").finish()
|
||||||
}
|
}
|
||||||
|
|
|
@ -266,7 +266,7 @@ fn contains_illegal_self_type_reference<T: TypeVisitable<Interner>>(
|
||||||
trait_self_param_idx: usize,
|
trait_self_param_idx: usize,
|
||||||
allow_self_projection: AllowSelfProjection,
|
allow_self_projection: AllowSelfProjection,
|
||||||
}
|
}
|
||||||
impl<'a> TypeVisitor<Interner> for IllegalSelfTypeVisitor<'a> {
|
impl TypeVisitor<Interner> for IllegalSelfTypeVisitor<'_> {
|
||||||
type BreakTy = ();
|
type BreakTy = ();
|
||||||
|
|
||||||
fn as_dyn(&mut self) -> &mut dyn TypeVisitor<Interner, BreakTy = Self::BreakTy> {
|
fn as_dyn(&mut self) -> &mut dyn TypeVisitor<Interner, BreakTy = Self::BreakTy> {
|
||||||
|
|
|
@ -1022,7 +1022,7 @@ impl<'a> InferenceContext<'a> {
|
||||||
non_assocs: FxHashMap<OpaqueTyId, Ty>,
|
non_assocs: FxHashMap<OpaqueTyId, Ty>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a, 'b> TypeVisitor<Interner> for TypeAliasImplTraitCollector<'a, 'b> {
|
impl TypeVisitor<Interner> for TypeAliasImplTraitCollector<'_, '_> {
|
||||||
type BreakTy = ();
|
type BreakTy = ();
|
||||||
|
|
||||||
fn as_dyn(&mut self) -> &mut dyn TypeVisitor<Interner, BreakTy = Self::BreakTy> {
|
fn as_dyn(&mut self) -> &mut dyn TypeVisitor<Interner, BreakTy = Self::BreakTy> {
|
||||||
|
|
|
@ -880,6 +880,7 @@ pub enum Rvalue {
|
||||||
/// **Needs clarification**: Are there weird additional semantics here related to the runtime
|
/// **Needs clarification**: Are there weird additional semantics here related to the runtime
|
||||||
/// nature of this operation?
|
/// nature of this operation?
|
||||||
// ThreadLocalRef(DefId),
|
// ThreadLocalRef(DefId),
|
||||||
|
ThreadLocalRef(std::convert::Infallible),
|
||||||
|
|
||||||
/// Creates a pointer with the indicated mutability to the place.
|
/// Creates a pointer with the indicated mutability to the place.
|
||||||
///
|
///
|
||||||
|
@ -889,6 +890,7 @@ pub enum Rvalue {
|
||||||
/// Like with references, the semantics of this operation are heavily dependent on the aliasing
|
/// Like with references, the semantics of this operation are heavily dependent on the aliasing
|
||||||
/// model.
|
/// model.
|
||||||
// AddressOf(Mutability, Place),
|
// AddressOf(Mutability, Place),
|
||||||
|
AddressOf(std::convert::Infallible),
|
||||||
|
|
||||||
/// Yields the length of the place, as a `usize`.
|
/// Yields the length of the place, as a `usize`.
|
||||||
///
|
///
|
||||||
|
@ -906,19 +908,21 @@ pub enum Rvalue {
|
||||||
Cast(CastKind, Operand, Ty),
|
Cast(CastKind, Operand, Ty),
|
||||||
|
|
||||||
// FIXME link to `pointer::offset` when it hits stable.
|
// FIXME link to `pointer::offset` when it hits stable.
|
||||||
// /// * `Offset` has the same semantics as `pointer::offset`, except that the second
|
/// * `Offset` has the same semantics as `pointer::offset`, except that the second
|
||||||
// /// parameter may be a `usize` as well.
|
/// parameter may be a `usize` as well.
|
||||||
// /// * The comparison operations accept `bool`s, `char`s, signed or unsigned integers, floats,
|
/// * The comparison operations accept `bool`s, `char`s, signed or unsigned integers, floats,
|
||||||
// /// raw pointers, or function pointers and return a `bool`. The types of the operands must be
|
/// raw pointers, or function pointers and return a `bool`. The types of the operands must be
|
||||||
// /// matching, up to the usual caveat of the lifetimes in function pointers.
|
/// matching, up to the usual caveat of the lifetimes in function pointers.
|
||||||
// /// * Left and right shift operations accept signed or unsigned integers not necessarily of the
|
/// * Left and right shift operations accept signed or unsigned integers not necessarily of the
|
||||||
// /// same type and return a value of the same type as their LHS. Like in Rust, the RHS is
|
/// same type and return a value of the same type as their LHS. Like in Rust, the RHS is
|
||||||
// /// truncated as needed.
|
/// truncated as needed.
|
||||||
// /// * The `Bit*` operations accept signed integers, unsigned integers, or bools with matching
|
/// * The `Bit*` operations accept signed integers, unsigned integers, or bools with matching
|
||||||
// /// types and return a value of that type.
|
/// types and return a value of that type.
|
||||||
// /// * The remaining operations accept signed integers, unsigned integers, or floats with
|
/// * The remaining operations accept signed integers, unsigned integers, or floats with
|
||||||
// /// matching types and return a value of that type.
|
/// matching types and return a value of that type.
|
||||||
//BinaryOp(BinOp, Box<(Operand, Operand)>),
|
//BinaryOp(BinOp, Box<(Operand, Operand)>),
|
||||||
|
BinaryOp(std::convert::Infallible),
|
||||||
|
|
||||||
/// Same as `BinaryOp`, but yields `(T, bool)` with a `bool` indicating an error condition.
|
/// Same as `BinaryOp`, but yields `(T, bool)` with a `bool` indicating an error condition.
|
||||||
///
|
///
|
||||||
/// When overflow checking is disabled and we are generating run-time code, the error condition
|
/// When overflow checking is disabled and we are generating run-time code, the error condition
|
||||||
|
@ -937,6 +941,7 @@ pub enum Rvalue {
|
||||||
|
|
||||||
/// Computes a value as described by the operation.
|
/// Computes a value as described by the operation.
|
||||||
//NullaryOp(NullOp, Ty),
|
//NullaryOp(NullOp, Ty),
|
||||||
|
NullaryOp(std::convert::Infallible),
|
||||||
|
|
||||||
/// Exactly like `BinaryOp`, but less operands.
|
/// Exactly like `BinaryOp`, but less operands.
|
||||||
///
|
///
|
||||||
|
@ -1095,6 +1100,10 @@ impl MirBody {
|
||||||
for_operand(op, &mut f, &mut self.projection_store);
|
for_operand(op, &mut f, &mut self.projection_store);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Rvalue::ThreadLocalRef(n)
|
||||||
|
| Rvalue::AddressOf(n)
|
||||||
|
| Rvalue::BinaryOp(n)
|
||||||
|
| Rvalue::NullaryOp(n) => match *n {},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
StatementKind::FakeRead(p) | StatementKind::Deinit(p) => {
|
StatementKind::FakeRead(p) | StatementKind::Deinit(p) => {
|
||||||
|
|
|
@ -167,6 +167,10 @@ fn moved_out_of_ref(db: &dyn HirDatabase, body: &MirBody) -> Vec<MovedOutOfRef>
|
||||||
for_operand(op, statement.span);
|
for_operand(op, statement.span);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Rvalue::ThreadLocalRef(n)
|
||||||
|
| Rvalue::AddressOf(n)
|
||||||
|
| Rvalue::BinaryOp(n)
|
||||||
|
| Rvalue::NullaryOp(n) => match *n {},
|
||||||
},
|
},
|
||||||
StatementKind::FakeRead(_)
|
StatementKind::FakeRead(_)
|
||||||
| StatementKind::Deinit(_)
|
| StatementKind::Deinit(_)
|
||||||
|
@ -253,6 +257,10 @@ fn partially_moved(db: &dyn HirDatabase, body: &MirBody) -> Vec<PartiallyMoved>
|
||||||
for_operand(op, statement.span);
|
for_operand(op, statement.span);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Rvalue::ThreadLocalRef(n)
|
||||||
|
| Rvalue::AddressOf(n)
|
||||||
|
| Rvalue::BinaryOp(n)
|
||||||
|
| Rvalue::NullaryOp(n) => match *n {},
|
||||||
},
|
},
|
||||||
StatementKind::FakeRead(_)
|
StatementKind::FakeRead(_)
|
||||||
| StatementKind::Deinit(_)
|
| StatementKind::Deinit(_)
|
||||||
|
@ -548,6 +556,10 @@ fn mutability_of_locals(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Rvalue::ShallowInitBox(_, _) | Rvalue::ShallowInitBoxWithAlloc(_) => (),
|
Rvalue::ShallowInitBox(_, _) | Rvalue::ShallowInitBoxWithAlloc(_) => (),
|
||||||
|
Rvalue::ThreadLocalRef(n)
|
||||||
|
| Rvalue::AddressOf(n)
|
||||||
|
| Rvalue::BinaryOp(n)
|
||||||
|
| Rvalue::NullaryOp(n) => match *n {},
|
||||||
}
|
}
|
||||||
if let Rvalue::Ref(
|
if let Rvalue::Ref(
|
||||||
BorrowKind::Mut {
|
BorrowKind::Mut {
|
||||||
|
|
|
@ -1628,6 +1628,10 @@ impl Evaluator<'_> {
|
||||||
}
|
}
|
||||||
CastKind::FnPtrToPtr => not_supported!("fn ptr to ptr cast"),
|
CastKind::FnPtrToPtr => not_supported!("fn ptr to ptr cast"),
|
||||||
},
|
},
|
||||||
|
Rvalue::ThreadLocalRef(n)
|
||||||
|
| Rvalue::AddressOf(n)
|
||||||
|
| Rvalue::BinaryOp(n)
|
||||||
|
| Rvalue::NullaryOp(n) => match *n {},
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2703,8 +2707,7 @@ impl Evaluator<'_> {
|
||||||
TyKind::Function(_) => {
|
TyKind::Function(_) => {
|
||||||
self.exec_fn_pointer(func_data, destination, &args[1..], locals, target_bb, span)
|
self.exec_fn_pointer(func_data, destination, &args[1..], locals, target_bb, span)
|
||||||
}
|
}
|
||||||
TyKind::Closure(closure, subst) => {
|
TyKind::Closure(closure, subst) => self.exec_closure(
|
||||||
return self.exec_closure(
|
|
||||||
*closure,
|
*closure,
|
||||||
func_data,
|
func_data,
|
||||||
&Substitution::from_iter(Interner, ClosureSubst(subst).parent_subst()),
|
&Substitution::from_iter(Interner, ClosureSubst(subst).parent_subst()),
|
||||||
|
@ -2712,8 +2715,7 @@ impl Evaluator<'_> {
|
||||||
&args[1..],
|
&args[1..],
|
||||||
locals,
|
locals,
|
||||||
span,
|
span,
|
||||||
);
|
),
|
||||||
}
|
|
||||||
_ => {
|
_ => {
|
||||||
// try to execute the manual impl of `FnTrait` for structs (nightly feature used in std)
|
// try to execute the manual impl of `FnTrait` for structs (nightly feature used in std)
|
||||||
let arg0 = func;
|
let arg0 = func;
|
||||||
|
|
|
@ -258,6 +258,10 @@ impl Filler<'_> {
|
||||||
| Rvalue::UnaryOp(_, _)
|
| Rvalue::UnaryOp(_, _)
|
||||||
| Rvalue::Discriminant(_)
|
| Rvalue::Discriminant(_)
|
||||||
| Rvalue::CopyForDeref(_) => (),
|
| Rvalue::CopyForDeref(_) => (),
|
||||||
|
Rvalue::ThreadLocalRef(n)
|
||||||
|
| Rvalue::AddressOf(n)
|
||||||
|
| Rvalue::BinaryOp(n)
|
||||||
|
| Rvalue::NullaryOp(n) => match *n {},
|
||||||
},
|
},
|
||||||
StatementKind::Deinit(_)
|
StatementKind::Deinit(_)
|
||||||
| StatementKind::FakeRead(_)
|
| StatementKind::FakeRead(_)
|
||||||
|
|
|
@ -459,6 +459,10 @@ impl<'a> MirPrettyCtx<'a> {
|
||||||
self.place(p);
|
self.place(p);
|
||||||
w!(self, ")");
|
w!(self, ")");
|
||||||
}
|
}
|
||||||
|
Rvalue::ThreadLocalRef(n)
|
||||||
|
| Rvalue::AddressOf(n)
|
||||||
|
| Rvalue::BinaryOp(n)
|
||||||
|
| Rvalue::NullaryOp(n) => match *n {},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -123,7 +123,7 @@ pub(super) struct ClauseElaborator<'a> {
|
||||||
seen: FxHashSet<WhereClause>,
|
seen: FxHashSet<WhereClause>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> ClauseElaborator<'a> {
|
impl ClauseElaborator<'_> {
|
||||||
fn extend_deduped(&mut self, clauses: impl IntoIterator<Item = WhereClause>) {
|
fn extend_deduped(&mut self, clauses: impl IntoIterator<Item = WhereClause>) {
|
||||||
self.stack.extend(clauses.into_iter().filter(|c| self.seen.insert(c.clone())))
|
self.stack.extend(clauses.into_iter().filter(|c| self.seen.insert(c.clone())))
|
||||||
}
|
}
|
||||||
|
|
|
@ -154,7 +154,7 @@ impl<'db, DB> ops::Deref for Semantics<'db, DB> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'db, DB: HirDatabase> Semantics<'db, DB> {
|
impl<DB: HirDatabase> Semantics<'_, DB> {
|
||||||
pub fn new(db: &DB) -> Semantics<'_, DB> {
|
pub fn new(db: &DB) -> Semantics<'_, DB> {
|
||||||
let impl_ = SemanticsImpl::new(db);
|
let impl_ = SemanticsImpl::new(db);
|
||||||
Semantics { db, imp: impl_ }
|
Semantics { db, imp: impl_ }
|
||||||
|
|
|
@ -40,9 +40,6 @@ pub(super) fn pattern_top_r(p: &mut Parser<'_>, recovery_set: TokenSet) {
|
||||||
pattern_r(p, recovery_set);
|
pattern_r(p, recovery_set);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Parses a pattern list separated by pipes `|`, with no leading `|`,using the
|
|
||||||
/// given `recovery_set`.
|
|
||||||
|
|
||||||
// test or_pattern
|
// test or_pattern
|
||||||
// fn main() {
|
// fn main() {
|
||||||
// match () {
|
// match () {
|
||||||
|
@ -52,6 +49,8 @@ pub(super) fn pattern_top_r(p: &mut Parser<'_>, recovery_set: TokenSet) {
|
||||||
// [_ | _,] => (),
|
// [_ | _,] => (),
|
||||||
// }
|
// }
|
||||||
// }
|
// }
|
||||||
|
/// Parses a pattern list separated by pipes `|`, with no leading `|`,using the
|
||||||
|
/// given `recovery_set`.
|
||||||
fn pattern_r(p: &mut Parser<'_>, recovery_set: TokenSet) {
|
fn pattern_r(p: &mut Parser<'_>, recovery_set: TokenSet) {
|
||||||
let m = p.start();
|
let m = p.start();
|
||||||
pattern_single_r(p, recovery_set);
|
pattern_single_r(p, recovery_set);
|
||||||
|
|
|
@ -401,7 +401,7 @@ struct Writer<'a, 'span, S: InternableSpan> {
|
||||||
text: Vec<String>,
|
text: Vec<String>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a, 'span, S: InternableSpan> Writer<'a, 'span, S> {
|
impl<'a, S: InternableSpan> Writer<'a, '_, S> {
|
||||||
fn write(&mut self, root: &'a tt::Subtree<S>) {
|
fn write(&mut self, root: &'a tt::Subtree<S>) {
|
||||||
self.enqueue(root);
|
self.enqueue(root);
|
||||||
while let Some((idx, subtree)) = self.work.pop_front() {
|
while let Some((idx, subtree)) = self.work.pop_front() {
|
||||||
|
@ -524,7 +524,7 @@ struct Reader<'span, S: InternableSpan> {
|
||||||
span_data_table: &'span S::Table,
|
span_data_table: &'span S::Table,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'span, S: InternableSpan> Reader<'span, S> {
|
impl<S: InternableSpan> Reader<'_, S> {
|
||||||
pub(crate) fn read(self) -> tt::Subtree<S> {
|
pub(crate) fn read(self) -> tt::Subtree<S> {
|
||||||
let mut res: Vec<Option<tt::Subtree<S>>> = vec![None; self.subtree.len()];
|
let mut res: Vec<Option<tt::Subtree<S>>> = vec![None; self.subtree.len()];
|
||||||
let read_span = |id| S::span_for_token_id(self.span_data_table, id);
|
let read_span = |id| S::span_for_token_id(self.span_data_table, id);
|
||||||
|
|
|
@ -616,7 +616,7 @@ Please report this bug to https://github.com/salsa-rs/salsa/issues."
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'me, Q> Drop for PanicGuard<'me, Q>
|
impl<Q> Drop for PanicGuard<'_, Q>
|
||||||
where
|
where
|
||||||
Q: QueryFunction,
|
Q: QueryFunction,
|
||||||
Q::Value: Eq,
|
Q::Value: Eq,
|
||||||
|
|
|
@ -666,7 +666,7 @@ Please report this bug to https://github.com/salsa-rs/salsa/issues."
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'me, Q, MP> Drop for PanicGuard<'me, Q, MP>
|
impl<Q, MP> Drop for PanicGuard<'_, Q, MP>
|
||||||
where
|
where
|
||||||
Q: QueryFunction,
|
Q: QueryFunction,
|
||||||
MP: MemoizationPolicy<Q>,
|
MP: MemoizationPolicy<Q>,
|
||||||
|
|
|
@ -493,7 +493,7 @@ where
|
||||||
is_static::<Slot<K>>();
|
is_static::<Slot<K>>();
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'me, Q> QueryTable<'me, Q>
|
impl<Q> QueryTable<'_, Q>
|
||||||
where
|
where
|
||||||
Q: Query<Storage = InternedStorage<Q>>,
|
Q: Query<Storage = InternedStorage<Q>>,
|
||||||
Q::Key: InternValue,
|
Q::Key: InternValue,
|
||||||
|
|
|
@ -149,7 +149,7 @@ where
|
||||||
db: &'me D,
|
db: &'me D,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'me, D: ?Sized> fmt::Debug for EventDebug<'me, D>
|
impl<D: ?Sized> fmt::Debug for EventDebug<'_, D>
|
||||||
where
|
where
|
||||||
D: plumbing::DatabaseOps,
|
D: plumbing::DatabaseOps,
|
||||||
{
|
{
|
||||||
|
@ -242,7 +242,7 @@ where
|
||||||
db: &'me D,
|
db: &'me D,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'me, D: ?Sized> fmt::Debug for EventKindDebug<'me, D>
|
impl<D: ?Sized> fmt::Debug for EventKindDebug<'_, D>
|
||||||
where
|
where
|
||||||
D: plumbing::DatabaseOps,
|
D: plumbing::DatabaseOps,
|
||||||
{
|
{
|
||||||
|
@ -729,7 +729,7 @@ impl Cycle {
|
||||||
db: &'me dyn Database,
|
db: &'me dyn Database,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'me> std::fmt::Debug for UnexpectedCycleDebug<'me> {
|
impl std::fmt::Debug for UnexpectedCycleDebug<'_> {
|
||||||
fn fmt(&self, fmt: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
fn fmt(&self, fmt: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
||||||
fmt.debug_struct("UnexpectedCycle")
|
fmt.debug_struct("UnexpectedCycle")
|
||||||
.field("all_participants", &self.c.all_participants(self.db))
|
.field("all_participants", &self.c.all_participants(self.db))
|
||||||
|
|
|
@ -489,12 +489,12 @@ pub(crate) fn handle_document_symbol(
|
||||||
tags.push(SymbolTag::DEPRECATED)
|
tags.push(SymbolTag::DEPRECATED)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#[allow(deprecated)]
|
||||||
let doc_symbol = lsp_types::DocumentSymbol {
|
let doc_symbol = lsp_types::DocumentSymbol {
|
||||||
name: symbol.label,
|
name: symbol.label,
|
||||||
detail: symbol.detail,
|
detail: symbol.detail,
|
||||||
kind: to_proto::structure_node_kind(symbol.kind),
|
kind: to_proto::structure_node_kind(symbol.kind),
|
||||||
tags: Some(tags),
|
tags: Some(tags),
|
||||||
#[allow(deprecated)]
|
|
||||||
deprecated: Some(symbol.deprecated),
|
deprecated: Some(symbol.deprecated),
|
||||||
range: to_proto::range(&line_index, symbol.node_range),
|
range: to_proto::range(&line_index, symbol.node_range),
|
||||||
selection_range: to_proto::range(&line_index, symbol.navigation_range),
|
selection_range: to_proto::range(&line_index, symbol.navigation_range),
|
||||||
|
@ -539,11 +539,11 @@ pub(crate) fn handle_document_symbol(
|
||||||
url: &Url,
|
url: &Url,
|
||||||
res: &mut Vec<SymbolInformation>,
|
res: &mut Vec<SymbolInformation>,
|
||||||
) {
|
) {
|
||||||
|
#[allow(deprecated)]
|
||||||
res.push(SymbolInformation {
|
res.push(SymbolInformation {
|
||||||
name: symbol.name.clone(),
|
name: symbol.name.clone(),
|
||||||
kind: symbol.kind,
|
kind: symbol.kind,
|
||||||
tags: symbol.tags.clone(),
|
tags: symbol.tags.clone(),
|
||||||
#[allow(deprecated)]
|
|
||||||
deprecated: symbol.deprecated,
|
deprecated: symbol.deprecated,
|
||||||
location: Location::new(url.clone(), symbol.range),
|
location: Location::new(url.clone(), symbol.range),
|
||||||
container_name,
|
container_name,
|
||||||
|
|
|
@ -120,7 +120,7 @@ pub struct DataVisitor<'a> {
|
||||||
string: &'a mut String,
|
string: &'a mut String,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> Visit for DataVisitor<'a> {
|
impl Visit for DataVisitor<'_> {
|
||||||
fn record_debug(&mut self, field: &Field, value: &dyn std::fmt::Debug) {
|
fn record_debug(&mut self, field: &Field, value: &dyn std::fmt::Debug) {
|
||||||
write!(self.string, "{} = {:?} ", field.name(), value).unwrap();
|
write!(self.string, "{} = {:?} ", field.name(), value).unwrap();
|
||||||
}
|
}
|
||||||
|
|
|
@ -134,7 +134,7 @@ pub enum TokenTreeRef<'a, Span> {
|
||||||
Leaf(&'a Leaf<Span>, &'a TokenTree<Span>),
|
Leaf(&'a Leaf<Span>, &'a TokenTree<Span>),
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a, Span: Copy> TokenTreeRef<'a, Span> {
|
impl<Span: Copy> TokenTreeRef<'_, Span> {
|
||||||
pub fn span(&self) -> Span {
|
pub fn span(&self) -> Span {
|
||||||
match self {
|
match self {
|
||||||
TokenTreeRef::Subtree(subtree, _) => subtree.delimiter.open,
|
TokenTreeRef::Subtree(subtree, _) => subtree.delimiter.open,
|
||||||
|
|
|
@ -79,7 +79,7 @@ impl CommentBlock {
|
||||||
let mut block = dummy_block.clone();
|
let mut block = dummy_block.clone();
|
||||||
for (line_num, line) in lines.enumerate() {
|
for (line_num, line) in lines.enumerate() {
|
||||||
match line.strip_prefix("//") {
|
match line.strip_prefix("//") {
|
||||||
Some(mut contents) => {
|
Some(mut contents) if !contents.starts_with('/') => {
|
||||||
if let Some('/' | '!') = contents.chars().next() {
|
if let Some('/' | '!') = contents.chars().next() {
|
||||||
contents = &contents[1..];
|
contents = &contents[1..];
|
||||||
block.is_doc = true;
|
block.is_doc = true;
|
||||||
|
@ -89,7 +89,7 @@ impl CommentBlock {
|
||||||
}
|
}
|
||||||
block.contents.push(contents.to_owned());
|
block.contents.push(contents.to_owned());
|
||||||
}
|
}
|
||||||
None => {
|
_ => {
|
||||||
if !block.contents.is_empty() {
|
if !block.contents.is_empty() {
|
||||||
let block = mem::replace(&mut block, dummy_block.clone());
|
let block = mem::replace(&mut block, dummy_block.clone());
|
||||||
res.push(block);
|
res.push(block);
|
||||||
|
|
Loading…
Reference in a new issue