- 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
Third
Admin
Frist
Admin
Seen in production code, many years ago:
if ( some_condition ) (some_other_condition) ? a = b : 0; else some_other_action();
Too lazy to add braces round the inner if()?
Admin
This is a point where Powershell got it right : $a = if ($condition) { $trueValue } else { $falseValue }
Admin
Most likely just a merge conflict solved incorrectly by including both the before and the after...
Admin
I have problems understanding that snippet...
Admin
That would make sense....
If this was C# rather than C++
Admin
I bet it is lua
Admin
The main statement of the if() is a ternary whose branches are an assignment (true) or just zero (false). Someone could have put braces around a real else-less if(), but I guess that would have been too much work.
And I would dearly love an explanation of how to put properly-formatted blocks of code in this [REDACTED] forum thing, wossname, No Deb B.
Admin
I actually prefer the Python syntax: a if condition else b
Admin
Testing code blocks, will this be code...
Admin
From my test, backticks seem to work.
Admin
Is that a loose check for null or an exact check?
Admin
I guess that commit message is better than "reticulating splines"
Admin
And every other language family without the (needless, imho) distinction between statements and expressions; Lisp, Scheme, Haskell, *ml, ...
Admin
Seems like WIP (world in progress) ...
Admin
I don't think I'll ever get the hang of that (or likewise Perl's "do if" and "do unless"). To me it sounds like a bad manager: "Do this! ... Oh wait, I meant only if (whatever) ..."
It's not about execution order (I know this can be vastly different from what's written in the source code in many cases), but more about logical order how I think of things. The condition is first, and everything afterwards depends on it. So why would I first want to read one branch that may or may not be taken before I see whether it will be taken?
Admin
Have you ever tried to debug somebody's nest trinary statements...
Admin
@TheCPUWizard: If the author was checking for builder!=null, that would be quite reasonable, but the author was checking for builder.worldId!=null etc. and will still throw an NPE (or equivalent in whatever language this is) if builder==null.
Admin
It's a bit rubbish anyway, you've got two different objects with the same stuff in them and you're assigning the properties over one by one. You'd stop and think: refactoring possible here?
Admin
Begin the snippet with (PRE)(CODE) and end it with (/CODE)(/PRE) where "(" is "<" and ")" is ">"
Pre and Code are HTML tags that will disappear at display time (View Page Source is your friend)
Admin
Yes, one could go back to grandpa (Algol 60) where you didn't have ?:, but you did have 'if', so:
a := if b then c else d;
Which was perfectly valid. This appears to be OK in other languages in current use as well as demonstrated by some of the comments.
Everything old is new again.
Admin
One night I was up late programming, and I wrote something alone these lines.
if (a < b == true) return true; else return false;
I realized that I could take out the if statement entirely and just say:
return a < b == true;
A few minutes later I realized I must be too tired and went to sleep.
Admin
`
Admin
Python does this pretty well I think. It gets a bit unruly if you start chaining ternary operators together; though I think that's true in all languages
worldid = builder.worldid or 'some_other_value'
worldid = builder.worldid if builder else 'some_other_value'
Admin
No - I see this all the time in the codebase I work on.
Comatose devs putting in changes without looking at the code around it, below or after, or the code calling or the code the change calls.
Lot's of true WTFs in this codebase because enterprise devs don't take the time to read the existing code, much less try to make it better. Over time the cruft just keeps adding up.
I am a robot - I am a leaf on the wind, watch me soar.
Admin
"No - I see this all the time in the codebase I work on."
"Lot's of true WTFs in this codebase because enterprise devs don't take the time to read the existing code:"
Wait... aren't you an enterprise dev as well then...? :P
Admin
It's called 'NoseBBleed', silly.
Admin
The == operator might make sense in languages with a === operator, if we'd ignore the second code block.
Let me guess -- the ternary operator is overloaded with some world details constructors?
Admin
In "other languges" like c .... expression values have no sensible justification. The feature just fell out of the parser as a side effect of the desire to have single-line multiple assignments:
a=b=c=d=0
Which, as everyone knows, is a critical language feature.
Admin
This reminds me of some old C++ code that had this pattern everywhere: bool conditional = !!pointer; At first it seems ridiculous, but actually served a purpose: quickly casting a pointer value (or null) to a boolean value in a consistent manner, to be used elsewhere in the codebase (which in some cases relied on particular bits being set for proper type conversion).
Admin
The double-not is not needed. A non-null pointer will convert to a true bool value, and a null pointer will convert to a false bool value, which is about as consistent as one could hope for.
Admin
Just for the record, it can get pretty ugly in Python too:
Admin
Original submitter here. Just an FYI - I guess the code dude read the submission a little bit wrong. The second four lines were the original version, the first four lines were the final version. They didn't appear together; it was changed from one to the other.
Admin
Especially fun to do with PHP where they have it backwards.
Admin
I do that currently, in Perl, the "do if" thing.
I find it makes sense in one case at least: "log a message if log is enable" the important thing is to log that messaged, the if part is secondary. I find it more readable this way.
And eventually, it is consistent with prototyping and debugging: at file there are a lot of messages that are logged, when the code stabilize, the option to enable/disable logging is added, so is the if statement at the end of the line.
Admin
OK, that's one case I can somewhat understand. OTOH, the common "die unless" idiom seems even stranger this way. Dying is not the important thing here, it's the exceptional case.
Admin
Well, you did realize. Many programmers (according to sites like this one) apparently never realize it or even don't think there's anything wrong with it.
Admin
That's a ternary.
Admin
Yep. I do the same. It adn also be easier for some other (non-log) statements to be done in this way, but the benefit of that quickly degrade as the do part increases beyond a certain (poorly defined) length of code.
For instance
a = get_val(this) unless (defined(a));
makes sense and is easy to understand whereas
a = (estremely long line of gibberish----------------------------------------------------------------------------------------) unless (defined(a))
does not necessarily make sense....
Admin
I'm already doubtful of your first example. E.g., if I was trying to find out where some unset/default value comes from, I'd read across this line and think "ah, a is assigned here, so I can't be that" ... (Of course, with a single line, you'd notice, but imagine a lot of assignments, some with if/unless, some not.) I find it easier if a line starting with "a = " means there's definitely an assignment of a (if the line is reached, of course; that's why we use indentation to easily see conditionals and loops).
For a similar reason, I prefer ternaries in a number of cases, i.e. with "a = c ? t : e;", I see immediately that a is assigned something, whereas with "if c then a = c; else a = e;" I have to mentally merge two cases to convince me that that's the case.
Admin
I regularly refactor such statements in our code :(
And new ones keeps getting added.
Often in the form of return variable > 0 ? true : false; //Or some other condition of similar simplicity.
I hope I never do understand the reasoning behind writing such statements.
Admin
Genuinely confused. XML? HTML? VRML? UML? YAML? Markup languages and (modeling languages) don't really have statements or expressions, do they?
Admin
I think the "reasoning" is that some people seem to make a mental difference between Boolean values and comparisons, roughly speaking. So they're like, "variable > 0" can't be a value that you can return, it's just a comparison, so I must make it into a value. Or, reading a bool variable gives a value, so you can't use it as an if-condition, you need a comparison there.
Admin
Terrible sorry. Imagine I said "programming" there; *ml meaning metalanguage, i.e. OCaml, SML, Alice, etc. Aside: if your language doesn't have statements or expressions, there is no distinction to make, so my point would still stand.
Admin
If this is JavaScript, then the code does make sense (the the extent that JavaScript code makes since)
In JS
null == undefined
, they may have wanted to ensure that undefineds are "converted" to nulls so that strict equality could be used to it later.Admin
i have co worker who does (c#) a == true ? true: a all the time. this is the simple one i keep cleaning up code behind him. he does condition ? true : some toehr expression ? true : somethingelse; for every boolean operation.
Admin
The one use of the double-not is to suppress a warning generated by (some non-zero number of) compilers that you are doing an implied comparison and so the assignment will not be as fast as you think. The alternative is to write a not-equal-zero test.
Admin
First saw a construct like that in PERL --as has been pointed out, that language feature far pre-dates PowerSnail.
Admin
I actually ran into a issue where you had to write something simular to get it to work in debug mode. The statment "return basket;" caused a NullReferenceException in debug mode but not in release mode. It turned out that the developer of the e-commerce library used had added a debug assert in an implicit cast oparator which was triggered in debug. As a result the above statement had to be written "return basket == null ? null : basket;". One of the few places where a comment was warranted so noone cleand up the code and thus reintroduced the bug.