Cole Ellison • 2025-02-15
Updated: 2025-03-11
The organization of this page may evolve over time. Perhaps this grouping of sections blindly by content type is less relevant in the face of particular topics of interest.
Generally, I tend to gravitate towards web performance, software design, geometry or mathematically-driven design. I’m currently interested in the local-first movement in app/web development and am experimenting with a small homelab setup.
Questions the old idea of spending “innovation tokens” and reaping complexity. Instead, this offers the idea of “boundary tokens” which are spent when a project exits the area of what is well and commonly understood by contributors. It shifts the focus to value deep knowledge of one’s chosen tools and puts a higher cost on investing in services outside of that scope due to the maintainability and familiarity concerns.
yes, it’s from 2018, but it’s a nice dive into the render and commit phases of React
Learning requires the ability to fail publicly. While this may be “okay” in groups of only senior+ employees, it becomes much more acceptable and common when instruction is a core part of the job. “Juniors force-multiply seniors, not by writing code, but just by forcing seniors to teach and rethink their knowledge.”
Related prior/contemporaneous detail on the design and pursuit of the squircle are found in the following: iOS 7 Icon Squircle and Unleashing Genetic Algorithms on the iOS 7 Icon (Mike Swanson)
This one reminded me of Eva Parish’s What I think about when I edit.
A generative culture is an “organizational culture that is high-trust and emphasizes information flow is predictive of software delivery performance and organizational performance in technology.” The six key aspects of such a culture are: high cooperation, trained messengers, shared risks, encouraged cross-functionality (bridging), allowing failure to invite inquiry, and experimentation with the novel.
The subsection on incremental decoupling here provides a framework for facilitating painful migrations. Using jQuery is easy, so preventing new uses of it in a draconian way would lead to inevitable animus. Setting up linting on new code and a PR bot to pull in the migration orchestration team on relevant PRs allows for the easy suggestion of alternatives. Stripping functionality out of the version of jQuery used was another good move to prevent regressions.
Deals with the inevitability of instability and unknowns in the face of unavoidable complexity incurred as software projects mature. Further reading includes the Laws of Software Engineering (Lehman & Belady) that provides a set of pseudo-axioms describing the forces affecting software systems. Out of the Tar Pit (Moseley & Marks) is also recommended on accidental vs essential complexity.
How to build a learning culture in an engineering org. Somehow, 15 minutes is enough to provide a full framework for the cycle of fostering resilience, growth, and collective education among engineers.
Doing something that looks like the inverse may be good, but nothing is guaranteed. Microservices are another design pattern for systems, and the collective sentiment that they operate as some golden panacea is likely overblown in many instances. I still, generally, believe in smaller services, but the added network overhead has to be justified by traffic data and good architecture. This lead me to Assault by GC from Marc Gravell, which talks about an approach to circumvent GC issues StackExchange was having that caused outages.
No promise that I’ve gone and used these, but I’ve certainly read about them and find them compelling enough to list.