- Feature Articles
-
CodeSOD
- Most Recent Articles
- Crossly Joined
- My Identification
- Mr Number
- intint
- Empty Reasoning
- Zero Competence
- One Month
- A Little Extra Padding
-
Error'd
- Most Recent Articles
- Monkeys
- Killing Time
- Hypersensitive
- Infallabella
- Doubled Daniel
- It Figures
- Three Little Nyms
- Tangled Up In Blue
- 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
To get this started:
if ( comments <= NO_OF_SECOND_COMMENT ) return "first";
Admin
One more time bug and I'm calling for a general strike. Let's all switch to POSIX time already.
Q: What time is it?
A: 1244466496
Q: When do you want to have lunch?
A: About 1244480000 work for you?
Admin
give us a couple hundred years to integrate with our machines and that should be perfectly reasonable.
Admin
Protip: You don't have to wait until a Feb 29th to fix this bug.
Admin
Most in-house time libraries I've seen were broken. Including the ones I wrote myself.
A fun one was detecting the numbers of days between two dates by asking the OS-provided library the number of seconds since a fixed date, and dividing the difference by 86400.
Worked like a charm... until daylight savings kicked in...
Admin
puts c++ beard on
no include guards, which is especially great when using so many #defines
expects that someone puts a global "using namespace std;" before including time_help.h (or spreads specific using directives like "using std::cout;" etc. around)
no "inline" linkage, so multiple source-files #including time_help.h will result in multiple definition errors
mixing floating point with integer calculations without proper cast and relying on compiler specific behaviour
"#define SECpYEAR 31536000" some lines later "#define YEAR time(NULL)/31536000+1970" --> yay for still using magic numbers --> double yay for for not putting the definition in round braces
Oh that code is so great. But regarding that it's not even 2^8 lines long, why not just rewrite instead of fixing?
Admin
"int dateformat;" and "int YEARSCOPE;" in header file is a very clever solution - each .c file can use its own time format and yearscope (whatever it means).
I like that the month length is a random variable with value (almost correct) of expected value in randomly taken month (AVGDAYINMONTH 30.4375). Although
would not be so optimized.Admin
Admin
I remember the very moment, as a rookie coder, when I was using VBScript's date libraries and ran into yet another unexpected behavior. I made the crucial mistake of saying "Psh, I can do this better myself" instead of taking the time to understand how the date/time libraries really work.
I shunned built-in date/time functions and built workarounds for the next 2-3 years. It became second nature to just ignore their existence. Fortunately, I didn't work on a lot of products that used dates except for a timestamp here and there.
I don't know what caused me to revisit it (either working with a new language or looking at someone else's code) but I soon realized how much time and how many issues I introduced myself too and wasted my life on.
Admin
I see the bug! Sugust has 31 days not 30!:
Admin
My biggest daylight savings WTF was a calendar app that showed one row too many when the clocks went forward in spring and one too few in autumn.
The workaround was so ugly I had to code it looking through my fingers.
Admin
Fixed!~
Admin
Sugust only has 4.5 days ;o)
Admin
musical interlude Does anybody really know what time it is?
Admin
Actually, with only 30 days in August, a bug would occur every day during half of the year. This code is obviously not used... or if it is, not finding said bug earlier is TRWTF.
Admin
If anybody really cares, let's hope they don't call the function from this WTF.
Admin
Apparently:
August has 30 days September has 31 days October has 30 days November has 31 days December has 30 days
So during the month transitions of August, October and December, this function would return the wrong value.
But I bet the real WTF is that FEBLENGTH is a #defined constant that was set once when the code was compiled in a non-leap year.
Admin
Strange, that dude forgot Sugust all over the place. But maybe the team fixes it soon enough in Deptember.
Admin
Sorry, didn't realise that the actual header was part of the article. I guess my suspicions about FEBLENGTH were unfounded.
Admin
Admin
Admin
Many years ago, we got bug reports that our IsLeap() function was broken because it said that the year 2000 was a leap year. (We got it right --- 2000 was a leap year --- while many of the "big names" got it wrong, and had to patch it along with their other Y2K fixes.)
Admin
Admin
These seem like rather important parts of the story that shouldn't have been left off...
#define LASTLEAPYEAR 2008 #define LEAPYEARINTERVAL 4 #define SINCELASTLEAPYEAR YEAR-LASTLEAPYEAR #define YEAR time(NULL)/31536000+1970 #define LEAPYEAR ((((YEAR-LASTLEAPYEAR)%LEAPYEARINTERVAL)==0)?true:false)
Admin
Let's not forget that in their world, day 22 of each month is formatted in mode 3 as the 22:th... (beats me why the : is there)
For real fun with ordinals, though, try Welsh, where depending on the number and the grammatical gender of the following noun, the suffix after digits may be -af, -il, -ydd, -edd, -ed, -fed, -eg, or -ain.
Admin
It's not "car-crash" code, it's "WTF IS THIS SHIT?" code. I could probably take a dump and the result would make ,ore sense than this pile of garbage.
Someone got pwned by date formats...
Admin
Yes, yet again, complain about something, do NOTHING about it, and leave it to someone else. Which is exactly why code like this exists.
a) someone weak creates it b) someone with NO BALLS WHATSOEVER finds it c) said person with NO SPINE reports to hilarious internet site, taking about as much time and energy as it would to probably FIX the original problem d) someone like me says "that's why there are so many WTFs, it's because the shit developers are the only ones with spines".
:(
Admin
*more
Actually I think this says it all:
#include <time.h> // Includes base header time.h
Protip: if you feel the need to comment an #include line, but not the actual contorted and horribly broken logic you've rendered unto your text editor, you may not be a good programmer.
Admin
Admin
... seriously though, a lack of parentheses around a macro is just BEGGING for trouble. For extra fun, make macros with unbalanced braces, parentheses, and doublequotes in them... and perhaps throw in a return and/or semicolon occasionally.
Admin
C++ beard on again
Oh I have forgotten those:
C <time.h> instead of C++ <ctime>
expects someone to #include <iostream> etc.
And as for my initial comment about that time_help.h expects someone to put using declarations before #inclusion: This might be a false assumption. It could also that it just expects someone to write code like
namespace std { #include "time_help.h" }
and because of that maybe, the author has #included time.h instead of ctime, because basically ctime is time.h inside namespace std.
Admin
I would suggest a comment on an include line indicates that line - among others - was copy-pasted from some form of "beginner's tutorial"...
Admin
But the full file has been linked over in the initial post.
Admin
If this is a sample of the code, then the application is probably more of a train wreck instead of a car crash.
Admin
/me runs for cover
Admin
Cool, uncopyrighted code! So I can take this and use it for my job!
Just have to fix that August bug and add some parentheses around the define expressions and we're ready to go.
Thanks, DWTF!
Admin
It's probably C - single line comments with // are no longer C++ only and it's including time.h rather than ctime.
The preprocessor in all the compiler suites I'm aware of cache includes and don't parse them twice. Some people would argue that include guards are just noise (personally I do use them, but that may be more out of habit).
Again, this might be C rather than C++.
I'll let my compiler inline for me where it thinks it's suitable. Most attempts to game the optimising passes of a decent compiler lose.
Those are definite WTFs, and as you say it looks eminently fixable. It's probably Alex fictionalising things as usual - the submitter probably did fix this.
Admin
Lousy Smarch weather!
Admin
It is 25 or 6 to 4.
Admin
Admin
Gah. I hadn't clicked on the link, and was going on what was included in the article body. Apologies.
Admin
Heh. MMDDYY dates FTW. Why the hell did someone create this retarded, mixed-up format to begin with ? :p
dodges tomatoes
Admin
Admin
You must've missed the call to cout then.... Or I missed when cout was added to C.
Admin
A few more to add for you:
And that is without even considering the actually algorithms in use. Probably plenty more. Ugh, this is indeed a disaster!
Admin
Yours Yazeran
Plan: to go to Mars one day with a hammer
Admin
Anything that prevents a future issue and loss of time/money/resources can be seen as a ROI in my book. The bug can be fixed in a couple hours, and would pay dividends as well as avoiding the case where they use "certain" parts of it that worked. They can fix the bug and hopefully make all parts work correctly in less than a day.
Admin
Admin
Admin
[quote user="Zapp Brannigan"][quote]Ah Leeeeerooooy Jennnnnkinnnnnns![/quote]
Thank You! I always speculated on the name of that Design Pattern.