Moody weather, a variety of cars, good coffee.


Maybe we should build more personal software in the text:

For navigation, the Cat featured leap keys: two rose-colored keys below the spacebar. You could press and hold one while typing a sequence of characters to “teleport” to the nearest instance of that pattern. The left leap key would take you back, the right leap key would take you forward.

User conventions emerged to support life within this system. Users would implement their own navigational systems using special characters, tags, “@keywords”, and consistent date and timestamp formats that would work well with the leap keys.

— Alexander Obenauer, Recreating the Canon Cat Document Interface

At the least, we’re probably over-indexed on scripts gluing files together, spreadsheets, and ideologies that expand into multi-hour courses.


The King Gizzard & the Lizard Wizard Rule: If you provide a text box for people to put things on the internet, you will eventually need some kind of moderation mechanism for people to opt out of the King Gizzard and The Lizard Wizard discourse without bothering the admins.


Many folks seem really excited about autumn’s arrival. (Pending, in more stubborn locales.)

Trees in Oregon, some turning rather festive

Maybe the world is too much blasting, dismal, infernal summer lately.

p.s. Infernal! The double meaning/etymology makes sense now. 🧠


Taylor Troesh, Compressing Codebase Collocates:

To decompress a codebase, inline its paths of execution. For example, rewrite each endpoint of a webserver with only standard library functions and simple database drivers. One can repeat the decompression process all the way to bedrock machine code, but most programs accrue diminishing returns before that point.

To compress a codebase, recursively replace collocates with equivalent”zero-cost” abstractions. Don’t try to outsmart yourself — prioritize infrastructure for the most egregious repetition frictions of digital desire paths.

Writing code for compression/expansion is sticking around in my head. First, because the result seems concise and punchy, two of my favorite qualities in writing for humans.

Second, because there’s something organic and creative to the cycle of making something, trying to subtract the non-essential, adding to make more something, subtracting to improve the something-ness of it. Repeated cycles reveal more about what something actually is, often unknown to us at the outset or surprising when we discover its essence after many iterations or de-/re-compression cycles.

Dang old intellectual endeavors, sometimes they’re really something.


A blog post can just end.

Informality is an advantage, most days.

And, being an amateur.

We’re all terrified of being revealed as amateurs, but in fact, today it is the amateur—the enthusiast who pursues her work in the spirit of love (in French, the word means “lover”), regardless of the potential for fame, money, or career—who often has the advantage over the professional. Because they have little to lose, amateurs are willing to try anything and share the results. They take chances, experiment, and follow their whims. Sometimes, in the process of doing things in an unprofessional way, they make new discoveries. “In the beginner’s mind, there are many possibilities,” said Zen monk Shunryu Suzuki. “In the expert’s mind, there are few.”

– Austin Kleon, Show Your Work


I am told that you can enter thousands of words in a note attached to a task in Things. This seems like an esoteric and unconventional bit of trivia, Things being a task management app, not one of the likely candidates for a “second brain.” My pal Brian Bailey knows the exact number:

My to-dos in Things are often prompts to think and write, such as a post, short story, or planning for a new year. That’s when I normally switch to iA Writer. But recently, I started to wonder why. The to-do in Things usually has notes, initial bullet points, or maybe a draft intro. I often find myself switching back and forth between them.

— Brain Bailey, Focused Writing in Things

You’ll have to read the exact number in his post. 😉

Things is one of the apps I had in mind when I wrote about humble shopkeepers of software. It is, nearly two decades on, nearly complete software. I love that.

Would I love to see them go all the way and add notes, applying their characteristically well considered, high standards of function, form, and feel? Absolutely. Would it make it even harder for me to stick with a notes app I’m already using? Absolutely.

Am I a little worried they might slip and mess up something nearly perfect as-is? Also, yes.

I’ve found that there is an ebb and flow to how I use different tools. Sometimes, I want to consolidate to as few as possible, other times I love having one that specializes in each piece of the puzzle, like an outliner. For now, I’m enjoying going to Things for what’s next, then staying there to actually work on it.

Current status: trying to consolidate tools, so I waffle between them less often. I so want to be the person who is happy with only a few applications to do all of their things. Yet, I am, repeatedly, not that person.

Maximalism, I love you, your grass is always plentiful, and the greenest! Maybe uncanny in how lushly, deeply green it is. 🤔


Think of how much context space you’re wasting from all the times a coding agent says, “of course you’re right…”

Slaps CLAUDE.md yeah I can fit so many more tokens in this baby since I told the agent to 1) call me “Meatbag” and 2) say “gotcha” when I correct it and then get on with the task.


Modern applications can’t hope to escape towering chains of complexity. Careful consideration of trade-offs and a bit of gardening are the way through.

If you don’t read, you won’t succeed.

– Tom MacWright, How to keep package.json under control

Possibly the best one-liner advice on managing dependencies out there. You might as well get good at understanding and mitigating the carried complexity.


The CSS rediscovery continues!

