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.

8,807 thoughts on “Stringly Typed Booleans

  1. I have realized some new items from your web page about computer systems. Another thing I have always considered is that computer systems have become an item that each household must have for many people reasons. They provide convenient ways to organize homes, pay bills, go shopping, study, hear music and in some cases watch television shows. An innovative method to complete many of these tasks is by using a computer. These pc’s are portable ones, small, robust and mobile.

  2. That is really attention-grabbing, You are an overly skilled blogger. I have joined your rss feed and look forward to in search of more of your fantastic post. Additionally, I have shared your site in my social networks!

  3. Terrific work! This is the type of information that should be shared around the web. Shame on the search engines for not positioning this post higher! Come on over and visit my web site . Thanks =)

  4. Unquestionably believe that which you said. Your favorite justification appeared to be on the internet the simplest thing to be aware of. I say to you, I definitely get irked while people think about worries that they just do not know about. You managed to hit the nail upon the top and also defined out the whole thing without having side effect , people can take a signal. Will likely be back to get more. Thanks

  5. I do enjoy the manner in which you have framed this specific problem plus it does indeed give me some fodder for thought. However, because of everything that I have seen, I simply wish when other responses stack on that people today remain on issue and not embark on a tirade regarding the news of the day. Yet, thank you for this outstanding point and although I do not necessarily concur with it in totality, I regard the standpoint.

  6. Including productive portion are a real meditation of 1’s own city’s bright and you may diverse area. To search Chișinău, you can trust an efficient and you will practical transport system. Whether or not their’d instead discuss the urban area by foot or approach next that have enjoyable having public transit, Chișinău offers lots of options to suit your needs. Is actually an online condition Fortunate Females’s Attraction Luxury, and play for fun instead of having fun with anything. It’s going back to a general change in opportunity, and you will Novomatic’s Pleased Girls’s Attention Luxury position can make it goes. Zoals eerder in deze Sugar Twist-review gesuggereerd, heeft deze gokkast een snoepthema. Het haalt ook het grootste deel van zijn esthetische kwaliteit rechtstreeks uit Sugar Rush. De achtergrond toont een roze fantasiewereld van met snoep bedekte heuvels, met snoepautomaatmachines aan beide zijden van de rollen. Een van deze apparaten, direct links van het rooster, fungeert als de verzamelaar voor tumble-winsten.
    https://maximlandbase.com/divine-fortune-verantwoord-review-van-de-netent-slot-voor-nederlandse-spelers/
    Sinds online bingo populair werd, Pragmatic Play zijn onlangs begonnen om te laten zien dat hun live casino games zijn net zo goed. Het casino heeft het recht om deze te wijzigen op elk gewenst moment, evenals de winsten als gevolg van gratis spins. Het is echter belangrijk om de voorwaarden van de bonus te lezen en te begrijpen voordat je ermee akkoord gaat, zijn onderworpen aan inzetvereisten. Om het spelen zo leuk en verantwoord mogelijk te houden maken wij vanuit Bingoal gebruik van een aantal interventies, mocht dat nodig zijn. Deze interventies zijn gericht op het beschermen van de speler en hebben betrekking op het inzicht geven in speelgedrag, het adviseren en mogelijk aanpassen van speellimieten, tijdelijke of permanente uitsluiting en verwijzing naar deskundige zorginstanties. Wij vinden het belangrijk om zo goed mogelijk te zorgen voor onze spelers.

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>