data:image/s3,"s3://crabby-images/b198e/b198efd582690bac7e845aeef199d3ea6f322c86" alt="The importance of common language"
Coding Philosophy
A collection of 117 posts
data:image/s3,"s3://crabby-images/b198e/b198efd582690bac7e845aeef199d3ea6f322c86" alt="The importance of common language"
data:image/s3,"s3://crabby-images/b8fb2/b8fb218c910a5332d3dd5561dbcb2e6eaf24b33d" alt="The Phoenix Project"
The Phoenix Project
The Phoenix Project is a must-read book for anyone who works in technology. If you have ever worked in a larger company you will immediately identify with the situation described at the beginning of the book. You have an overworked IT department that seems disorganized and is always behind on
data:image/s3,"s3://crabby-images/4b6c8/4b6c824e567270a6353062950ad1c804fb227365" alt="Runner on a trail in the mountains, stopping to take a picture of the view."
data:image/s3,"s3://crabby-images/a3bde/a3bde0c5b4d74a682490c1578e108bb9e493a477" alt="The Arc of a Developer"
data:image/s3,"s3://crabby-images/4d7f8/4d7f8068c770e1026072a1a16545aef07d110dae" alt="A young boy with dark skin and curly hair covering his face with his hands."
data:image/s3,"s3://crabby-images/5559a/5559a49e9133e31bc5ce02edd2ab9cf848c0f598" alt="Podcast Player showing the Legacy Code Rocks logo and the Title "Checks and Balances in Coding With ...""
data:image/s3,"s3://crabby-images/c963d/c963d69d507562371787162f591c323026ca9722" alt="Painless Functional Specs Part 1"
data:image/s3,"s3://crabby-images/340d2/340d203ae10a7aa7d8658b0c8c4648452b069a11" alt="Do we really need more features?"
data:image/s3,"s3://crabby-images/77d24/77d243143f7635076426be99568ff377861e0685" alt="XP Explained"
data:image/s3,"s3://crabby-images/893c9/893c9ed9d4959b06e320cf45de3bb742d7ef78f0" alt="Premature Reuse"
Premature Reuse
Premature Optimization
Premature Optimization is a phrase that is often heard in software engineering. It’s where you envision some potential performance bottleneck, so as you are writing the code, you go out of your way to create the most optimum code (ie written in a way that the compiler
data:image/s3,"s3://crabby-images/32eef/32eefdc4286fa1fb6a166c5da43f2d800b7d612e" alt="Its Already Hard, Don't Make It Worse."
data:image/s3,"s3://crabby-images/1824e/1824e67ec0d35093f867c81b7fea3afe9ac860c0" alt="Rituals"
data:image/s3,"s3://crabby-images/9f2be/9f2be3d8c9192185838d2f9547cd4ba6c23a5261" alt="Probably Are Gonna Need It (PAGNI)"
Probably Are Gonna Need It (PAGNI)
YAGNI
Software engineers like acronyms. It makes it easy to remember and refer to certain ideas. You’ve likely heard the acronym YAGNI, which stands for “You Ain’t Gonna Need It.” The premise behind this is that as software engineers, we have a tendency to overengineer things. We often
data:image/s3,"s3://crabby-images/226cf/226cf0fce8cd25601c759e7577b0276264b7217d" alt="How I use Test-Driven Development (TDD)"
data:image/s3,"s3://crabby-images/18183/181836639a636ec7879a7b41b77384ab4664d960" alt="Fixing Legacy Code: Missing The Forest For The Trees"
Fixing Legacy Code: Missing The Forest For The Trees
Sometimes I wonder if we are missing the point by fixing legacy code. It’s not that we shouldn’t fix bad code when we encounter it, but it’s more a feeling of we’re missing an important opportunity. Let’s start with something that you may be familiar
data:image/s3,"s3://crabby-images/f0665/f0665796ed690b754860713fe6f86ef7735b8e3d" alt="Legacy Code Testing and Requirements"
Legacy Code Testing and Requirements
One of the first traps you run into as a developer working on Legacy Code is to ask for the original requirements. It seems logical. Let’s figure out what the original designers of the machine intended. However for legacy code, that is a rabbit hole that will lead you
data:image/s3,"s3://crabby-images/86c52/86c52737e8930bd876427e69bb04114a88463449" alt="Command Query Separation of Class Methods"
data:image/s3,"s3://crabby-images/d4df8/d4df8168aab5e6358d89f91b7f91c2d932c70ec3" alt="The Joel Test"
data:image/s3,"s3://crabby-images/89236/89236aa217513128a58c3606b2c7f0de5ac730fb" alt="Back to Basics"
data:image/s3,"s3://crabby-images/e1370/e13706b0e99a966507a94fbd3fec5bb3cf522a46" alt="Peopleware"
data:image/s3,"s3://crabby-images/63f41/63f41edbd794fbf89361270c7dae37c99537364f" alt="Seven Transformational Training Assumptions"
Seven Transformational Training Assumptions
In the appendix of his book “Why Employees Are Always a Bad Idea”, Chuck Blakeman lays out his philosophy around training with 7 fundamental assumptions. Since we are all about training, coaching and mentoring here at SAS Workshops, I thought I would elaborate on his 7 assumptions and how I
data:image/s3,"s3://crabby-images/0593e/0593efdcc07a0c2da90368e505474da7f4a2353c" alt="Code as Communication."
data:image/s3,"s3://crabby-images/d1e3e/d1e3e57e027ed66634bdda4ce83c30703a287b78" alt="Simplest Thing That Could Work"
Simplest Thing That Could Work
It seems like I have been giving the same piece of advice lately: Start with the simplest thing that could possibly work and only add complication as you need it. Sometimes our natural tendency is to plan for all eventualities. We get so caught up planning for what might happen,
data:image/s3,"s3://crabby-images/76dff/76dffe786b1b60cd0fba301fdfa35f2bec6c357e" alt="Forget the word but"
data:image/s3,"s3://crabby-images/ed1fa/ed1fa51633dd4248f81432f85adb46a88c72598f" alt="The Freedom of Refactoring"