Then, a few years ago, I read a blog post by Josh W Comeau called My Custom CSS Reset. I realized that there’s no deep magic; everything a reset does is just normal CSS that you can read and understand.

— Jake Lazaroff, My Modern CSS Reset

I have only copypasta’d other folks’ (thanks, Eric Meyer) reset code, assuming it’s deep CSS tricks that I didn’t want to understand. But Jake’s is an easy read, particularly if you read through his post.

I suppose it kind of blurs the line between “CSS reset” and “classless CSS framework”. My goal isn’t really to adhere to a strict definition of either one; I’ve just found this set of styles to be a good starting point for most websites I build.

I love a good classless CSS framework. I did not have “more excited about CSS than JS” on my 2025 web dev bingo card, but here we are.


It’s no “for sale, baby shoes…” (spoiler redacted), but I like the feel of this short fictional invention:

From decades of reading The New Yorker, he had an extensive recall of the fabric that makes up the world. This recall, however, seemed exclusive to facts and anecdotes that led to an easy, repellent, or vulgar punchline about the minutiae that constitute the world. For this reason, it was most practical that around Thanksgiving, he was seated at the kids table.

If you’re keeping score at home, this is, IIRC, my debut as a writer of fiction. 🤔


Polyglot runtimes have arrived and fizzled throughout my stage whisper 25-year career. Supporting multiple programming languages without reducing them to an uninteresting lowest common denominator has proven wildly difficult.

That is, most multi-language runtimes are one of: “you can use any language, as long as you conform to Java-style OO”, “any language can run in a browser as long as it quacks like a DOM manipulation written in JavaScript”, or “bring your favorite languages, as long as it conforms to conventions invented for C sometime in the 1970s”.

It’s wild, to me, that the solution to “I want to re-use singular code that solves my problem but is not in the language I’m using” may end up being “use an LLM to rewrite it wholesale into your language of choice”. 🤷‍♂️

See also: LLMs are, themselves, weird little computation architectures.


📚_The Long Way to a Small, Angry Planet_, Becky Chambers

I’ve read three of Chambers’ books now and would characterize them as “comfy sci-fi”. In the best possible way! There’s a spaceship with many sapient species making up its crew. There are stakes and adventures, but they aren’t galactic in scale or epic in drama. It’s a nice reprieve from the cold-eyed intensity of, e.g., Herbert.

This one is a “found family” sort of outing. Our crew has a few adventures, but they are secondary to the relationships and connections formed. Again, it’s an enjoyable change of pace from what I normally read. I love a hero’s journey dotted with encrypted deck-of-cards messaging and “what if computers were exceptionally competent and evil?” plot lines. But I think it’s good to read about relationships and “what if birds and apes were sapient and worked together in deep space?” too. 😆


We live in a time when the math favors iteration

Granted, quality of idea matters. The worst idea executed swiftly and repeatedly is still probably the worst idea. But it’s hard to know, with ideas, when you’ve got a winner or not. Hence, the power of iteration.

output=iterationsrateideaoutput = iterations * rate * idea

There are many ways to turn a good idea into great work.

  • Generate one immaculate idea, get it done, get it out there, promote it relentlessly.
  • Have ten good ideas, try them all quickly, put the best idea out there, pursue the one or two that seem most promising.
  • Have one hundred ideas of wildly varying goodness, try them at a fantastic pace, see which one sticks.

For better or worse, the world we live in favors the last one. The person with one great idea is often not the person who is known for great work. Unless they’re lucky, persistent, or both!

(Once you’ve got that good idea, you still need The Quality.)

Allow me an idiomatic metaphor: “Good Vibrations” was a whopper of a good idea but took 7 months to record. Most albums take far less time than that to record (not you, Bruce Springsteen), contain 8-12 songs, and 1-2 songs stand out. Today, you can slop out one hundred songs with AI and if any of them are listened to more than a couple times it’s a big success.

Of the many “All you need is attention, context, cheese-whiz” sort of papers out there, the unsung hero is “All you need is billions upon billions of iterations.”

Hence, evolution and all of human creativity as well! It only took hundreds of light bulbs and dozens of airplanes before Edison or the Wright Brothers found the one that works.


Easier doesn’t mean less good

Explosion of mediocrity, video gaming edition: it’s become easier to build games, so there are more and more games every year; but the number of highly acclaimed games per year has stayed constant or even declined slightly (orange dots).

Nabeel S. Qureshi

More accessible does not mean success comes more easily or more work will have higher quality. Accessibility is orthogonal to magnitude and density of quality.

For any creative endeavor, this is true. Axiomatically, if you make something easier, you’re lowering the cost of entry. This applies to average creators as much as potential superstars like Mozart, Carmack, or Einstein.

If you make it easier to do, less devoted, determined, or talented people will do it. More people means you will see more volume, making “merely” average work seem more common. The work you observe might also be more uniform or bland, since making something accessible often means many folks are starting from similar templates or boilerplates.

