Skip to content

szepeviktor/very-clean-code

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 

Repository files navigation

Very clean code

Tweet theories

Additions to https://github.com/piotrplenik/clean-code-php

💡 Cognitive Load is what matters https://github.com/zakirullin/cognitive-load

🟢 Happy and unhappy path

if (error) unhappy path;

happy path;

🖱️ https://szymonkrajewski.pl/why-should-you-return-early/

🟢 Arrays versus objects

An array is a dumb container of unknown data. Arrays should be used to store lists: keyless elements of the same type. BTW strings are containers of unknown bytes.

🖱️ https://github.com/CuyZ/Valinor

🟢 Base value of an array

The base value of an array is not null but [].

🔴 String manipulation

String manipulation including concatenation is the job of low level libraries as it is highly error prone.

💡 Creating messages for UI and logs is not string manipulation.

🟢 Write positive conditions

Explicit is better than implicit.

❌ if (state !== null)
✔️ if (state instanceof Resolver)

🔴 Mixing programming languages

Have low-level libraries connect different languages.

  • Main language + SQL: ORM
  • Main language + HTML: template engine
  • Main language + JavaScript: JSON
  • Main language + CSS: use CSS classes and CSS variables

Principles

  • Abstraction: strive to make deeper layers do the work, write less project-specific code.

  • Be explicit! Implicit things need more brain work thus are error prone.

  • There are only two hard things in Computer Science: cache invalidation and naming things.

    — Phil Karlton

    Gain knowledge of things, so you can name them.

Support my thinking

Please consider supporting my work, as formulating the conclusions above takes at least several months.

Sponsor

Thank you!