- Feature Articles
-
CodeSOD
- Most Recent Articles
- Brushing Up
- Irritants Make Perls
- Crossly Joined
- My Identification
- Mr Number
- intint
- Empty Reasoning
- Zero Competence
-
Error'd
- Most Recent Articles
- Not Impossible
- Monkeys
- Killing Time
- Hypersensitive
- Infallabella
- Doubled Daniel
- It Figures
- Three Little Nyms
- 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
Admin
Probably a compile-time constant... change the constant and recompile, and you've got a debug build. Good for performance if the compiler can optimise out any unused code, but annoying in an IDE that's smart enough to spot dead code and warn you about it...
Admin
Umm. Wont it wait 100 * 100 counts of whatever the wait function takes. Assuming that's milliseconds, this ought to be "timeInCentiseconds"
Admin
Admin
So...is the TDWTF here the syntax error near ToUpper, the apparent company coding standard requirement that detailed change history comments must be written for even the most minor changes, commenting out the old code instead of deleting it, having a separate function to check for Nothing, not using the invariant culture for the ToUpper call, or the fact that this is VB.NET?
I think it's the last one.
Admin
Right, but if you're talking about virtual functions, (like this one), it's very unlikely, as the program will crash before it can execute the function... Unless you call it specifically.
And really, doing ptr->SomeClass::Function(a,b,c) is usually asking for problems ^^
Admin
Example:
Also, doing above in C, while possible, would be a PITA ^^
Admin
It's actually not VB itself, it's VB6 programmers still doing things the same way they did back then, when there is a better way. I mean really, assigning the value to the function name? Works, but it's confusing. I'm pretty sure there is "Option strict off" at the top of the file I found this in. Might also seriously contain a "on error resume next" also, and I'm not shitting you. I get hundreds of warnings when compiling. I've been told to ignore them.
The company is changing to C# this year, so the code quality should get even worse, given that this "code problem" is actually a management problem and switching the language doesn't accomplish the same thing as firing the managers.
Admin
Speaking as someone's red-headed step child: get your own.
Admin
Admin
You may just have identified it. At least, these figures and the general WTF-ery of the code certainly brought a particular product to my mind.
Admin
On a more serious note though, I feel for you. I work with VB6 and VB.NET code in my day job, and I dread having to fix anything our (luckily former) senior developer worked on. I once tried building one of his solution files and actually got a warning from Visual Studio telling me that couldn't display any more warnings.
We should probably all be very afraid that he used to work on missile defense systems before joining our company...
Admin
I remember working on some cryptographic components which were tended to get very layered (due to misunderstandings and bad design, mainly - instead of replacing a translation layer {for example} they simply added another one). Nonetheless, the RSA component passed many (about 13, I think - some were shortcut calculations, some were redundant, maybe I exagerate) parameters down the chain.
A structure like you suggest is far more appropriate - but in that case, why not use a struct? Your suggestion is perhaps marginally simpler in certain cases, but I'm not sure I really see that it's all that different (you simply get rid of the populating structure bit...)
Admin
Clearly we need a function that removes the Not-non-uninvisible property as well.
Admin
Admin
Admin
Admin
Let's say I have a Controller object that manages state, including boolean state, for a graph of objects. Why would I not give objects that depend upon that boolean state a reference to the Controller object instead of farming out to yet another object on the heap that adds nothing of value whatsoever?
Admin
Compilers are getting better and better at exploiting undefined behavior to improve the performance of compliant code; IMO it's a pretty small step from some of the things they do now to "changing" the semantics of code that relies on being able to call methods on null.
Addendum (2011-07-21 01:10): And just to give you an idea of the sort of optimization that could matter, consider the following code:
The standard says that the function call on line 3 counts as a dereference, which means that the compiler can know that p can't legally be null. (More specifically, it can know that it can do anything it wants in the case that it is null.)
The fact that p "can't be" null means that the conditional on line 4 isn't needed, because it will always take the true branch. Thus the compiler can discard the else branch.
It is entirely legal -- and I would argue completely moral -- for the compiler to emit the following pseudo-assembly for that function:
That means that foo would always return 1, while if it were to just blithely go along with a naive transformation, you'd expect it to return 2 if p were NULL.
Now, no compilers that I tried (MSVC 2010, GCC 4.6.0, Intel CC 11.0, and Clang++ 2.9) actually perform this optimization, but they could. And not only could they, it'd probably be almost easy to add to some of them.
To argue this, let's look at a simplified version of that function:
As before, the dereference of p on line 3 allows the compiler to optimize away the conditional on line 4. (Note the change of return value from 1 to y -- this avoids dead code elimination from removing line 3.)
Now, do compilers optimize away the conditional? Yes they do, or at least GCC does.
Here is the actual output from g++ -O2 for this version (I removed a label and demangled the name of foo):
No conditional... no branch... no predicated instruction.
Now, in this case the actual semantics don't change -- calls where p is non-null will return *p and calls where p is null will still segfault -- but it does show that the fundamental optimization of using dereferences to infer that certain values cannot be null is already in place.
The only thing that is preventing them from using that mechanism to optimize my earlier example is likely either that they just haven't thought about it or that they have and decided that it wasn't worth breaking existing code that ill-advisedly relies on a particular implementation of undefined behavior.
(And actually, I lied before when I said the optimization in the second version of foo don't change the semantics: they do change the semantics if you're on a system that lets you map page 0, and you do so. Without the optimization I describe, foo(NULL) will return 2; with the optimization, it will return the value at address 0.)
Long story short: don't rely on undefined behavior unless you have a damn good reason and you do some audits (and keep doing audits as you change both the code and compilers/compiler versions) to make sure that the compiler isn't doing something you don't expect. Undefined behavior is a part of C/C++ programming, and you will write code that falls into that category. But that code is not something you should be proud of. It's not something you should try to justify. It's something you should fix.
Addendum (2011-07-21 01:20): I forgot one critical aspect: the definition of someFunction may need to be visible, and the compiler able to establish that its invocation does not change the value of p. I'm not sure about this though... what I said may be correct as I wrote it. I don't know what the rules are regarding where the compiler is allowed to assume values don't change and stuff like that (the whole volatile thing.)
Addendum (2011-07-21 01:40): One last comment then I'm going to bed. In the previous addendum I had a bit of pointer-pointee confusion -- I now think that what I said originally is indeed, correct.
The only function that can (legally) obtain the address of p is foo itself. It never does, which means that the compiler is allowed to assume that p is not aliased to anything. (Assuming locals aren't aliased "behind the compiler's back" is common.) Thus the call to someFunction can't change the value of p, which means that my proposed optimization goes through as described.
The compiler is allowed to make that optimization regardless of whether the definition of someFunction is available. (Practically speaking, making it available and thus eligible for inlining would be likely to affect whether the optimization was performed, in much the same way that I needed to return y in the second version of foo to prevent the dead-code-elimination optimization step from removing the dereference before the redundant-null-check optimization phase got a chance to run.)
Admin
YES! Which is a perfectly good reason for not liking something. Programming is about communication and this is BAD communication. MAX_NUMBER_ATTACHMENTS in no way communicates the fact that it enables or disables logging.
A future programmer gets sent a request to increase the maximum number of attachments, then gets sent a bug report when exceptions are thrown because the logging never really worked but it didn't matter because it was off. Then everyone sits back thinking, bah, silly programmer, can't even increase the maximum number of attachments without causing exceptions! Then multiply this by an entire codebase.
Naming is one of the most important skills for a programmer.
Admin
If you call Wait(x) with 100 <= x < 200 it will call Thread.Sleep(100) once. So the submitter is correct that the unit is milliseconds.
Perhaps the variable should be called timeInMillisecondsRoundedToTheNearestSecond.
Admin
While we are at it, why not anonymous structured type creation:
I guess this idea needs more work, it's starting to feel like javascript.
By the way, a syntax like what Hortical suggested already exists in scala, if I'm allowed to make propaganda.
Admin
Admin
I love the mutable boolean that is immutable.
Admin
A MutableBoolean is actually pretty useful if you need a method to be able to change a flag you pass in its argument list, as the standard Java Boolean is immutable. So the only real WTF is rolling your own, rather than using the MutableBoolean provided by commons-lang. Oh, and value should be declared volatile, to ensure visibility of changes made in other threads. And the initialisation to true is pointless, as the only constructor provided sets it. But aside from that...
Admin
On Solaris 8 (old box hanging around) /bin/true is (this is the whole file):
I think on older release it was just a 0-byte file but at some point someone thought it would be a good idea to apply for copyright for those 0 bytes.
Admin
Admin
You sick fuck! He's your son!
Admin
It takes 10 seconds. Just write it.
DO IT LIVE! FUCK IT! I'LL WRITE IT AND WE'LL DO IT LIVE!
Admin
Admin
Exactly. The code in the article was written for a very specific purpose and it fulfills that purpose. commons-lang wasn't necessary in any event because he could have used AtomicBoolean for thread safety, equals and hashcode (which is what I would have done).
So it wasn't the best way to do it. But it's not "WRONG".
Admin
That sounds like a good way to spread around unnecessary dependencies....
Admin
I'd like to quickly point out that I realize that this goes against code reuse, etc., etc., but I'm just trying to solve the problem of parameters, not everything else.
Addendum (2011-07-21 10:58): Ok, here is my (bad) example:
Admin
The only reason to write a MutableBoolean is in universes in which commons-lang hasn't been written yet. I'd be prepared to guess that maybe the MutableBoolean in the example dates from before commons-lang was introduced to the development community.
Quite a few of the WTFs I've seen are only sillies because they involve reinvention of code which at its time of writing didn't exist.
Now get off my lawn.
Admin
Possible there's a company policy to the effect that "All source code must have a copyright header in this format" blah blah. No big deal. Easier (and quicker, and more efficient too, I would surmise) to add a header to all the files matching a particular format than to have to do it by hand and thereby have to make a decision as to what should sensibly have a header and what should not.
So I'm afraid no WTF there either.
Admin
the reason to have these 2 functions below
public bool IsOk { get { return value >= 0; } }
public bool IsNotOk { get { return !IsOk; } }
are to use it like this...
if(PART_1 == IsOK AND PART_2 == IsNotOk)
very super elegant readable!
Admin
I'd name the actual language/DB involved but then there'd be 30 postings "<X> is TRWFT!" (sic) And it's not, it's the programmers.
Admin
More likely the developer is just being a smart ass because the company is not professional enough to perform code reviews.
Admin
I used to work for the government, where the success of a project was measured by how much money you spent. Did you spend your entire budget? Then the project is a success. Did you fail to spend your entire budget? Uh oh, project is a failure.
Admin
Ummm ... yes.
If someone creates a field that holds the employee's social security number, and they call it "zipcode", then, yes, I will dislike that program "just" because of the names.
Real example: I once created a function that determined whether or not a stock number that was entered by the user was valid. I called it "validateStockNumber" and it returned a boolean. Then someone else came along and added a bunch of code to also update a shipping manifest. Then someone else came along and made another update to remove the stock number validation. So then "validateStockNumber" in fact didn't validate stock numbers at all but instead updated shipping manifests.
Later another programmer came along who had to call this function through a web service. So he called his proxy function "validateStockNumberButReallyUpdateManifest".
Yes, I hated those code changes "just" because of the name.
Admin
Absolutely true ... IF you have other variables that would go in the object. But what if, for the problem at hand, the only variable you have is a single boolean. You COULD create a custom object just to hold that one boolean. But why? Why not just create a MutableBoolean that you can use in other places where you also have a single boolean?
Yes, I don't use a MutableBoolean or a MutableInteger or a Mutable-anything-else when what I really want is an object with several variables. That would just be an unnecessary extra step. But it's not at all uncommon to have just one field that I need to manage for the current problem.
Admin
I agree with earlier posters that it would be nice if a function call could return multiple values. If you could say, for example:
But the "pure Java" approach isn't really that much worse. You would typically write:
Or if you're not a bean fanatic, just let NameParser have public fields for firstname and lastname that you can use once you've created the object.
This has the side advantage that you can easily ignore "return values" that you don't care about for this particular invocation. It has the disadvantage that if the references are not written immediately following the call, it is not obvious to the reader just what was calculated where.
Admin
Admin
Admin
/*
[...]
Actually, that's not the worst example of license WTF from the late Sun.
They used to have a /bin/true which was just an empty file. That is a perfectly valid implementation of /bin/true (remember, "true" in the context of a shell script needs to return 0, which is a WTF in its own right, but that's a different matter entirely). Then some lawyer stumbled upon the fact that Sun is shipping a file without a license notice!!1!. So a license was added. They ended up with a file saying
#!/bin/sh
(i.e., "this is a shell script")
Then a license notice, and then... nothing.
Eventually it got kicked out again, because users were complaining that sun was asserting copyright on empty files. But still.
Admin
/** *Stops the the following comment from not be made not non-uninvisible */
Admin
Because it often (even usually) doesn't make sense. That return value doesn't have meaning outside of the context of the call, so it needn't be -- and in fact shouldn't be -- made to persist.
For instance, take a look at BigInteger; like the boxed types, it is immutable. BigInteger has two functions that do division: BigInteger divide(BigInteger other); BigInteger[] divideAndRemainder(BigInteger other); The second version returns an array where [0] is the quotient and [1] is the remainder.
I'd argue that the following would have been a not-entirely-unreasonable alternative for this API: BigInteger divide(BigInteger other, MutableBigInteger outRemainder) And even if that's not what you want to present to the client, I think it's reasonable to have as a private function behind the scenes.
Now, your proposal: don't use a MutableBigInteger, but put a BigInteger field in some other object and have divide set it.
What object should get it? The one you're calling divide on? So it's going to have a remainderFromTheLastTimeYouCalledDivide field in it? Oh, and now your immutable object isn't, because it has to change that field.
The one that has the call to divide is in? So there should be an CanHoldTheRemandierOfDivision interface with a setTheRemainderOfDivision() function, and divide should take a CanHoldTheRemaniderOfDivision object?
There's no good place for that field.
Admin
I'd love to see the "blame" output for it. Can you imagine what bugfixes have gotten us to this point?
--Joe
Admin
Without knowing the rest of the code you can't say whether the names are suitable or not.
Admin
MutableBoolean: The unspeakable love-child of Erwin Schrödinger and George Boole. You never really know if it's true or false until you call the accessor method.