DEV Community

Cover image for Software Design Principles in Note-taking
Mark Castillo for Developers @ Asurion

Posted on

Software Design Principles in Note-taking

Those of us who've been writing code for some time have likely applied these design principles in our work. These help our code become clear and readable - maintainable. It helps collaborators (and your future self) better understand your creation.

I started to entertain strategies for note-taking when I realized that it was time to stop dumping all of my notes into Notepad and start compiling and organizing them into something that sentient beings could understand. However, those that I've read were mostly geared towards capturing ideas (for book writing, graduate studies, etc.)

And so I thought, "I'm familiar with principles to write clean code... could I apply those to my notes, maybe?" I've found success in translating these into note-taking. As I share them with you, I hope you do too.


Single Responsibility Principle

"A class, method, or function should only have one responsibility."

In line with it's traditional definition, each note or page should contain only one focal idea or purpose. The main goal: don't dump everything on a single document. Give each major component an island of their own.

Using application support as an example - responsibilities include supporting weekly requirements and troubleshooting of reported issues. Respectively, I've organized my notes as such:

  • Deployment Steps - a detailed, step-by-step guide on how to do the deployment. Screenshots and all.
  • Troubleshooting - the first aid kit. A compilation of valid, known, and even weird issues encountered and how they were solved. This comes in handy especially when someone else performed the resolution.
  • Overview - the page that ties them all together. Contains top-level information like the AWS account and region, access requirements, relevant URLs, plus it references the Deployment Steps and Troubleshooting pages.

Looks something like this:

SRP visual

You might think that having separate pages for each topic would be counterproductive in the long run, but it's actually the opposite. I know exactly where something is. No more guessing which piece contains what information. It also makes everything shareable and easier to build on to.


Open-Close Principle

"Entities should be open to extension, but closed to modification."

Chain your notes together, but don't weld them. Build them up as if you were making notes using pen and paper - give each idea or article, no matter how small, it's own space to grow. Then make use of links to connect the dots, like the choose-your-own-adventure books of old.

charlie conspiracy meme

It could look something like this - let's say you have an application issue that's been a pain point for quite some time. And so, you add it to your wish list of improvements. Fast forward in time, you're writing about what's shiny and new in the enhancement's you've made and the story behind it.

OCP visual


Don't Repeat Yourself

"Every piece of knowledge must have a single, unambiguous, authoritative representation within a system."

Your mileage may vary on this one as it depends on your use case. But the idea is to link your notes whenever you can.

One possible use of this could be: you encounter an issue or error that has the same nature as one that you've encountered and/or resolved before. When you get around to documenting, instead of writing everything down again from scratch, you could just make a reference to the existing document.


Bonus: Single Source of Truth

"There should be one definitive data repository that all users and systems refer to."

This is more a personal preference of mine. Having a "master copy" of my notes in one place eliminates the mental load of having to keep track of what is where. Gone are the days of Did I have that in Confluence? OneNote? Or was it in Slack Canvas? 😬

I like to use Obsidian. All of the notes I keep and its revisions go through there first before being shared anywhere else. I find it convenient to have the updated copy within reach, as the ones in Confluence or even GitHub can fall behind when I jump from project to project.

SSoT stock image

But! Having a single source of truth does not mean that you should limit yourself to a single tool. Go with whichever you fancy the most, but there's no one app to rule them all; use the right tool for the right job. I use a combination of Logseq and Obsidian as they both use markdown formatting - Obsidian excels in long-form notes whereas Logseq excels in short-form (bulleted, quick notes and to-do lists).


Note-taking is not much different from any other skill we learn. And it's tools are the equivalent of an IDE. Pick the one that works with your style and you end up with a second brain that works for you.

Related: Zettelkasten Method

Top comments (2)

Collapse
 
vince_llauderes_47017f0e7 profile image
Vince Llauderes

Great Post Mark! Thanks for sharing 😊.

Using a note-taking tool like Obsidian or Notion feels like having a second brain. I store all my knowledge and notes, particularly in Notion.

Collapse
 
raymundmelvinchuagithub profile image
raymundmelvinchua-github • Edited

Superb insights! ☺️ The merging of deconstruct thinking and notetaking! The philosopher and software engineer in one. 😎. "Emphasizing connection rather than collection".