|
|
|
|
|
by potiuper
2682 days ago
|
|
A basic linter does not resolve the semantic question. The linter could be satisfied by changing the code syntax given the rule to always include curly brackets after an if to: if (something) {}; { do_something(); } But, the question is the empty bracket correct or should the contents of the subsequent scope be cut into the scope of the if bracket or copied into it or should the if condition be removed altogether? Code styles do not change the intent and always requiring {} after an if is unnecessary for single statements given the intent is correct: if (side_effect()); else { do_something(); } Alternative syntax styles for the same semantics do not clarify the intent of a program. |
|
That's not the job of the linter, that's the job of the engineer.
> The linter could be satisfied by changing the code syntax [...]
What you're suggesting is the equivalent of turning your car stereo up so that you don't hear the strange noise your car is making.
> But, the question is the empty bracket correct or should the contents of the subsequent scope be cut into the scope of the if bracket?
That's the job of the engineer to figure out. The linter is only supposed to raise the flag, not come up with the answer.