- 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
- 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
comment* comment = (comment*)NULL;
Admin
This WTF is indeed a gem
Admin
Well, that explains the pile of almost-as-bad-as-MS-Windows-2 that my father got with his @%^trad-Schneider PC1640.
Admin
That's the real issue with most WTFs.. if you actually fix them, they think you're insane and fire you.
Admin
She was wrong. Boolean is an object. Original developers were using object oriented principles. Whereas she didn't. Very unprincipled.
Admin
And that's where you're wrong: she is thinking outside the box. A skill that only talented coders have
Admin
These puns are getting ever more ternible!
Admin
"..the unit tests were exemplary." WTF!!
Admin
The tests were probably written by the single sane developer on the team before they were deemed unproductive and let go, because none of their code did anything relevant once deployed to production.
Because as we all know, "lines of code that are executed in production" is a great metric by which to measure productivity.
Admin
Quite the opposite, she elected to use primitives, which need to be boxed into reference types, as needed. She's literally thinking inside the box.
Admin
Who needs thinking inside or outside of the box when you have auto(un)boxing? Of course, that would put all those Youtubers filming them unpacking stuff out of business...
Admin
You're not saying that .NET is better than JVM, are you? I hope not!!!
Admin
Boxing booleans into Booleans shouldn't ever result in heap allocations. The JLS requires that if a==b for boolean values, then boxing a and b must return identical objects. Likewise for int values between -128 and 127 and for char values between 0 and 127. So I wouldn't expect that all of the boolean fixes that Naomi made to affect the number of heap allocations, but all of the int fixes that she made very likely would do so.
https://docs.oracle.com/javase/specs/jls/se8/html/jls-5.html#jls-5.1.7
Admin
It has been a while since I last worked with java, but I'm pretty sure if you use new Boolean() instead of Boolean.valueOf(), you create a new object and those optimizations do not apply. The submitted code is clearly using new Boolean()
Admin
Doing all that refactoring (15k lines) as one commit is the real WTF.
Admin
Derp you're right.
Admin
Just in case anyone missed the implicit reference about XML and regex,
https://stackoverflow.com/questions/1732348/regex-match-open-tags-except-xhtml-self-contained-tags
Admin
I am primarily a Java programmer with very little experience in .net. So no claims like that here...
Admin
Yes, this would be a no-brainer. In Java, any call with the /new/ operator will always create a new object instance (and for that matter, execute the constructor method right after /new/). Therefore, the expression /new Boolean(false) = new Boolean(False)/ will /always/ return false. This may come as a surprise to non-Java coders. The proper way of doing what you probably intended is /new Boolean(false).equals(new Boolean(false))/. That will /always/ return true.
Autoboxing any primitive type /may/ in practice result in a new object, but this is by all means not mandatory for the JVM and not-to-be-relied-on behaviour.
Addendum 2019-09-04 11:51: (not sure what happened to my equals operator, of course where it says '=' above, it should say '=='. As written, it would obviously not even compile)
Admin
Since this is Java, I don't think it's any relationship to the crappy old GUI named Gem either.
Unless for some godforsaken reason someone decided to re-implement the whole C codebase in Java which, well, it's enterprisey so we can't rule that out entirely. But let's hope not.
Admin
Not forgetting that all boxed primitive types are (normally) immutable, so you should never need to clone one, unless you specifically want
==
to fail. In other words, you should have been able to just write:Admin
@Jake a 15kloc commit may seem insane, but if that commit is the result of automated refactoring, it seems rather reasonable to not split it.
Admin
Instead of 15,000 one-line commits.
Admin
You are all missing the big wft. Java Boolean is immutable(Can't change value), so there is no need to create a copy at all. A simple this.isSided = gemGeometryEntryPoint.isSided would be the perfect solution.
Still a wft to use Boolean everywhere. I only ever use a Boolean when mapping a nullable database field to java, but there may be other use cases for a tristate boolean.
Admin
About that...
http://nestedvm.ibex.org
Admin
TRWTF is obviously boxing itself. Honorable mention goes to 'wft'. ;)
Admin
@Harris: Aieeeeee. Sincerely yours.
Admin
The correct way would be to use Boolean.valueOf(...) which will always return one of Boolean.TRUE or Boolean.FALSE, which can be compared with ==, but given the described quality of the code base, looks like knowing that would be too much to expecte from the developers there.
Admin
The problem with committing a 15KLOC code change: The unit tests may be exemplary, but are they complete? When the software has a long history after the unit tests were first written, there would be changes made to handle quirks in the data or company procedures, and I would not trust that every programmer making those changes had updated the unit tests correctly, or even documented what the change was for. (The test passing does not always mean the code is AOK; sometimes the test doesn't work.)
In fact, I would expect that many issues would be discovered after the big code change went into use. Breaking the changes up into several chunks would simplify tracking down those quirks.
Admin
Since I've seen a couple comments about the "15,000 line commit"... there may be some exaggeration for comedic effect going on in this article. It's been a few years, but I feel like it was slightly less than 3k in actuality, and it wasn't a single commit. I was a lot more careful than the article makes it sound like, and worked closely with our tester (who, IIRC, appreciated having some meaningful work for a change - yeah, that should tell you something).
On the other hand, now that I'm not a green-behind-the-ears intern who feels she has to prove herself? I don't think I'd have done anything like that. I guess that's what they call hindsight. Still, they kept inviting me back, and the only thing I heard about "Gem" was that it was more stable than it had been (I got myself subscribed to the bug tracker), so I guess I did something right.
Admin
the real wtf is "greatly improved performance", not to mention "unit tests were exemplary"