- 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
REALLY?
Admin
Er, do compiler bugs really count as features? After all, actually utilizing them is a fast-track to non-portability and upgrade havok.
Admin
It's not. It's ASP.Net/C#. The property is always there, and it's always True or False.
Admin
Not unless you do not know how the OR logical operator works, yes, really.
Admin
err?
!boolVal == boolean not
~boolVal == binary negation
I don't think you are correct.
-dave-
Admin
<FONT face=Tahoma size=2>This is most likely C#, since the Page.IsPostBack method checks if the ASP.NET page has been posted back, and doesn't need some resource expensive stuff to be evaluated again. It could ofcourse also be Javascript [:P]</FONT>
Admin
for eaxmple in when you try it in Netscape4 you have no getElementById so it is false for both ... or rather it would be except for the way the && operator short-circuits:
if the first part equates to false then the result is false
otherwise the result is what the second part equates to
take the line
var isIE=document.getElementById&&document.all;
in IE6 the first part is not false so isIE = document.all, which is an object in IE6; in firefox the first part is not false so isIE = document.all, which is undefined in firefox.
So if you
alert(isIE)
then in IE6 you get "[object]" and in Firefox you get "undefined".
And so when you try it in Netscape4 you get
alert(isIE) -> "undefined"
alert(isNotIE) -> "undefined"
Admin
I've seen this type of code before, and more often than not it is the result of an error or oversight after a change request, or maintenance fix.
Suppose, for example, that the original code was:
if (Page.isPostBack == true) {
//
}
Then the coder realized that there was a bug in the way the it worked, and that the logic in the condition needed to be reversed. Of course, he or she could have easily done:
if ( Page.isPostBack == false ) {
//
}
or...
if (!Page.isPostBack) {
//
}
But he or she might have just negated arbitrarily any part of the expression, tested and saw that it worked, and never thought anything else of it. Resulting in:
if (!Page.isPostBack == true) {
//
}
Like I said, I've seen this before. I call it the "spaghetti cook" approach to debugging: keep throwing noodles at the wall; when one sticks, its done. :)
-dZ.
Admin
I've seen code like this a lot, and the reason is always the same: Coding standards that assume the programmers are idiots.
Say a programmer writes this:
Now he submits this code for review. The people doing the reviewing aren't looking for the code's correctness, they're looking to see that it adheres to the organization's coding standard. And a surprising amount of coding standards contain something to the effect of "all if statements will specify the test they are performing, implied tests for a statement's truth are not allowed".
So our programmer gets back this code because all his if statements don't have an explicit test for truth. So what does he do? Why, it's simple, he just adds " == true" to every if statement. It doesn't change the meaning of any of them, and it gets it past the stupid standards checkers.
Sad, but true.
Admin
I bet the compiler was perfectly OK, and the bug was that somebool had type int, and the value was neither 0 (for false) nor 1 (for true). Comparing that value against true for equality resulted in taking the else branch.
Never compare against true. In C, don't even #define your version of true; you won't need it.
Admin
That's a completely different situation. The problem with the "Have you stopped beating your wife" question is because the question has different meanings in English and Moronese. If you've never beat your wife, the correct answer to the question in English is "No." However, to someone understanding the question in Moronese, this sounds like you've said that you're still beating your wife.
Similar to the "quus" vs. "plus" problem.