Archive

The Dulin Report

Browsable archive from the WordPress export.

Results (27)

Strategic activity mapping for software architects May 25, 2025 On the role of Distinguished Engineer and CTO Mindset Apr 27, 2025 My giant follows me wherever I go Sep 20, 2024 The day I became an architect Sep 11, 2024 Form follows fiasco Mar 31, 2024 On Amazon Prime Video’s move to a monolith May 14, 2023 One size does not fit all: neither cloud nor on-prem Apr 10, 2023 Comparing AWS SQS, SNS, and Kinesis: A Technical Breakdown for Enterprise Developers Feb 11, 2023 Why you should question the “database per service” pattern Oct 5, 2022 Monolithic repository vs a monolith Aug 23, 2022 All developers should know UNIX Jun 30, 2022 There is no such thing as one grand unified full-stack programming language May 27, 2022 Most terrifying professional artifact May 14, 2022 Best practices for building a microservice architecture Apr 25, 2022 TypeScript is a productivity problem in and of itself Apr 20, 2022 Tools of the craft Dec 18, 2021 TDWI 2019: Architecting Modern Big Data API Ecosystems May 30, 2019 Which AWS messaging and queuing service to use? Jan 25, 2019 Let’s talk cloud neutrality Sep 17, 2018 What does a Chief Software Architect do? Jun 23, 2018 Singletons in TypeScript Jul 16, 2017 Online grocers have an additional burden to be reliable Jan 5, 2017 What can we learn from the last week's salesforce.com outage ? May 15, 2016 IT departments must transform in the face of the cloud revolution Nov 9, 2015 Top Ten Differences Between ActiveMQ and Amazon SQS Sep 5, 2015 What can Evernote Teach Us About Enterprise App Architecture Apr 2, 2015 Docker can fundamentally change how you think of server deployments Aug 26, 2014

Most terrifying professional artifact

May 14, 2022

Gather around the fire, kids; I am about to tell you a horrifying story.




“The most terrifying professional artifact Neal ever encountered was a single C function that served as the heart of a commercial software package whose CC was over 800! It was a single function with over 4,000 lines of code, including the liberal use of GOTO statements (to escape impossibly deeply nested loops).”

— Fundamentals of Software Architecture: An Engineering Approach by Mark Richards, Neal Ford




In the summer of 2002, I worked on one of the early implementations of online banking. I had a coworker who mostly kept to himself. He was responsible for a significant part of the project. While the rest of the team worked together and might have created the impression of inefficiency, this particular developer was a lone wolf who worked seemingly long hours and always delivered. The management loved him. On the surface, he made all of us look bad.



Except when he resigned, and I inherited his code.



His entire work was confined to a single 40000+ long JSP file -- Java code commingled with HTML, with a giant if/else statement covering all possible execution paths, using HTTP redirects to MacGyver a GOTO.



While a standard software practice is to give meaningful names to variables, he would name them iiiiiiiiii. Eventually, when the number of is became too long even for him, he added numbers: iiiiiii1iiiiiii2, etc. 



I was given assignments to fix bugs in his code, and the only way I could work on that code was by convincing my boss to let me refactor it first. It was no simple task because I lacked the gravitas to convince otherwise non-technical management that certain things needed to be done at only two years out of college.



Ask yourself: at two years out of college, have you faced a situation like this?



I was given a few days to figure it out. The only way I could wrap my head around this code was by printing it out, taping printed sheets together, spreading it on the floor, and crawling over it using a highlighter to annotate blocks of code. Having spent about a week working from 9am to 11pm, I managed to refactor that monstrosity.




This is me, summer of 2002, with the top portion of the monstrosity I was expected to untangle



I learned some valuable lessons from this experience:




  1. Developers are like toddlers. When a toddler is quiet, it can only mean one of two things — either he’s napping, or there is trouble brewing.
  2. One cannot start working on code changes without understanding code and being able to run the code on their machine.
  3. Sometimes, to understand the code, one must resort to old-fashioned paper and pencil tactics to untangle the mess.








Featured image: Garnished Spaghetti in Ghana via WikiMedia Commons