Skip to content

Commit

Permalink
blog: code editors (#143)
Browse files Browse the repository at this point in the history
  • Loading branch information
paularmstrong authored Mar 2, 2024
1 parent fe5ee31 commit b4c5754
Show file tree
Hide file tree
Showing 8 changed files with 1,143 additions and 10 deletions.
7 changes: 7 additions & 0 deletions .astro/types.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -388,6 +388,13 @@ declare module 'astro:content' {
collection: "blog";
data: InferEntrySchema<"blog">
} & { render(): Render[".mdx"] };
"2024-03-02-code-editors-are-personal.mdx": {
id: "2024-03-02-code-editors-are-personal.mdx";
slug: "2024-03-02-code-editors-are-personal";
body: string;
collection: "blog";
data: InferEntrySchema<"blog">
} & { render(): Render[".mdx"] };
"desktop-organization-and-workflow.mdx": {
id: "desktop-organization-and-workflow.mdx";
slug: "desktop-organization-and-workflow";
Expand Down
3 changes: 2 additions & 1 deletion astro.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,11 +9,12 @@ import { remarkReadingTime } from './plugins/remark-reading-time.mjs';
import react from '@astrojs/react';
import expressiveCode, { ExpressiveCodeTheme } from 'astro-expressive-code';
import { pluginCollapsibleSections } from '@expressive-code/plugin-collapsible-sections';
import { mermaid } from './plugins/remark-mermaid';

const darkTheme = readFileSync(new URL('./config/theme/tailwind-dark-slate.json', import.meta.url), 'utf-8');
const lightTheme = readFileSync(new URL('./config/theme/tailwind-breeze.json', import.meta.url), 'utf-8');

const remarkPlugins = [remarkReadingTime];
const remarkPlugins = [remarkReadingTime, mermaid];

export default defineConfig({
site: 'https://paularmstrong.dev',
Expand Down
2 changes: 2 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -44,10 +44,12 @@
"eslint-plugin-astro": "^0.31.4",
"eslint-plugin-mdx": "^3.1.5",
"eslint-plugin-tailwindcss": "^3.14.2",
"mermaid": "^10.8.0",
"netlify-cli": "^17.16.2",
"onerepo": "1.0.0",
"prettier": "^3.2.5",
"prettier-plugin-astro": "^0.13.0",
"rehype-mermaid": "^2.1.0",
"typescript": "^5.3.3"
},
"packageManager": "[email protected]",
Expand Down
22 changes: 22 additions & 0 deletions plugins/remark-mermaid.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
import type { RemarkPlugin } from '@astrojs/markdown-remark';
import { visit } from 'unist-util-visit';

const escapeMap: Record<string, string> = {
'&': '&amp;',
'<': '&lt;',
'>': '&gt;',
'"': '&quot;',
"'": '&#39;',
};

const escapeHtml = (str: string) => str.replace(/[&<>"']/g, (c) => escapeMap[c]!);

export const mermaid: RemarkPlugin<[]> = () => (tree) => {
visit(tree, 'code', (node) => {
if (node.lang !== 'mermaid') return;

// @ts-ignore
node.type = 'html';
node.value = `<div class="mermaid" data-content="${escapeHtml(node.value)}"><p>Loading graph...</p></div>`;
});
};
139 changes: 139 additions & 0 deletions src/content/blog/2024-03-02-code-editors-are-personal.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,139 @@
---
title: Code editors are very personal
description: |
I just spent far too long trying to bend [Zed](https://zed.dev) to my will. It reminded me of how I needed multiple weeks on and off configuring and reconfiguring VSCode to work for me. It is rare that the defaults provided in a code editor work for me. So I tried, and I've given up for a few very important (to me) reasons…
pubDate: 2024-03-02
---

import { Image } from 'astro:assets';
import VSCode from '../../images/blog/2024-03/vscode.png';

I just spent far too long trying to bend [Zed](https://zed.dev) to my will. It reminded me of how I needed multiple weeks on and off configuring and reconfiguring VSCode to work for me. It is rare that the defaults provided in a code editor work for me. So I tried, and I've given up for a few very important (to me) reasons.

But before that, all of this takes me back to my history with code editors. The main theme that's stuck with me across each one is that I want it to be a _code editor_. Not an IDE. I don't want a terminal, I don't want to run tests, I don't want a million and one features that are better handled by other tools and apps.

## Code editor timeline

An approximate timeline, as near as I can remember would look something like this:

<div class="bustout-sm">
```mermaid
timeline
1990s : Windows Notepad
: Geocities
: Adobe GoLive
: ResEdit
2002 : BBEdit
2005 : TextMate
2011 : Sublime Text
: Xcode<br>(for a short stint)
2021 : VSCode
```
</div>

### 1990s - Script kiddie

I started nerding out with various things when I was too young to even know what I was doing, but I had fun doing it. I worked on all kinds of various things, but nothing noteworthy. I do remember having a Windows computer at home as our main machine for a stint on which I used Windows Notepad.

### 2002 - BBEdit

About this time I started ditching Adobe GoLive and going all in with BBEdit. I landed a job on my college campus building websites for our student union, student groups, and more. I got really good at writing HTML by hand. CSS was really just starting to proliferate and I was hooked.

### 2005 - TextMate

TextMate was already available, but we didn't make the switch until it was really getting popular. TextMate did everything I needed and nothing more.

### 2011 - Sublime Text

I've spent more time using Sublime Text than any other editor. I would be really interested in knowing the full stats of hours spent in the application over the course of ~10 years.

I loved Sublime Text. It was fast, boosted my productivity, and simple – nothing about Sublime Text ever got in my way.

### 2021 - VSCode

I _begrudgingly_ switched to VSCode. I never wanted to. In fact, over the course of at least three years, I tried to sit down and force myself to use it and configure it to my liking for a week at a time on at least four different occassions.

VSCode was slow. It does far too much for a "code editor" and is nearly a full-blown IDE… and at this point, with the right extensions, it _is_ a full IDE.

I really only switched to VSCode for a few reasons:

1. The Sublime Text LSP for TypeScript sucked (and it still sucks). "Go to definition" rarely, if ever works.
1. SublimeLinter is very difficult to configure correctly.
1. As a principal-level leader who needed to spend a lot of time pair-programming and teaching others, it was too difficult to not work in the same editor everyone else was.

I finally got VSCode to a point where it typically is not noticeably slow and 90% of its features are tucked away, hidden, or completely disabled. These are the things that are either unnecessary or poorly implemented for me:

- Terminal: tends to be problematic or have integration issues
- Debugger: takes too long to set up and configure for every project. I just use Node's `--inspect --inspect-brk` flags and pop open an inspector in a chromium-based browser
- _All the tooltips_: VSCode is way too aggressive about showing overlay hints and tooltips while I'm typing. I'm still typing. I actually type pretty darn fast, but these tooltips appear even faster and they're always wrong.
- Disabled/hidden: Most of the UI panels other than the explorer view
- The search UI is horrible. I've moved it over to a panel, but it's missing the ability to do regex replacements. You _have to_ use the side bar's find tab for this.

<div class="bustout-sm">
<Image src={VSCode} alt="A minimal approach of using VSCode with most panes and features disabled." />
</div>

## Trying something new

I recently tried to go back to Sublime Text, but I just couldn't figure out how to get by the same first two issues that led me to switching to VSCode in the first place. So I threw that out the window.

I have the following hard requirements for an editor:

1. Ability for custom keyboard shortcut snippets.

I've used the same custom snippet since my days with BBEdit: <kbd>CMD+CTRL+,</kbd> will add `<div></div>` and highlight `div` to change to any other HTML tag. I must use this snippet hundreds of times per day and I cannot live without it.

2. Two & three pane views.

The panes need to stay open even when there is no file open in them. As visible in my VSCode screenshot above, keeping the panes open prevents any sort of unwrap/reflow of text in the open pane.

3. Stop shoving AI at me.

I prefer to write things myself and know what I'm actually doing instead of hoping that an LLM connected the dots between keywords and syntax correctly.

4. "Go to definition" must actually work.

Including going to definitions from `node_modules` (which Sublime Text doesn't support).

### Zed

Non-starters:

- Missing custom snippets. The inability to add my snippets in Zed made it a non-starter (and I spent a good hour scouring through discussions and issues trying to find a solution).
- Extra panes disappear when empty and there's no way to prevent that.

Annoying, but I can live with:

- I absolutely hate that the settings are only in JSON. This is actually the same as Sublime Text, but annoyingly, you have to manually open both the defaults and your custom settings in order to know what is actually possible.

- Minimal/lack of documentation on how to configure key bindings.

I can eventually get used to different key bindings for things, but the syntax currently requires I know the internals of Zed and its code to perform actions.

- AI - at least it can be disabled, but how do I _know_ that what I'm writing isn't being fed to some machine to learn from?

### Lapce

Honestly, I didn't spend enough time here and I probably should, but…

Non-starters:

- Like Zed, no snippet support.
- Extra panes disappear when empty and there's no way to prevent that.

Annoying and I don't want to deal with:

- It feels like it's trying to be VSCode with all the features, bells & whistles, but I can't make them go away.
- No native OS X menubar

Super annoying, but I can live with:

- I closed a couple panels upon first open and I can't figure out how to get them back.
- What the heck goes in the right panel? It's just blank and click/right-click does nothing in it.
- It took me a good 5 minutes to figure out how to open a folder/project in the editor.

---

## Sitting for now

I guess I'll be sitting with VSCode for now. Despite my annoyances – at least most of them can be hidden away or disabled.
Binary file added src/images/blog/2024-03/vscode.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
31 changes: 31 additions & 0 deletions src/pages/blog/[...slug].astro
Original file line number Diff line number Diff line change
Expand Up @@ -169,3 +169,34 @@ for (const entry of randomEntries) {
@apply text-blue-400;
}
</style>

<script>
// @ts-ignore
async function renderDiagrams(graphs) {
const { default: mermaid } = await import('mermaid');
mermaid.initialize({
startOnLoad: false,
fontFamily: 'var(--sans-font)',
// @ts-ignore This works, but TS expects a enum for some reason
theme: document.documentElement.dataset.theme === 'dark' ? 'dark' : 'default',
});

for (const graph of graphs) {
const content = graph.getAttribute('data-content');
if (!content) {
continue;
}
const svg = document.createElement('svg');
svg.id = 'mermaid-' + Math.round(Math.random() * 100000);
graph.appendChild(svg);
mermaid.render(svg.id, content).then((result) => {
graph.innerHTML = result.svg;
});
}
}

const graphs = document.getElementsByClassName('mermaid');
if (document.getElementsByClassName('mermaid').length > 0) {
renderDiagrams(graphs);
}
</script>
Loading

0 comments on commit b4c5754

Please sign in to comment.