This might sound a bit elitist. But, I think there’s plenty of room to produce great work without elite skill. ZZ Top and AC/DC are far less sophisticated, and their members less talented, than Prince or Van Halen, but still produce work that carries an appeal of its own.

The same applies to software. You don’t need a room full of doctorates to produce excellent software, you don’t need a master of arcana to produce fast software, and you don’t need a transcendent genius to solve someone’s problem in a well-considered product.


CSS done grown up

Look at this bit of CSS. For greatest effect, imagine sending it yourself from ten or fifteen years ago, or the first time you hit upon a limitation in browser compatibility or looked at someone else’s stylesheet and wondered “what the heck is going on here and what’s a high-pass filter?”

CSS in 2025 is pretty good!

Marvel at all the things that are just there, no hacks or preprocessors or compilers required. Gradients, animations, input states. CSS has grown into the open-ended, declarative, and compatible system it always wanted to be. I dare say that CSS is (finally?) hitting its mark.

Can Ruby, JS, Python, C#, Java, etc. make a similar claim? Particularly in expanding the capability with, AFAICT, only superficial syntactic changes and adding new rules.

Can you still use Python from ten years ago, add new functionality to a Ruby program with a keyword, or use new features in JavaScript across all runtimes? Were it only true! (Where it’s not, there are usually pretty good reasons, to be fair.)

Based on tinkering with SwiftUI lately: this beats configuring views. Even when I’m building both with the help of Spicy AI Auto-complete. 😉

Previously: low-key CSS libraries.


Feel, fast, function, form

In that order, every time.

I make a big deal about working downhill. Get stuff done, slice it smaller, get feedback, go again, remove friction, a little faster this time.

But let me tell you, none of that matters if it doesn’t come together and feel great once it’s all assembled in front of you.

When you feel it, you know. The feature makes you smile when you use it. It fits right in, like it was always meant to be there. You want to use it again. You want to tell people about it.

This is the difference.

— Mitchell Hashimoto, You Have to Feel It

Everyone loves a little faster, even if they say they want more function or nitpick on the form. But not everyone asks for it to feel great. That’s what distinguishes the good from the great and the great from the sublime.

Feel, fast, function, form. In that order. Every time.

It has to feel great, feel quick, have the right functions, and pleasing forms. In that order of importance.

I’ll excuse anyone if they’re not a transcendent genius who can create things exhibiting those qualities in that order and every time they sit down to build. But when you can get all four of those things together, even in small quantities, then you’ve got something special.

Feels great, feels fast, gets the job done, all the right affordances and embellishments. In that order, every time. You gotta try, at least.


Since I last wrote a /now post:

  • Friends visited, a lovely time being a tourist in our hometown was had.
  • We went to Disneyland for my birthday, stayed at our favorite hotel, ate our favorite things, it was good.
  • Saw The Roots in a downtown town square, this was a great way to check off a rare “live music experience I’d like to have”, expectations were met and exceeded.

I’m building myself a personalized CRM for tracking job applications. A very vanilla Rails stack so far, the only exotic thing I’ve done is try deploying to a local Docker runtime via Kamal. Turns out that’s swimming upstream more than I want, so it’s deployed to a local Docker runtime via a bespoke script that Claude Code helped me write.🤷🏻‍♂️

The McPhee method. I’ve been so thoroughly nerd-sniped by this. A way of turning notes into outlines into essays and articles? The only way this could be more my jam is if there was some connection to Stevie Wonder, Stravinsky, or Porsche. This is taking up a surprising amount of mental space.😆🤓


No surprises

When leading projects, in any capacity, avoid startling your colleagues. Tech leads, engineering managers, product managers, etc. need to keep peers and stakeholders informed. When there are successes, let them know. When risks are discovered, communicate the steps taken to mitigate them. When setbacks occur, indicate how it will affect the remaining scope and schedule of the project. Dig out, not up.

Stakeholders and peers are startled when they think a project is smooth sailing only to hear the ship is sinking. When things go poorly, projects slip by inches, then feet, then all of a sudden. It’s on project leaders to detect these slips, address the root causes, and let people interested in the project know what’s going on and what you’re doing about it.

This may seem obvious! But it’s easy to get so wrapped up in solving the problem that you forget to communicate the problem. To want to say, with ease, “things aren’t going great, but I have it under control.” Or, to feel like the issue is yours alone and forget you may have peers in the organization that could help if only you communicated it.

A non-obvious way to surprise people is to silently, but suddenly, succeed. Release new features or change functionality in production without any kind of internal notice or documentation, and I’ll bet you hear something from customer support, marketing, sales, etc. They won’t begrudge you for doing your job and shipping code, but they might ask you to please let us know next time so we can prepare our teams, campaigns, or update our documentation. Or, they might come at you with pitchforks, wanting to know why things are changing out from under them.

Corollary: Don’t Be Spooky. If you need to tell someone, IC or stakeholder, that a project has run into surprises, just tell them. Don’t open up with context-free messages like “can we talk?”

Have the hard conversation now, before it gets tougher.


Morning reading level up