- 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 am guessing this is possibly used in a password enforcement security rule? My best guess as to why you would compare backwards.
Or for Date/Time rendering that are not in the form of YYYYMMDD.
Captcha: quake - head shot!
Admin
Good point and I knew that. I was just replacing the very inefficient WTF code.
<rant style="grumpy old developer">I mean what if I gave you two strings that happen to be 1MB in size? Yes a processor can do that pretty quickly but you're wasting memory and cpu cycles for pointless work. I've been writing code for 23 years now (started at 12) and I think developers just continue to get worse. </rant>
Admin
("ThisContainsOneTwoThree", "OneTwoThree") returns true. The second string has to be 11 characters long (a phone number perhaps?). I'm not sure what the difference in backwards is supposed to make. I'd rewrite it as:
This also eliminates the IndexOutOfBoundsException.
Admin
Ohh.. this was coded on Valentine's day. How sad.
Admin
The Java language uses fixed-width Unicode characters. It allows conversions using FileReader/FileWriter and String objects. However, every in-memory Char is Unicode (UCS2 or 16-bit as of Java 1.4).
So, one never cares about the character set in a java.lang.String object. The exception is JNI native code, which must marshall C/C++ strings to Unicode (See the Java Native Interface).
Admin
Nah, the function name is much more appropriate without the 'K'. You know, just to make sure the initial warning in the function name sinks in when you run across it somewhere else in the code.
Admin
Sir, I believe you might be overestimating the programmers we are dealing with here. I really wouldn't put it past someone to write a BIDI system where the strings are reversed in their memory representation. It still, in no way, qualifies as "The Right Thing To Do(tm)". This code never qualifies for any award other than a frontpage post to this site.
Admin
Admin
Old is definately a relative term. Maturity is a logarithmic function. Anyone who has a child knows that a newborn is infinately less mature than a three-year-old, which is drastically different than a five-year-old, which is different from a twelve-year-old. I think that same rule applies to technology, including programming languages. There is a point when the aging starts to level out, and like children, is dependent on itself and its creators.
The vast majority of Java that I've had to support that is 5+ years old was either written by people who have never programmed before (thank you dot com era), or programmers who used other older non object-oriented languages. The old COBOL programmers, who may have been excellent programmers, didn't always adapt to Java's OO methodology, and thus wrote code that was not easy to maintain and thus needing of rewriting after only a few short years of service. (Please don't flame me, accusing me of COBOL biggetry. I am just stating that COBOL programmers and JAVA programmers tend to see things very differently) As for the people who had never programmed before, that code was typically impossible to understand let alone maintain.
So, with the mix of unaccustomed developers and the infancy of the language, I believe it is perfectly legitimate to consider 5+ year-old Java code old, with "old" being synonomous with "outdated".
Admin
I love variables with articles in their names. Not just any StringToCompareTo, this is THEStringToCompareTo. I should stop using i in for loops in favor of "anInteger"
Admin
Yet.
Admin
I believe the word you are looking for is "rubbish" or "broken". In your case, you were re-writing young code because it was wrong, broken, or downright unmaintainable: you were not re-writing it because it was merely "old".
What I've been trying to get at is that re-writing something just because it is "old" and doesn't conform to your latest idea of what's best practice (Read: Doesn't use the latest whizz-bang framework features), even if the code you are re-writing works, is a really bad idea. Yet it seems a lot of developers spend quite a bit of time doing just that. I wonder how many developer man hours are wasted re-factoring perfectly good code because someone didn't like the look of it?
Admin
Old code for me means more than 20 or 30 years old. For me old means:
... the company that developed the code originally been bought, gone out of business, been resurrected, and declared Chapter 7 and 11 at various times
...and the industry that developed it no longer exists, except as a legacy support
...the language is at least 3 ANSI/ECMA revisions behind
...the compilers no longer exist for the language you are using
...at least some of the developers of the code have retired
...and at least is dead, of old age.
Now that is old code. Java! Pffft!
Admin
It's bad style to end your parameters with a preposition.
Admin
The comments here always contains more WTFage than the submission.
False If the strings are equal. True if (up to) the last eleven characters of the From string, trimmed of leading or trailing whitespace, match the trimmed To string.
a) there's no need to reverse the To string. b) There are better ways to accomplish the whole thing.
Admin
"The comments here always contains more WTFage than the submission. "
Including my own, of course. No one is immune to the powers of this site.
Ignore 3a.
Admin
String theStringToCompareFromDummy String theStringToCompareToYouIdiot
-Harrow.
Admin
When you're holding a hammer, everything looks like a nail.
Admin
Except for its impact on global warming, that would be equivalent to
(Strings are immutable in Java). If you want someString.trim() to have some useful effect, you must assign its return value to something, as in
Admin
I think that this is an excellent example of the kind of functional description, that should have been contained in the comments at the start of the function.
Admin
Looks like his wistful musing came true, more's the pity:
http://www.netcobol.com/products/windows/netcobol.html
I would ask "why?", but I don't think I'd like the answer...
Admin
Not too important, but nobody mentioned the twisted parameters in the comment.
The superLongVariableNames are, of course, a WTF.
It could have been a comparision of something like phone-number, where "from" might contain an area code 030/789 505 123 compared to 789 505 123 - but it's returning false for exact match.
Trimming the substring, not substringing the trimmed string, seems to be a hint for a prefix which might or might not be divided by a space.
Perhaps "Mon 2007/09/25" vs. "2007/09/25"?
btw.: 14.2.2002 was a thursday.
Admin
Obviously so it goes up to 11.
Admin
Maybe it was written in 1902
Admin
Of course not. God uses Lisp.
Admin
Admin
I'm not 100% on java, but wouldn't 0-11 return 12 characters? Just right for an 8.3 filename..
Admin
I think the author is reversing the strings because he wants to find end-point the LAST match (and he hasn't learnt about lastIndexOf). Of course it is dangerous to try reading the mind of an idiot.
Admin
No, the second index is exclusive.
Admin
Or madness0.
And the Lord could not count grains of sand with a 32-bit word. Who knows where we would go to if Lisp weren’t what he preferred?
Admin
No. It's a little strange, but the string you get back does not include the character in position 11. I was once advised to think of it like so: the first index is the first character you want, while the second is the first character you don't want. I'm not sure why that decision was made, but we're pretty much stuck with it at this point.
Admin
Good one. Me thinks it is a method to compare a phone number without country and area codes.
Admin
Admin
Does not make sense: a) It's 11 characters, as mentioned before. b) Stripping off something could be a path, but you weren't forced to use all characters, you could use 6.2 (like foobar.js) and would get parts of the path that way.
Admin
This is something I absolutely agree with. Don't end your parameter names or sentences with a preposition unless you absolutely have to!
Captcha: xevious (I had a hard time trying to type this in.)
Admin
Admin
No, you should use "anIntegerThatIAmUsingAsALoopCounterInThisFunctionWhichMayOrMayNotBeUsedElseware" after all, you don't want ambiguous variable names!
Admin
Give the author of that code a break. I myself have written pages of code only to replace them a week later with one line doing exactly the same.
Still it's a funny piece of code there. hehe
Admin
Hardware. Software. Elseware.
Admin
ah ha... it was you wasn't it!!!
Admin
ah ha... it was you wasn't it!!!