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.
CL Lighthouse – Informative, reliable, and easy to use overall.
BlueCrest Center – Clear branding and logical layout, information flows naturally.
Stronghold Link – Logical structure helps locate important information quickly.
CN Portal – The content is concise, and everything loads fast.
Bonded Guide – Well-structured layout makes finding information effortless.
Bonded Overview – Focused content layout ensures the main points stand out.
Vertex Central – Easy to use and very well-structured.
Centurion Bond portal – Site works well, content feels straightforward and current.
Bonded Overview – Pages are concise and structured for quick understanding.
CoreMerge portal – Information is structured clearly, and navigation feels effortless.
Bonded Guide – Navigation is smooth, and information is easy to comprehend.
Bond overview – Well-structured pages with readable and concise information.
Services – Well-structured pages, concise content, and effortless browsing.
Watch Lighthouse – Resources are clear, finding info is hassle-free.
AboutUs – Clear sections, smooth browsing, and content is straightforward.
Careers – Job listings are readable, and applying is straightforward.
HB Hub Online – Navigation is straightforward, layout is clean, and content is easy to digest.
ClearPath Bond info – Useful content and fast response across the site.
CoreStead resource – Helpful and concise content that’s simple to understand.
Login – Quick access, simple layout, and pages are effortless to navigate.
Compass Insights – Logical layout, content is digestible and user-friendly.
Bond Central – Smooth navigation, clear structure, and information is concise.
Bond Central Hub – Quick-loading pages, polished interface, and browsing content is effortless.
Dependable Capital page – Clear headings and concise content make finding information easy.
Bonding Insights – Very approachable, guides are simple to follow.
Events – Pages are well-arranged, simple to explore, and visuals are clean.
Services – Service details are easy to locate, and browsing between sections is simple.
Bond Central – Navigation is intuitive, sections are organized, and content reads clearly.
Capital Gateway – Clear structure, responsive pages, and all sections are easy to navigate.
Bond support site – Easy-to-read information with good structure.
Events – Organized layout, easy navigation, and information is simple to find.
CoreWard Bond – Clean design and quick loading, content feels reliable.
Community – Simple layout, smooth navigation, and content feels approachable.
Mainline Hub – Pages are neatly organized, navigation is smooth, and content is easy to follow.
Keystone Space – Layout feels tidy, menus are intuitive, and information is concise.
Unity hub – Organized content and smooth-loading pages make exploring easy.
Bond Central Hub – Quick-loading pages, neat structure, and content is well-organized.
FAQ – Answers are concise, and the section organization makes browsing effortless.
Features – Organized layout, smooth browsing, and text is readable.
Anchor Hub Online – Fast response times, clear layout, and information is concise.
News – Clean design, informative content, and pages load without delay.
Gallery – Visually tidy pages, clear structure, and easy to move through.
Coalition Bond portal – Smooth interface and a layout that’s easy on the eyes.
CornerPeak info – Well-organized site with professional styling and smooth navigation.
Mainstay Spot – Sleek interface, organized sections, and content is readable.
Explore Axis – Well-structured pages, simple browsing, and content is easy to follow and understand.
Portfolio – Minimal design, intuitive navigation, and content is easy to follow.
Orbit Connect – Pages load quickly, interface feels organized, and content is easy to scan.
Home – The homepage is clear, loads quickly, and navigation is smooth.
Durable Capital site – Fast-loading pages with well-presented, easy-to-read material.