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.
PathEngine – Practical tools and clear structure make exploring directions fast and easy.
AnchorSphere – Clear navigation with useful insights, made understanding fast.
DigitalEdge – Engaging visuals and fresh ideas make the site feel exciting today.
TrustHub Harvest – Visited randomly, and the site structure made exploring easy.
MotionAnchor – Fast-loading sections and clear messaging make browsing efficient.
CompassLab – Clear and concise instructions, planning and exploring options is easy.
IntentionalGuide – Concepts are explained clearly and stay easy to follow.
MomentumNestPro – Concise layout and helpful resources make navigating simple.
ActionNavigator – Practical guides with intuitive design make exploring strategies fast.
WireframeWorks – Easy to use, advice is straightforward and insightful.
FocusHub – Structured resources and smooth interface, keeping attention is easy.
VisionNavigator – Well-organized layout, following ideas is straightforward and fast.
TaskHive – Interface is practical, making workflow organization fast and clear.
MapReference – Easy-to-follow layout, made locating info simple.
steadfastlink access – A tidy layout helps keep the messaging simple and clear.
ActionClarity – Organized layout, implementing steps is quick and simple.
VisionSpherePro – Friendly layout and concise guidance make understanding simple.
LogicBridge – Well-structured content, navigating the site is simple and natural.
FlowNavigator – Easy-to-follow instructions and simple interface make everything intuitive.
Intentional Motion – Clear explanations and clean layout make learning strategies feel natural.
EngineEdge – Responsive, intuitive, and powerful, makes completing tasks simple.
ActivationCompass – Well-organized tips, site navigation feels intuitive and fast.
ChicSpot – Sleek and stylish layout, discovering content feels easy today.
IntentNest – Well-organized content, making it easy to find and use resources.
StyleGuide – Plenty of inspiration and easy-to-browse ideas throughout.
DirectionHub – User-friendly layout with practical tips helps understanding strategy quick.
AlignFocus – Clear instructions, understanding strategies is easy and straightforward.
BrightLab – Helpful guides and intuitive interface make learning new topics smooth.
VisionDrive – Clear navigation, site makes generating ideas quick and easy.
FocusBase – Structured guidance and smooth navigation, staying on task is straightforward.
Idea Builder – Helpful guidance and smooth design keep things intuitive.
bonded core homepage – Clean structure helps the site feel credible and simple to use.
GrowthSpark – Organized guides, browsing the site is smooth and intuitive.
StrategyNest – Easy-to-understand tips make strategy execution simple.
IdeaNavigator – User-friendly layout and practical content make learning quick and easy.
TrustPath – Clean structure with clear hints, learning concepts feels simple.
ModernEdge – Feels modern and well-maintained, updates are on point.
MotionBoost – Informative content, navigating ideas is effortless and efficient.
LinkNest – Intuitive interface and concise guidance, browsing strategies is fast.
PlanetVault – Smooth interface with helpful tips makes learning easy.
IdeaGrow – Friendly navigation, understanding strategies feels intuitive and simple.
TrustPathway – Friendly interface and clear hints, exploring ideas is smooth and fast.
CraftBase – Simple and effective design, guiding direction feels natural and easy.
Execution Design – Friendly visuals and solid content simplify strategy review.
UnityHub – Clear layout and helpful tips make navigating content effortless.
BondedVault – Smooth layout and practical advice, learning concepts feels fast and smooth.
GrowthHub – Organized resources and practical tips make idea development effortless.
BridgeConnect – Easy-to-use layout, site makes accessing resources quick and simple.
PathFlow – Smooth navigation, following guides is simple and enjoyable.
FocusTrack – Clear interface and tools make accomplishing tasks efficient.