mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-16 07:03:57 +00:00
Auto merge of #16519 - tetsuharuohzeki:more-lint, r=lnicola
Enable some minor lints that we should tackles (take2) This enables these lints: - borrowed_box - derived_hash_with_manual_eq - forget_non_drop - needless_doctest_main
This commit is contained in:
commit
bb0de88f24
7 changed files with 19 additions and 16 deletions
|
@ -168,10 +168,6 @@ new_ret_no_self = "allow"
|
||||||
useless_asref = "allow"
|
useless_asref = "allow"
|
||||||
|
|
||||||
## Following lints should be tackled at some point
|
## Following lints should be tackled at some point
|
||||||
borrowed_box = "allow"
|
|
||||||
derived_hash_with_manual_eq = "allow"
|
|
||||||
forget_non_drop = "allow"
|
|
||||||
needless_doctest_main = "allow"
|
|
||||||
too_many_arguments = "allow"
|
too_many_arguments = "allow"
|
||||||
type_complexity = "allow"
|
type_complexity = "allow"
|
||||||
wrong_self_convention = "allow"
|
wrong_self_convention = "allow"
|
||||||
|
|
|
@ -264,7 +264,7 @@ impl GenericParamsCollector {
|
||||||
self.add_where_predicate_from_bound(
|
self.add_where_predicate_from_bound(
|
||||||
lower_ctx,
|
lower_ctx,
|
||||||
bound,
|
bound,
|
||||||
lifetimes.as_ref(),
|
lifetimes.as_deref(),
|
||||||
target.clone(),
|
target.clone(),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -275,14 +275,14 @@ impl GenericParamsCollector {
|
||||||
&mut self,
|
&mut self,
|
||||||
lower_ctx: &LowerCtx<'_>,
|
lower_ctx: &LowerCtx<'_>,
|
||||||
bound: ast::TypeBound,
|
bound: ast::TypeBound,
|
||||||
hrtb_lifetimes: Option<&Box<[Name]>>,
|
hrtb_lifetimes: Option<&[Name]>,
|
||||||
target: Either<TypeRef, LifetimeRef>,
|
target: Either<TypeRef, LifetimeRef>,
|
||||||
) {
|
) {
|
||||||
let bound = TypeBound::from_ast(lower_ctx, bound);
|
let bound = TypeBound::from_ast(lower_ctx, bound);
|
||||||
let predicate = match (target, bound) {
|
let predicate = match (target, bound) {
|
||||||
(Either::Left(type_ref), bound) => match hrtb_lifetimes {
|
(Either::Left(type_ref), bound) => match hrtb_lifetimes {
|
||||||
Some(hrtb_lifetimes) => WherePredicate::ForLifetime {
|
Some(hrtb_lifetimes) => WherePredicate::ForLifetime {
|
||||||
lifetimes: hrtb_lifetimes.clone(),
|
lifetimes: hrtb_lifetimes.to_vec().into_boxed_slice(),
|
||||||
target: WherePredicateTypeTarget::TypeRef(Interned::new(type_ref)),
|
target: WherePredicateTypeTarget::TypeRef(Interned::new(type_ref)),
|
||||||
bound: Interned::new(bound),
|
bound: Interned::new(bound),
|
||||||
},
|
},
|
||||||
|
|
|
@ -721,6 +721,9 @@ impl Clone for Box<dyn OpaqueInternableThing> {
|
||||||
pub struct InTypeConstId(salsa::InternId);
|
pub struct InTypeConstId(salsa::InternId);
|
||||||
impl_intern!(InTypeConstId, InTypeConstLoc, intern_in_type_const, lookup_intern_in_type_const);
|
impl_intern!(InTypeConstId, InTypeConstLoc, intern_in_type_const, lookup_intern_in_type_const);
|
||||||
|
|
||||||
|
// We would like to set `derive(PartialEq)`
|
||||||
|
// but the compiler complains about that `.expected_ty` does not implement the `Copy` trait.
|
||||||
|
#[allow(clippy::derived_hash_with_manual_eq)]
|
||||||
#[derive(Debug, Hash, Eq, Clone)]
|
#[derive(Debug, Hash, Eq, Clone)]
|
||||||
pub struct InTypeConstLoc {
|
pub struct InTypeConstLoc {
|
||||||
pub id: AstId<ast::ConstArg>,
|
pub id: AstId<ast::ConstArg>,
|
||||||
|
|
|
@ -228,7 +228,7 @@ impl MemoryMap {
|
||||||
&self,
|
&self,
|
||||||
mut f: impl FnMut(&[u8], usize) -> Result<usize, MirEvalError>,
|
mut f: impl FnMut(&[u8], usize) -> Result<usize, MirEvalError>,
|
||||||
) -> Result<FxHashMap<usize, usize>, MirEvalError> {
|
) -> Result<FxHashMap<usize, usize>, MirEvalError> {
|
||||||
let mut transform = |(addr, val): (&usize, &Box<[u8]>)| {
|
let mut transform = |(addr, val): (&usize, &[u8])| {
|
||||||
let addr = *addr;
|
let addr = *addr;
|
||||||
let align = if addr == 0 { 64 } else { (addr - (addr & (addr - 1))).min(64) };
|
let align = if addr == 0 { 64 } else { (addr - (addr & (addr - 1))).min(64) };
|
||||||
f(val, align).map(|it| (addr, it))
|
f(val, align).map(|it| (addr, it))
|
||||||
|
@ -240,7 +240,9 @@ impl MemoryMap {
|
||||||
map.insert(addr, val);
|
map.insert(addr, val);
|
||||||
map
|
map
|
||||||
}),
|
}),
|
||||||
MemoryMap::Complex(cm) => cm.memory.iter().map(transform).collect(),
|
MemoryMap::Complex(cm) => {
|
||||||
|
cm.memory.iter().map(|(addr, val)| transform((addr, val))).collect()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -126,6 +126,10 @@ impl DropScopeToken {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl Drop for DropScopeToken {
|
||||||
|
fn drop(&mut self) {}
|
||||||
|
}
|
||||||
|
|
||||||
// Uncomment this to make `DropScopeToken` a drop bomb. Unfortunately we can't do this in release, since
|
// Uncomment this to make `DropScopeToken` a drop bomb. Unfortunately we can't do this in release, since
|
||||||
// in cases that mir lowering fails, we don't handle (and don't need to handle) drop scopes so it will be
|
// in cases that mir lowering fails, we don't handle (and don't need to handle) drop scopes so it will be
|
||||||
// actually reached. `pop_drop_scope_assert_finished` will also detect this case, but doesn't show useful
|
// actually reached. `pop_drop_scope_assert_finished` will also detect this case, but doesn't show useful
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//! Implementation of "implicit drop" inlay hints:
|
//! Implementation of "implicit drop" inlay hints:
|
||||||
//! ```no_run
|
//! ```ignore
|
||||||
//! fn main() {
|
|
||||||
//! let x = vec![2];
|
//! let x = vec![2];
|
||||||
//! if some_condition() {
|
//! if some_condition() {
|
||||||
//! /* drop(x) */return;
|
//! /* drop(x) */return;
|
||||||
//! }
|
//! }
|
||||||
//! }
|
|
||||||
//! ```
|
//! ```
|
||||||
use hir::{
|
use hir::{
|
||||||
db::{DefDatabase as _, HirDatabase as _},
|
db::{DefDatabase as _, HirDatabase as _},
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
//! Implementation of "range exclusive" inlay hints:
|
//! Implementation of "range exclusive" inlay hints:
|
||||||
//! ```no_run
|
//! ```ignore
|
||||||
//! for i in 0../* < */10 {}
|
//! for i in 0../* < */10 {}
|
||||||
//! if let ../* < */100 = 50 {}
|
//! if let ../* < */100 = 50 {}
|
||||||
//! ```
|
//! ```
|
||||||
|
|
Loading…
Reference in a new issue