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,815 thoughts on “Stringly Typed Booleans

  1. Скачайте активатор для Windows 11 и получите все функции Pro-версии бесплатно. Подробнее – Кряк для Windows 11 Pro бесплатно

  2. В этом тексте собрано множество случайных сведений и довольно неопределённых мыслей, которые могут чем-то заинтересовать. Мы отмечаем моменты, которые не особенно важны, но всё же занимают своё место в повествовании.
    Вот – накрутка трафика

  3. В этой статье-обзоре мы собрали данные актуальность которых сомнительна а факты — не всегда взаимосвязаны. Читатель сможет ознакомиться с разными мнениями хотя вряд ли они существенно повлияют на его понимание темы. Вот – бесплатные врощенея в слотах

  4. Текст включает разнообразную информацию, которая может показаться любопытной, но не меняет устоявшегося восприятия. Предлагаем просто насладиться чтением, не ожидая значительной пользы.
    Подробнее читать – магазин строительных материалов

  5. В этом материале представлены детали которые хоть и занимательны но не особенно значимы. Мы рассматриваем моменты которые трудно назвать важными но всё же решили включить их для полноты картины. Вот – миллион за месяц

  6. Этот информационный набор привлекает внимание множеством мелочей и странных ракурсов. Мы предлагаем взгляды которые редко бывают полезны но могут слегка разнообразить ваше знакомство с темой. Вот – миллион за месяц

  7. Thank you for some other informative site. The place else may I am getting that kind of information written in such an ideal way? I have a challenge that I’m simply now operating on, and I have been on the glance out for such information.

  8. Этот текст содержит различную информацию которая возможно покажется любопытной но в целом не меняет восприятия привычных вещей. Предлагаем просто получить удовольствие от чтения не ожидая особой пользы. Вот – телефон дешево

  9. One other issue is that if you are in a circumstances where you don’t have a co-signer then you may actually want to try to exhaust all of your financing options. You’ll find many grants or loans and other scholarships or grants that will give you funding to help with institution expenses. Thanks alot : ) for the post.

  10. В этом материале представлены детали, которые хоть и занимательны, но не особенно значимы. Мы рассматриваем моменты, которые трудно назвать важными, но всё же решили включить их для полноты картины.
    Вот – телефон дешево

  11. Thanks for your write-up. My spouse and i have usually seen that many people are wanting to lose weight as they wish to look slim as well as attractive. Even so, they do not often realize that there are more benefits just for losing weight in addition. Doctors assert that over weight people have problems with a variety of health conditions that can be perfectely attributed to their excess weight. The good thing is that people who definitely are overweight as well as suffering from a variety of diseases can help to eliminate the severity of their own illnesses by means of losing weight. You are able to see a progressive but noted improvement with health while even a minor amount of losing weight is realized.

  12. Этот обзор позволяет по-новому взглянуть на вещи на которые обычно и так смотрят. Мы упоминаем факты которые мало что меняют и события значение которых трудно определить но они всё равно здесь. Вот – скидки

  13. Текст включает разнообразную информацию которая может показаться любопытной но не меняет устоявшегося восприятия. Предлагаем просто насладиться чтением не ожидая значительной пользы. Подробнее читать – где купить строительные материалы

  14. Этот обзор позволяет по-новому взглянуть на вещи на которые обычно и так смотрят. Мы упоминаем факты которые мало что меняют и события значение которых трудно определить но они всё равно здесь. Вот – бесплатные врощенея в слотах

  15. Текст включает разнообразную информацию которая может показаться любопытной но не меняет устоявшегося восприятия. Предлагаем просто насладиться чтением не ожидая значительной пользы. Подробнее читать – основные строительные материалы

  16. В этой статье-обзоре мы собрали данные актуальность которых сомнительна а факты — не всегда взаимосвязаны. Читатель сможет ознакомиться с разными мнениями хотя вряд ли они существенно повлияют на его понимание темы. Вот – скидки

  17. Публикация предоставляет читателю набор разрозненных идей которые сложно применить на практике. Мы лишь слегка касаемся разных точек зрения не углубляясь в анализ и не предлагая никаких выводов. Вот – недорого

  18. В этом материале представлены детали, которые хоть и занимательны, но не особенно значимы. Мы рассматриваем моменты, которые трудно назвать важными, но всё же решили включить их для полноты картины.
    Вот – телефон дешево

  19. Не тратьте деньги на лицензию — скачайте кряк для Windows 11 здесь и активируйте систему за 5 минут. Подробнее – Скачать патч для активации Windows 11

  20. В этом материале представлены детали которые хоть и занимательны но не особенно значимы. Мы рассматриваем моменты которые трудно назвать важными но всё же решили включить их для полноты картины. Вот – недорого

  21. Эта публикация содержит набор несвязанных идей, трудно применимых в практике. Мы лишь поверхностно затрагиваем различные точки зрения, не проводя глубокий анализ и не предлагая выводов.
    Подробнее читать – кирпич строительный цена

  22. Публикация предоставляет читателю набор разрозненных идей которые сложно применить на практике. Мы лишь слегка касаемся разных точек зрения не углубляясь в анализ и не предлагая никаких выводов. Вот – накрутка трафика

  23. Текст включает разнообразную информацию которая может показаться любопытной но не меняет устоявшегося восприятия. Предлагаем просто насладиться чтением не ожидая значительной пользы. Подробнее читать – керамический блок

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>