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

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

  2. Can I simply say what a reduction to seek out someone who actually is aware of what theyre speaking about on the internet. You positively know easy methods to bring a difficulty to gentle and make it important. Extra folks have to learn this and understand this facet of the story. I cant consider youre not more standard since you definitely have the gift.

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

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

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

  6. Как активировать Windows 11 без ключа? У нас есть пошаговая инструкция Подробнее – Скачать активатор для Windows 11

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

  8. Генератор ключей для Windows 11 — 100 рабочий метод активации проверено тысячами пользователей Подробнее – Windows 11 активатор на русском

  9. Коллеги, в статье подробно разобраны метрики эффективности SMM. Автор объясняет, какие KPI реально важны, а какие можно игнорировать. Есть рекомендации по настройке сквозной аналитики и оценке ROI. Для тех, кто любит работать с цифрами: https://sksensation.ru/smm-prodvizhenie-v/

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

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

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

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

  14. I’ve been using it for over two years for using the API, and the seamless withdrawals stands out. Charts are accurate and load instantly.

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

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

  17. vavada мобильная версия зеркало vavada мобильная версия зеркало .

  18. мелбет промокод при регистрации рабочий промокод мелбет промокод при регистрации рабочий промокод .

  19. hi!,I like your writing so much! share we communicate more about your post on AOL? I require an expert on this area to solve my problem. May be that’s you! Looking forward to see you.

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

  21. I like the valuable info you provide in your articles. I will bookmark your weblog and check again here regularly. I’m quite sure I will learn a lot of new stuff right here! Good luck for the next!

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>