5.0.0 β€’ Published 6 months ago

@putout/plugin-remove-useless-functions v5.0.0

Weekly downloads
2,532
License
MIT
Repository
github
Last release
6 months ago

@putout/plugin-remove-useless-functions NPM version

🐊Putout plugin adds ability to find and remove useless functions.

Install

npm i @putout/plugin-remove-useless-functions -D

Rule

{
    "rules": {
        "remove-useless-functions": "on"
    }
}

❌ Example of incorrect code

const y = (...a) => {
    alert(...a);
};

[1, 2, null].filter((a) => a);

βœ… Example of correct code

const y = alert;
[1, 2, null].filter(Boolean);

Open Questions

Why there is no transform for such case:

const f = (a) => alert(a);

Isn't is the same as:

const f = alert;

Actually it is the same, and this example can be converted without an issue, but there is also cases like:

const one = (f) => (a) => f(a);

[
    1,
    2,
    3,
    4,
].map(one(console.log));

// output
1;
2;
3;

And if it will be simplified:

const one = (f) => f;

[
    1,
    2,
    3,
    4,
].map(one(console.log));

// output
'1 0 [1, 2, 3]';
'2 1 [1, 2, 3]';
'3 2 [1, 2, 3]';

So behaviour is totally different. The same result for:

[
    1,
    2,
    3,
    4,
].map(console.log);

Because map calls a function with 3 arguments, and console.log receives any count of arguments, to cut redundant args there is a need to use something like:

const one = (f) => (a) => f(a);

There is a lot such cases in the wild. While we have no syntax to set the count of arguments we are going to receive, and a way to avoid returning result we don't want function to return, there is no need in such a dengerous transform.

License

MIT

5.0.0

6 months ago

4.0.0

10 months ago

3.0.0

2 years ago

2.0.0

4 years ago

1.1.0

4 years ago

1.0.5

5 years ago

1.0.4

5 years ago

1.0.3

5 years ago

1.0.2

5 years ago

1.0.1

5 years ago

1.0.0

5 years ago