Remove expansion restriction + fix doc and tests naming

This commit is contained in:
ThibsG 2020-08-25 09:16:08 +02:00
parent 2a3ee5fa85
commit 3cb75c2e5c
2 changed files with 27 additions and 13 deletions

View File

@ -725,6 +725,7 @@ declare_clippy_lint! {
/// **Known problems:** None.
///
/// **Example:**
/// In an impl block:
/// ```rust
/// # struct Foo;
/// # struct NotAFoo;
@ -737,25 +738,40 @@ declare_clippy_lint! {
///
/// ```rust
/// # struct Foo;
/// # struct FooError;
/// struct Bar(Foo);
/// impl Foo {
/// // Good. Return type contains `Self`
/// fn new() -> Result<Foo, FooError> {
/// # Ok(Foo)
/// // Bad. The type name must contain `Self`
/// fn new() -> Bar {
/// # Bar(Foo)
/// }
/// }
/// ```
///
/// ```rust
/// # struct Foo;
/// struct Bar(Foo);
/// # struct FooError;
/// impl Foo {
/// // Bad. The type name must contain `Self`.
/// fn new() -> Bar {
/// # Bar(Foo)
/// // Good. Return type contains `Self`
/// fn new() -> Result<Foo, FooError> {
/// # Ok(Foo)
/// }
/// }
/// ```
///
/// Or in a trait definition:
/// ```rust
/// pub trait Trait {
/// // Bad. The type name must contain `Self`
/// fn new();
/// }
/// ```
///
/// ```rust
/// pub trait Trait {
/// // Good. Return type contains `Self`
/// fn new() -> Self;
/// }
/// ```
pub NEW_RET_NO_SELF,
style,
"not returning type containing `Self` in a `new` method"
@ -1679,8 +1695,6 @@ impl<'tcx> LateLintPass<'tcx> for Methods {
fn check_trait_item(&mut self, cx: &LateContext<'tcx>, item: &'tcx TraitItem<'_>) {
if_chain! {
if !in_external_macro(cx.tcx.sess, item.span);
if !item.span.from_expansion();
if item.ident.name == sym!(new);
if let TraitItemKind::Fn(FnSig { decl, .. }, _) = &item.kind;
if let FnRetTy::Return(ret_ty) = &decl.output;

View File

@ -137,9 +137,9 @@ impl MutPointerReturnerOk {
}
}
struct MutPointerReturnerOk2;
struct ConstPointerReturnerOk2;
impl MutPointerReturnerOk2 {
impl ConstPointerReturnerOk2 {
// should not trigger lint
pub fn new() -> *const Self {
unimplemented!();
@ -283,7 +283,7 @@ mod issue5435 {
}
}
trait MutPointerReturnerOk2 {
trait ConstPointerReturnerOk2 {
// should not trigger lint
fn new() -> *const Self
where