- Feature Articles
- CodeSOD
-
Error'd
- Most Recent Articles
- Secret Horror
- Not Impossible
- Monkeys
- Killing Time
- Hypersensitive
- Infallabella
- Doubled Daniel
- It Figures
- Forums
-
Other Articles
- Random Article
- Other Series
- Alex's Soapbox
- Announcements
- Best of…
- Best of Email
- Best of the Sidebar
- Bring Your Own Code
- Coded Smorgasbord
- Mandatory Fun Day
- Off Topic
- Representative Line
- News Roundup
- Editor's Soapbox
- Software on the Rocks
- Souvenir Potpourri
- Sponsor Post
- Tales from the Interview
- The Daily WTF: Live
- Virtudyne
Admin
I hope origional is spelled consistently throughout the code, or there will be other problems.
Admin
if(frist) ;
IOW, even the comment is empty. :)
Admin
More useful comments (I hope) ...
I almost wonder if the first one
if (!checkAndDelete( ...
isn't a warped attempt to call a method that has a return value and swallow the return value. Yes, darn near every language nowadays will swallow a return value. In Ye Olden Tymes that was less true. Of perhaps theif(...)
construct was a way to stop a warning or lint message about an unused return value. But that doesn't explain the useless negation.Of course the real truth is probably that there used to be a body under the
if
, then requirements changed. But the method call in theif
predicate has side effects, so of course it needed to stay. Under the misguided principal of "minimum possible changes ever; refactor never" they just removed the body leaving theif (...)
exactly as it was.Admin
I can guess how the first one happened. Presumably
checkAndDelete
both does the deletion and rerurns a value representing the result of the check (I guess whether there was anything to actually delete?). At one point, this return value was used to conditionally run some extra code - and at some point, that additional code became unnecessary.At that point, some less bright team member presumably first tried deleting the whole block, but found the code broke (the side effect of the deletion being important). So they decided to keep the
if
and just remove the body - as opposed to the less confusing alternative of just leaving thecheckAndDelete
call as a single statement, not caring about its return value.Admin
Aargh, the post above appeared while I was typing. Still, great minds and all...
Admin
"$mail->SMTPAuth = false; // turn on SMTP authentication"
This is certainly from PHPMailer a widespread email utility for PHP. I probably even have this exact line in my testing server copy of the code. The value gets set to "false" or "true" depending on how code is being tested.
Sure, the comment (which comes that way with the PHPMailer package) should be "// turn SMTP authentication on or off", but that's pretty picky when the point is so obvious to anyone actually using the code.
Admin
If this comment gets held for moderation, then.
Admin
But, it is not obvious.
I was going to say it should be:
$mail->SMTPAuth = false; // TODO: turn on SMTP authentication
as i read 'turn on SMTP authentication' in the imperative mood.
Admin
Left out:
and
Or are those no longer WTF's?
Admin
If you can code — and not make your code your master; If you can comment — and not make the comments a shame; If you can bear to have your flag for authentication Set by knaves in mockery of the same; Empty line
Admin
Be careful with this rationale. If "it doesn't matter because it's obvious", then what's the rationale for doing it at all? That's actually what everyone is trying to say when they say that the comments shouldn't simply repeat the code. If all you have to say to the next person that reads this code is what it already says... then don't say it again. Leave the comment out.
Admin
In a codebase I’m working on, there’s this:
[code] ///
git blame claims that the penultimate line was changed from 'true' to 'false' about a year after the function was initially written.
Admin
This. I've said it before, many times, and I'm sure I'll say it again, but...
Comments in code should answer the question, "why?"... (In French, it is, perhaps, easier: comments should describe pourquoi(1) and not quoi(2).)
(1) "pourquoi" === "why"
(2) "quoi" == (slightly indirectly) "what".
Admin
As an example of Microsoft turning something off to turn it on, I give you an exhibit from SQL Server:
SET NOCOUNT OFF
(Normally you see SET NOCOUNT ON which is a bit easier to understand for some reason - this line will supress SSMS from displaying the count of rows for each subsequent statement)
Admin
DISABLE NOCOUNT = OFF DELETE TABLE (NO) // This activates IPv4 NOT FROM PACKAGE "oregional.foo" DON'T INSTALL APP "smtpthing" UNLESS TRUE != FALSE WITHOUT DEPENDENCY DISALLOW ACCESS BLOCKED = NO_ENTRY OR DIE NEVER IF DOES NOT EXIST INPUTFILE(OUTFILE) UNLESS 100 MB < OR > OR = USED_SPACE THEN [ OR NOT ] REBOOT::HCF WHEN CONTINUE THEN STOP DO NOT EXIT -1
Admin
If code and comment disagree then probably both are wrong.
Admin
Could it be that the "NO" of "NOCOUNT" is intended like a "num"? Just a thought, but of course prefixing a count with "no" or "num" would be redundant, so perhaps far fetched.
Admin
The second example always evaluates to True because the & operator coerces Nothing to the empty string "". So that If statement block will always get executed!
Admin
Clear of breaking SRP and having a function that has a side effect. Nothing to see here....