Stringly Typed Booleans

I’m getting rather hacked off seeing boolean properties typed as strings. Stringly typed is a phrase I learnt off a post from the excellent Coding Horror blog and it describes a phenomena whereby properties that are of a specific type, e.g. Boolean, Date, int, are stored needlessly as strings.

I’m working on a website that communicates with a money laundering service to check whether an individual is “bad” or not. Individuals can pass the test, but importantly it is possible to pass the test with some warning flags raised. If any of the warning flags are raised then an email should be sent off to compliance for them to do…whatever it is they do. Fair enough right?

The warning flags are obviously booleans. There was either a warning raised or there wasn’t – there are no two ways about it (no pun intended). In the serialized response, the warning flags are encoded as “Yes” or “No”…which is understandable. Now, upon receiving the response, it is parsed and turned into an internal representation. This is where things get really weird. The programmer that coded the object that stores the response from the service has decided to encode the warnings as strings, initialised to “”. Which is totally fucking bonkers.

Why?

Well, now our boolean warnings aren’t really booleans – they have WAY more than two possible values and the meaning of these values is subjective. One may consider “”, null, “No” as false, but could conceivably also consider “false” or “0″. We get the same sort of problem with true – “Yes”, “1″, “true” and then we get a whole load of unknown values which is every other possible string in the world. Which might be considered to be true.

So how the hell can any number of programmers work on this piece of code without introducing errors because of differing definitions of truthy and falsey values? Well, they can’t. To illustrate the problem further, even loosely typed languages differ in their boolean coercion, for example JavaScript and PHP:

<script>
if("0") alert('Opposite day!');
</script>

<?php
if("0") echo 'Opposite day!';
?>

JavaScript considers “0″ true but PHP considers it false. Personally I think JavaScript is “right” here, but as I said before, it is totally subjective.

The icing on the cake is of course the extra code you have to write to check the truthy or falsey string values. Something along the lines of “if x is not null and not empty and not the word No then it is probably true…probably”, which would otherwise have been coded as “if x then true” if x was a boolean – which is orders of magnitude shorter.

Of course, there are some bat shit crazy strongly typed languages that allow you to assign null to a Boolean, but that is a different story altogether.

9,843 thoughts on “Stringly Typed Booleans

  1. This design is wicked! You most certainly know how to keep a reader entertained. Between your wit and your videos, I was almost moved to start my own blog (well, almost…HaHa!) Wonderful job. I really loved what you had to say, and more than that, how you presented it. Too cool!

  2. Матовое покрытие снижает нагрев кровли. Летом в мансарде заметно прохладнее чем у соседа с глянцевой металлочерепицей. Разница ощутимая в жаркие летние дни. металлочерепица для крыши частного дома

  3. Hey very cool web site!! Man .. Excellent .. Amazing .. I’ll bookmark your blog and take the feeds also?I am happy to find a lot of useful info here in the post, we need develop more techniques in this regard, thanks for sharing. . . . . .

  4. hey@casumo We are experts in the diagonis, treatment and care of dental problems. Most online casinos offer a wide range of pokies, the player must place an additional bet equal to their original bet. Overall, players can also deposit via Visa Gift Cards if they can be used for international or online purchases. Value display and tallying are transparent throughout the round. Each new symbol that locks contributes to the visible total, and the reset of the respin counter is clearly marked by a sound cue and animation. Some Hold & Win frameworks incorporate labeled tiles (for example, multiplier or collector tiles) that alter the value of other tiles or aggregate totals; where available, Fire Temple Hold & Win explains these modifiers in the information panel. If no modifiers are present, the feature proceeds in a straightforward additive manner where the sum of locked values is awarded at the end of the round.
    https://drink3water.com/2817/rabbit-win-casino-review-for-uk-players/
    Astronaut crash game is a fast-paced online betting game gaining traction among Indian players. With its simple mechanics, even beginners can quickly join the action. Thousands of users enjoy high multipliers of up to 10,000x and quick rounds that keep the thrill alive. Remember, the game is based on chance — play responsibly and understand that luck plays a key role. The Return to Player (RTP) in Astronaut typically hovers around 95%–96%, which is comparable to online slots. But unlike slots, the outcome in crash games depends on player action. This RTP represents the long-term average return, not a per-round guarantee. Trump temper on H-1B visas is forcing Indians to do these things to stay put in US Seasoned players pursue big wins. They might test the astronaut game demo or register with a lucky alias via the astronaut game login. Its unique 3 pit stop betting system hooks you. Whether you’re on the astronaut game app or diving into the full experience on PC, the stunning space visuals make every round irresistible.

  5. One thing I’d really like to reply to is that fat reduction plan fast may be accomplished by the right diet and exercise. Someone’s size not just affects appearance, but also the actual quality of life. Self-esteem, despression symptoms, health risks, as well as physical abilities are affected in an increase in weight. It is possible to just make everything right whilst still having a gain. In such a circumstance, a medical problem may be the offender. While an excessive amount of food instead of enough exercise are usually at fault, common health concerns and widely used prescriptions can certainly greatly add to size. Thanks a bunch for your post in this article.

Leave a Reply

Your email address will not be published. Required fields are marked *

You may use these HTML tags and attributes: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>