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.

5,115 thoughts on “Stringly Typed Booleans

  1. The Criminal Investigation Department (CID) of police has recently forecasted a report based on information provided by some arrested agents. As it turns out, around Tk 260 crore was transacted through 1xbet in a year, while Tk 245 crore was traded through Bet365, Tk 230 crore through Mostbet, Tk 140 crore through Bet Winner and Tk 133 crore through Betbuzz, according to the report. A dedicated promo store, a variety of payment methods, excellent betting markets, and high-quality livestreaming are a few of the features that have cemented Melbet among the top 10 betting sites in Bangladesh. Some of its flagship promotions include 10% higher profits for successful accumulator bets, up to 5% cashbacks on T20 match bets, and Champion Bets (where you win irrespective of the result). Cricket betting is one of the most popular betting options among punters in Bangladesh. Recently, this sport has become a real trend worldwide, attracting fans. The official Pin Up website offers online cricket betting options for popular leagues: IPL, League of Pakistan, BPL, and others.
    https://allods.my.games/forum/index.php?page=User&userID=219846
    In the past, sportsbooks did not always offer sports betting apps for users in every state they operated in or have respective ones available for iOS and Android devices. Some brands even offered state-specific apps. But, it has now become common practice for sportsbooks to make widely available betting apps.  Leonbets comes with a top-quality Bangladesh betting app Android where you can access numerous football betting markets with quite fair odds. In addition, the platform has professional customer support with a live chat feature. Claiming a bonus is a great way to get extra free money so that you can place more and bigger bets, for the chance to win large payouts. It’s super important to check the T&Cs very thoroughly before you claim any offers, though, because a lot of online betting sites apply maximum win limits to promotions like free bets. This means that you’ll only be able to win a certain amount, and even if you exceed that, you won’t get paid the extra.

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>