Skip to content

Rustc should throw a helpful warning on useless "self" argument in methods. #1827

Open
@iddm

Description

@iddm

When we have a code which does not need the self object we may simply say that it can be removed.

struct A(u64);
impl A {
    fn m1(&self) { // warning: unused self can be removed
        println!("Hello world");
    }

    fn m2(&mut self) { // warning: unused self can be removed
        println!("Hello again");
    }
}

Though, this warning should have a possibility to be ommited. And, for example, there are some special cases, one of which @eddyb has pointed me to: if we have a trait which requires method to accept self as a parameter, we don't need to emit such warning:

struct A(u64);
trait Printable {
    fn m1(&self);
}
impl Printable for A {
    fn m1(&self) { // no warning is here
        println!("Printed!");
    }
}

The reason of that is making easier to refactor this code in the future (especially if it is very long and we must read the whole method body just to understand that it does not depend on object at all) and to allow code users to call this method without an object.

If this idea gets approved, I would like to implement it by myself. But I have no idea how to work with it so I would like to get some advices where to look at, in learning purposes. I love rust and I want to help to make it better as much as I can.

Metadata

Metadata

Assignees

No one assigned

    Labels

    T-compilerRelevant to the compiler team, which will review and decide on the RFC.

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions