- Feature Articles
- CodeSOD
- Error'd
- 
                
                    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 like it. Simple, creative, easy to understand. And it even works most of the time.
Admin
rillant!
Admin
Actually, this indicates that the developer knows what he is doing and tries to write the most efficient code possible (the kind of thing a lot of modern software engineers lack). Definitely not WTF.
Admin
ee roblems or ther oders hen hey ry o igure ut hat s oing n n his ode...
Admin
Admin
Admin
Admin
Hah! I actually like his style... He managed, not only make it resiliant to differing first-letter case (googlebot or Googlebot, anyone?), but also save bunch of letters (the 'signatures' as well as the "=== false").
As a previous commenter put it... Absolutely rillant!
Admin
And one more thing: 'pider' is kind of 'q...er' in Russian :(
Admin
For that matter, the PHP online manual page for strpos() even explains why you should use === to check the return value.
Admin
Admin
He he, that's funny.
Still, I'm not sure what surprised me more: a) The "ingenuity" of developer. b) That the function can return "0" AND "FALSE" and that's not the same. c) That "strpos" is not appropriate function for searching substrings inside string.
Admin
Admin
You're fucking joking, right? If you truly believe this then you have no fucking idea and have no right to even compare yourself to software engineers, let alone criticize. How can you possibly put up a shitty, halfwitted string compare saving an entire one character as a paragon of efficiency when you routinely don't bat an eye at stuff that is 100% string and/or XML based, use interpreted scripting languages, javascript, reflection/runtime class interrogation and think its ok to transmit 1000000 bytes to describe a basic screen with minimal functionality.
Admin
Don't you realize that each of those spider names is a Registered Trademark. If they appeared in the source code, David's company would be obliged to pay usage fees!
{or post a disclaimer in the comments}
Admin
Quaker? Or can I buy a vowel?
Admin
Admin
in_array wouldn't work unless he puts the complete UA string in there, which isn't a very good idea.
This surprises me too, since I don't see any indication this is the case.
Admin
So for you the difference is 'z', but for me it is 'awk { $1 }' as I don't have a sig line.
Admin
Stop kidding! ('f...ggot' also suits well).
Admin
Admin
I'm surprised he didn't just do "strpos(' '.$agent, $spider_name)" - it's what I use in a small script on my site (which I use to redirect traffic from my site's old hostname to the new one; search engines get a "301 Moved Permanently" response to make them update their index, while normal clients get a "300 Multiple Choices" to force them to read the page and either report a broken link or update their damn bookmarks), and it works nicely.
Admin
I'm sure glad you don't work with me. We obviously have extremely different views on what makes a "good" developer. Writing inefficient code "most of the time" is not the hallmark of a "good developer."
Admin
everybody can fake an agent string. why not take reverse dns and use it? see: http://livebookmark.net/journal/2007/04/11/sitemaps-in-the-robotstxt-happy-harvesting/
Admin
Actually, there's a pseudo-plausible reason to do this: strpos(blah, "pider") matches both "spider" and "Spider".
Admin
Admin
Admin
I agree with all of you who say that PHP is a poor language. I mean, that's why Facebook, Wikipedia, Yahoo!, Digg, Sourceforge and Flickr are built on it, right?
Admin
What a cute comeback! It's a shame that nobody mentioned PHP was poor, but otherwise it was delightful. Well done.
Admin
If you feel yourself inferior because you are a PHP developer that's not our fault. :)
Admin
Probably it is an human smart as a bot then
Admin
Introducing: piderman baman
Admin
Admin
Really? So in other words, you don't evaluate the trade-offs between clarity and efficiency (where they diverge) on a case-by-case basis and choose the solution that best your overall design goals? You just always choose efficiency without regard to the problem, technology, or environment at hand?
I'm glad I don't work with you!
Admin
well that's like saying a million flies can't be wrong, manure must be tasty!
Admin
We're all glad we don't work with each other, after all who wants to work with people who spend all day surfing on websites?
But what your problem is with the definition of "efficiency". The code in this article should not be considered efficient by any definition. Because only code that does the job properly should be ranked on a scale of efficiency and this doesn't. It shouldn't even be considered for efficiency.
Admin
We're all glad we don't work with each other, after all who wants to work with people who spend all day surfing on websites?
But what your problem is with the definition of "efficiency". The code in this article should not be considered efficient by any definition. Because only code that does the job properly should be ranked on a scale of efficiency and this doesn't. It shouldn't even be considered for efficiency.
Admin
hat's enious, hat s!
Admin
Admin
One is reminded of Michael Jackson's (no, not THAT one) rules of code optimization:
Rule #1 - Don't do it.
Rule #2 (for experts only) - Don't do it yet.
Admin
Well, your solution requires a temporary string to be spawned and could cost you some cycles. Stop being lazy and just do what TFM tells you to: if (strpos($needle,$haystack) === true) {}
But yeah, I've got to admit the original code was clever; but it is simply wrong from a clarity standpoint.
The Real WTF(tm) is a library function returning int or bool. It should rather behave like C's strpos, Java's indexOf, Python's find(); they all return -1 if the haystack does not contain the needle. It makes more sense that way: you're testing the position of a substring, which is a number. A boolean would be expected if you're testing if string contains substring, regardless of position.
Admin
Where is the WTF? It's not the most visually appealing, but it would clearly work and is not too roundabout.
Admin
In nearly all applications, nearly all of the code has absolutely no reason to be efficient because it will be executed so rarely that it does not matter at all. Yes, even in embedded systems. It needs to be correct and maintainable first. Then, and only then does efficiency enter the picture, and if it runs too slow or uses to much memory, you do some profiling to see where the code needs to be more efficient.
Until you understand that, you're not a software engineer, you're not a developer, you're a wannabe cowboy coder.
Admin
You mean buttword.
Admin
that's a poorly designed API. if a call returns an integer most of the time, why not do like nearly every other language and have it return -1 if the string is not found.
Admin
Staggers me the amount of PHP developers who never heard of stristr(), including all commenters here, it seems.
Admin
I just did this on a recent project, to find the status of account applications. Their database had both "Approved" and "approved," "declined" and "Declined," etc.
Why would I not simply omit the first letter? And for those who are somehow claiming clarity, is there anyone who didn't instantly understand the code?
Admin
It eludes me why they couldn't make strpos() return -1 in case the "needle" was not found.
Admin
It could be worse in perl you would probably pass in a hash of hashes containing any number of needles and haystacks and you get back either "FALSE", the position of the needle in the haystack, a hash containing the index of which haystack the needle was in and for some reason the name of the implentors cat or FILE_NOT_FOUND.
And of course the behaviour would be dependant on random symbols in global scope.
Admin
because -1 is perfectly legal argument, for example, start or length of a substring (php.net/substr) therefore to prevent people from shooting their leg and not realizing it by directly using its return value as a parameter to another function, ie substr($s, 0, strpos($s, '%')) will return 'a' for 'a%b', but 'ab' for 'abc' having strpos return false will issue a warning, under normal circumstances
do not criticize something you haven't throughoutly researched