Remix.run Logo
Emacs and Vim in the Age of AI(batsov.com)
157 points by psibi 4 days ago | 98 comments
mark_l_watson 18 minutes ago | parent | next [-]

Nice writeup! The list of Emacs packages to use LLMs is the roadmap for getting started with AI Emacs integrations and I also liked his list of AI dangers at the end.

I have used Emacs for over 40 years but I found myself getting sucked into the black hole of VSCode as discussed in the article. When I bought a new MacBook a few months ago, I only installed Emacs, no VSCode, and so far that is working out for me.

Also, after many hours of experimenting with AI packages for Emacs, I have reverted to keeping Emacs mostly a pure human activity, and several times a week have sessions with gemini-cli and Claude Code when I want an AI coding assistant. This is just for me, not general advice, but I like to separate use of AI from my regular coding and writing workflows. I use AI for coding cumulatively about three or four hours a week.

himata4113 8 minutes ago | parent | prev | next [-]

I swapped from jetbrains products to lazyvim/nvim and honestly without AI it would have not been possible. The speed I was able to configure it exactly how I wanted and support workflows jetbrains would never support is great.

Escaping the god awful AI implementations in both vscode and jetbrains product is also a refresher. They don't know what the ** is going on, they don't know what users want, but I do and AI being able to extend my IDE in a way that helps me be more productive is very undervalued.

jurschreuder 4 hours ago | parent | prev | next [-]

I'm not sure AI Agents can already beat the average VIM user.

I use VIM and I get some inspiration from LLMs sometimes, but me and other developers always after some time give up and just quickly do it manually.

AI Agents will just full the code with maaaassive swaths of texts it will just make a project unusable.

We even get paid to turn client's AI LLM Claude sketches into real programs.

keithnz 4 hours ago | parent [-]

This is not my experience at all, the AI agents are many many many times faster than what I can do. What anyone can do. It's crazy how quick I can create stuff these days.

gdorsi 3 hours ago | parent | next [-]

It really depends on what kind and of job you do.

If it's not something very common LLMs could end up generating random code.

Also if you work on something performance critical, you can get inspiration from LLMs, but they often don't write fast code.

keithnz 3 hours ago | parent [-]

not my experience, they write fast code, and if you ask them to optimize, can pull all kinds of tricks out of the bag. Even with some of the niche stuff I work on, they seem really good.

mchaver 2 hours ago | parent [-]

Without telling us what kind of code you are talking about it is hard to compare. I would say that is true for CRUD web code because there is so much out there that the LLMs can reference.

keithnz 2 hours ago | parent [-]

I work on all sorts as we have an IoT product offering.... embedded bare metal systems, web, backend IoT servers, Gateways, APIs, Import/Export Systems, Integrations with Manufacturing systems, accounting systems, Automatic Test Equipment. I've been coding for nearly 50 years now, so pretty experienced. What peoples comments seem to imply to me is that they haven't really gone full agentic coding, where you hone your context, your tools, and how you iterate and test with an AI agent. Where any mistakes an AI makes you make sure it can't do it again, you have it setup so your AI code reviews are honed to focus on the things you care about etc.

gdorsi 41 minutes ago | parent | next [-]

Software development is a quite vast discipline.

In my experience performance of LLMs can be surprisingly good on things that are not mainstream, like database engineering, and surprisingly bad at mainstream categories approached in an unconventional way.

That said, I'm amazed that you have 50 years of experience and still able to have the mental flexibility to adapt to new development paradigms.

As you imply, this stuff isn't simple to pick up, and is completely different on how we have done our job without AI.

keithnz 37 minutes ago | parent | prev | next [-]

gdorsi , it's not that hard to swap really, because the goal, designing systems, just got easier. I feel AI lets you be a system engineer way better as you can quickly iterate. I have the same kinds of goals in mind, just can do it a heck of a lot quicker.

hubertdinsk an hour ago | parent | prev | next [-]

so not niche at all. You described a bit of everything.

Niche is more like "ISO26262 compliant, response time under 50ms, measured with a oscilloscope with at least 40MHz bandwidth, failure rate less than 10^-7, proven with maths and soak tests". It gets more niche the closer you get to hardware.

Next word prediction will get you laughed out of the room.

keithnz 41 minutes ago | parent | prev [-]

hubertdinsk, can't reply directly... but yes lots of niche things, especially in the embedded side, automatic test side. We have a lot of hardware, we control a lot of things, sense a lot of things. There's nothing inherently complicated about it such that AI can't code, in fact you feed AI technical data sheets its insanely useful when writing code against that hardware. It's going to pick up on all the weird nuances. It's great for protocols, especially proprietary ones. Anything with spec sheets are good.

armchairhacker 3 hours ago | parent | prev | next [-]

AI can generate code much much faster.

But do you never need a specific change (e.g. bugfix), that even describing in English is slower than just doing it? Especially in vim where editor movements are fast.

jnpnj 3 hours ago | parent | next [-]

Anybody using cursor or antigravity ?

I tried them a bit and often they can infer immense amount of ideas from the immediate source context and suggest paragraph patches semantically close to what I had in mind from just one word.

Saying this as a vi/emacs user who liked to automate via macros, snippets, dynamic overlay inserts and what not.. I still enjoy being sharp on a keyboard and navigating source / branches swiftly but LLM can match and go beyond it seems. (not promoting them, feel free to stay in good old vi command sequences if that's fun for you)

armchairhacker 18 minutes ago | parent [-]

I’m using Sweep autocomplete, which is like Cursor’s but in JetBrains, and it’s very good. Most of the time, I start the change and Sweep finishes it. Sometimes for larger changes, it initially has the wrong idea, but as I continue it eventually figures out what I’m doing.

Unfortunately they’re sunsetting it, ironically apparently because people aren’t using it. I think it’s strange this hasn’t been posted to HN. They say they will release an open-source local version; otherwise I’ll have to figure out an alternative, because it really saves time and effort…

keithnz 3 hours ago | parent | prev | next [-]

possibly there's cases where maybe you want to change some text or something, but I don't think its faster in vim given you likely don't have that file open, and by the time you get to the file, and location, you could have fixed it with your agent, not only that, you could have generated the test case and then fixed in your agent

1718627440 2 hours ago | parent [-]

I think you missed the point. It takes more time to write English prose than to open a file and just fix it, so unless the time the LLM needs is somehow negative, it's not going to be faster.

keithnz 2 hours ago | parent [-]

I didn't miss the point, it just feels like the people saying that really aren't using these tools as it just is not my experience at all. I've been a Vim user for multi decades now. There's just no way, it's far easier to type a prompt except maybe if you know exactly what file and exactly where in the file, you might be able to do it as fast as telling the AI to do it. It's not hard to get a minor fix done with a prompt and doesn't take too much English in my experience.

skydhash 5 minutes ago | parent [-]

Maybe it’s hormones, but time flies when you do edit with Vim or Emacs. It’s like playing on a piano. But using AI is like listening critically to someone playing trying to find mistakes. And that’s boring as hell.

zhann_dc 3 hours ago | parent | prev [-]

I'd argue you should be working towards no longer having to do these because agentic systems in place will do it in your stead.

All you need to do now, is sign off the code and adjust the agent so it would do these as you would.

bandrami 4 hours ago | parent | prev | next [-]

You're forgetting to count the time you spend deleting the excess stuff

keithnz 3 hours ago | parent [-]

no... I'm not.

otabdeveloper4 2 hours ago | parent | prev [-]

Note you're replying to a guy who never said anything at all about being "faster".

P.S. Software developers aren't being paid to be "fast". In fact, being "fast" is called "technical debt" and you're usually punished for it as a software developer.

xenodium 3 hours ago | parent | prev | next [-]

I put off adopting popular agents for most of 2025 primarily because there was no agent-agnostic path to first-class Emacs integration. That changed with ACP (https://agentclientprotocol.com), thus I started working on agent-shell.

I'm happy with how the integration is shaping up, enabling me to have my cake and eat it too (Emacs + AI agents).

I wrote an agent-shell post recently with the latest changes https://xenodium.com/agent-shell-0-47-1-updates

hbogert 2 hours ago | parent [-]

You have Every right to plug your agentshell here. I love it and I don't even care that much for agents (yet)

mark_l_watson 13 minutes ago | parent [-]

I agree, agentshell is a nice way to chat with LLMs. Well worth setting up. Emacs eye candy.

szopa 5 hours ago | parent | prev | next [-]

I have been a die hard emacs user for 20 years, and I have a very nice emacs setup (if a little bit idiosyncratic, but all emacs configs are idiosyncratic). However, recently I realized that I read code, but almost never write it. What is more, I spend a lot of time doing it in tmux, over mosh, from my phone. Emacs ergonomy is just not great if all you have is a horrible phone keyboard (and no swiping, because tmux redraws the screen if you swipe). And then I discovered helix. It has all the things I was jealous about vim, BUT it has sane defaults ootb. And truth be told, another thing I use a lot is bat, which is cat with syntax highlighting and an automatic pager.

truncate 4 hours ago | parent | next [-]

>> recently I realized that I read code, but almost never write it.

I think most engineers are reading code than writing it. I find it very hard to not use Emacs when reading large codebases. Interestingly, its mostly because of file navigation. I love using ido/ivy for file navigation, quickly filtering through buffers, magit.

Emacs in terminal is not an ideal experience though. So I can imagine it being multi-fold worse with phone keyboard.

johanvts 4 hours ago | parent | prev | next [-]

Emacs has multicursor, lsp and treesitter so from just reading the helix landing page idk what you gain? Bat sounds interesting, thanks.

locknitpicker 4 hours ago | parent | prev [-]

> However, recently I realized that I read code, but almost never write it.

This has been the norm for a few decades. Even software engineering courses emphasize the fact that code is read far more often than it is changed, which leads to all the basic software engineering principles around the importance of making code easier to read and to navigate through.

danebalia an hour ago | parent | prev | next [-]

I gave up on emacs and vim. Its like fighting bad design. Im long time users of both, but no plugins sufficiently provide a quality integrated experience with AI, MCP and agents. Emacs and neovim AFAIK are not designed for streaming. And with what each of them do, you can just build an IDE yourself (Claude Code). I combined with Vim bindings, spacemacs interface and built an IDE from scratch in one week with Rust. Its my daily drivers. This is true customization.

specproc an hour ago | parent | prev | next [-]

I'm a long time VS Code boy, but have recently started dabbling in Vim because I'm exhausted with AI.

Every VS Code update these days feels like it's exclusively AI orientated. The Vim approach seems fundamentally opposed to an AI-driven development model, or at least says, like everything else, "sure, you can do that, but set it up yourself."

I find the Vim philosophy appealing coming from a work environment that wants to replace me with API calls to American companies.

jwr 2 hours ago | parent | prev | next [-]

My time spent in Emacs has *increased* with the increased use of AI. I have to read, edit, accept and reject all those code changes and Emacs+Magit is pretty much the best interface for that.

TYPE_FASTER an hour ago | parent | next [-]

Yeah, I’ve been using IntelliJ for a few years but recently tried the Claude-code package and magit and it’s a pretty great combo.

mchaver 2 hours ago | parent | prev [-]

I will have to checkout Magit, but, as an already heavy Emacs user, my time in Emacs has remained constant even with increased use of agentic coders.

beemboy 5 hours ago | parent | prev | next [-]

I'm not convinced that terminal orientedness of AI tooling itself will last. My hypothesis is that it was chosen by developers of the current generation building for developers of the current generation. I hypothesize that there is a future where command lines and terminals don't matter, and hence I feel the focus will shift to, as the author points out, to planning, reviewing and ideation tools none of which demands a command line. In fact I expect an entirely new class of tool to emerge that does these things well that is neither an IDE nor terminal based. I think Claude Code's core will live but it's interface will morph in the coming years to adapt to the builders of the next generation. The analogy I use is my kids and manual transmission cars -- they grow up with EVs and single gear drives with linear torque curves, and will have no nostalgia for a manual transmission, engine noises, or supercharger whines. If you never used a terminal, will you pine for it?

vohk 4 hours ago | parent | next [-]

I'm not about to put any money down - I lack that degree of confidence in my prognosticating - but I doubt the terminal will ever really vanish, for much the same reason that 20 years of touch screens hasn't really put in a dent in a keyboard and mouse for serious work, and game controllers have barely changed despite multiple attempts at VR and other interfaces, and why the stylus is still going strong after more than 5000 years. Sometimes you just get it right.

A text interface is just really damn good at efficient and precise information delivery and interaction, in a way that takes a lot more work for a GUI to match, and they are composable in a way GUIs simply are not. Most users won't - and currently don't - care about terminals, but I doubt it will ever stop being a standard tool for power users.

I don't doubt we'll see new paradigms emerge, but I think they'll come in the form of higher level abstractions for certain classes of task rather than a replacement for the sort of TUIs and GUIs we have today.

ffsm8 an hour ago | parent | next [-]

> but I doubt the terminal will ever really vanish

I always smiled when in the various Star Trek series (pre 2005) the main crew made something in the holo deck it was always via voice commands and essentially "vibecoded", but whenever details mattered (veeeeeeery rarely, almost never) and a specialist was consulted, that'd be someone clearly looking at a mobile terminal interface

It's obviously fiction, but it amused me nonetheless... And it's possible that that's the future of our industry. But if it is, it'd consider it a dead industry, honestly. Even in that fictional universe, the value the specialist provides is almost never necessary

i_am_a_peasant 3 hours ago | parent | prev [-]

Yeah, I can’t imagine why anyone would think that moving away from the most explicit source of truth possible would make AI work any better. the things good UIs excel at is data representation, not processing. Representing a tree or a graph in text sucks. But AI can sure read a text representation of a tree or a graph and reason about it much faster than through a UI

rtpg 4 hours ago | parent | prev | next [-]

This stuff stands on the foundations it's built off of. It's very hard to argue against the stoic determinism of an `ls` call.

And all the success stories I've seen in people using these tools have had a similar theme: top level might be LLM-y but you rush to get to deterministic straightforward building blocks so that you can have reliability.

That, to me, looks like writing up a bunch of small programs to help establish vocabularies and workflows to avoid just churning and getting lost in the weeds.

I'd be interested in seeing some future form of process orientation, but in the meantime.... shells in general have proven they are decently good at tying stuff together quite well.

`ls dir | grep thingy | process` gonna involve less possibility of annoying drift and churn than "run process on all the files with thingy in their name in directory"

discardable_dan 4 hours ago | parent | prev | next [-]

Coining this phrase now: "It's the tokens stupid"

Hooking up to and generating calls across filesystem APIs cost multiple orders of magnitude more than calling `ls`. These tooling ideas are interesting, though. Maybe Kenneth_E._Iverson was right all along?

Talking to another senior dev over drinks tonight, we both worried not about our work but about who might come up never having written a single line of code. Never even opened a terminal. Is looking at the code something you learn in semester 5?

I think computer science education is going to stomp onward, poorly. And we will get that generation. And things like "terminal tooling is going out of style" won't even be said any more. Hacker groups will turn from discussions about new ideas to talking about doing leetcode without AI.

Our art died because we used our art to kill it. We are the last human masters.

That's a funny thing to think about.

simianwords 2 hours ago | parent | next [-]

>Hooking up to and generating calls across filesystem APIs cost multiple orders of magnitude more than calling `ls`. These tooling ideas are interesting, though. Maybe Kenneth_E._Iverson was right all along?

I don't think you understood what the idea was. Its not about calling `ls` vs not. I don't think UNIX commands are going away (or at least deterministic calls).

Its the interface itself that would go away. We won't work on terminals but some other interface which would use commands internally.

HKH2 an hour ago | parent | prev [-]

Yeah, in the future we will mourn the loss of the art of creating a new JS framework every week.

rekrsiv 4 hours ago | parent | prev | next [-]

A terminal still offers a more composable interface than a GUI. Analog feedback is still a concern for high level pilots. You are confusing power tools with entry-level instruments.

simianwords 2 hours ago | parent [-]

interesting, what do you mean by composable?

hbogert 2 hours ago | parent [-]

Albeit it's the shell, I assume he means piping

simianwords 2 hours ago | parent [-]

That has less to do with terminal than unix commands no?

hrmtst93837 2 hours ago | parent | prev | next [-]

The end of terminals has been forecast ever since mouse pointers showed up. If you build any nontrivial workflow across weird infra and hairy edge cases, GUIs locked to whatever version of "AI assistant" they're pushing will either make you faster or block you until you rage-reopen a shell.

I think there will always be a class of tool for users who want escape velocity from vendor UX conferences and forced upgrades. The moment sandboxes or walled gardens get in the way of the weird things that keep devs productive, someone will bolt a CLI to the latest AI.

mrtz 3 hours ago | parent | prev | next [-]

I'm somewhat agreeing with it. CLI tools won't go away, since lines of text as an exchange format between tools is extremely powerful, especially with text based LLMs. However using an interactive TUI application to prompt agents will probably be less relevant in the future. E.g. if I want to build a web frontend, why wouldn't I just prompt and interact directly on the side I'm building?

ManuelKiessling 4 hours ago | parent | prev | next [-]

My current assumption is that the interfaces and workflows that stakeholders and product owners use today to manage software engineering resources are the future interfaces and workflows towards agentic engineering systems.

kingkongjaffa 3 hours ago | parent | prev [-]

I think AI tooling has actually reminded us how useful the terminal really is. running claude code, running formatters and linters and test suites, managing incremental work with git etc. Are all vital in the modern way we write code. I don't see how you can put a glossy UI on top of that and maintain any fine-grained control. Since we're already giving up a LOT of control by having agents write our code, we need to retain some control and certainty over the quality control and review process of the outputs.

alexpotato 43 minutes ago | parent | prev | next [-]

> AI makes configuration and extension trivial

I recently said to a co-worker:

"Linux is free if your time has no value" is no longer true in the era of LLMs. Just about any wonky Linux issue can be fixed quickly with even just OpenCode and free models.

mvrckhckr 2 hours ago | parent | prev | next [-]

These were always personal preferences (I’ve used all types at different times and contexts), and I don’t think AI will have any major effect on their usage numbers.

rgoulter 8 hours ago | parent | prev | next [-]

May be splitting hairs, but I don't think it's the terminal-native part that's relevant, so much as that both LLMs and emacs/vim are text oriented in ways which e.g. VSCode isn't. (Or perhaps just the text-oriented nature is a result from initial constraint from being terminal-native).

As the author points out, that Emacs is a highly extensible 'operating system' which makes it relatively easy to bring different tasks together. -- This ought to be a natural parallel to what the agentic tools are trying to do (use MCPs and skills etc. to bring different functionality to the LLM execution environment).

That LLMs can help users extend emacs ought to lower the difficulty curve.

Still. It's silly to wish that Emacs could be the LLM's best friend, rather than demonstrating how it is.

RE: "what if in the future all coding skills are irrelevant". My experience has been that good results from LLMs come from putting good thought into its usage. They're quite far from a magic "push the button and get the result you want" where the skill doesn't matter.

chamomeal 7 hours ago | parent [-]

Not totally related to your point BUT I’d like to tack on that lisps and generally repl-friendly languages are in an interesting spot in the LLM-enabled world.

The calva-backseat-driver vscode extension runs an MCP that lets LLMs manipulate and eval clojure expressions in a REPL. It provides a tighter feedback loop and lets LLMs do much more complicated stuff with much more confidence. They can test functions as they go, read docs, check query outputs, write and eval tests. It’s actually crazy what Claude opus can do with REPL access.

It might be insanity to let an LLM modify your emacs on the fly, but I’m sure people will have some crazy and interesting ideas in that vein!

minikomi 3 hours ago | parent | next [-]

I don't let it execute emacs lisp itself, but elisp generated in org mode babel blocks which is instantly executable is a fine way to have gptel improve itself.

( See "meta tooling" in https://poyo.co/note/20260202T150723/ )

FabianCarbonara 6 hours ago | parent | prev [-]

This is super exciting. Emacs already treats UI as just more Elisp to eval. The AI could sculpt the entire editor to whatever you need in the moment. No plugin to install, no config to maintain. Just describe what you need and the editor becomes it.

dbacar an hour ago | parent | prev | next [-]

I dont know what the deal is with these editors that makes them on HN front page so frequently. In my opinion they are good text editors (used emacs for 4 years, and switched to vim nearly 10 years ago) but for coding I see them as a joke apart from some edge cases(clojure, lisp...). They are hard to setup as code editors, lots of customizations are needed and in my opinion it does not pay off.

ywatanabe1989 5 hours ago | parent | prev | next [-]

In my view, Emacs is getting more powerful in the AI era. The cost of writing Elisp has dropped significantly — I've ended up with 15+ personal Elisp packages as a result. The freedom Emacs offers is still unmatched. For example, I heavily rely on sending automatic response (https://github.com/ywatanabe1989/emacs-claude-code), monitoring repository, and targeted context building from dired.

johanvts 4 hours ago | parent [-]

Fully agree, but it is also the buffer based navigation approach that is just fantastic. I wish other programs would adopt this. Most applications use dedicated areas for various functions, instead of letting me just hit a key to bring the function to where I am currently looking.

gbro3n 5 hours ago | parent | prev | next [-]

I'm a muggle when it comes to vim, but I've considered learning it again recently because of AI. I'm building more than I have in years because I love being able to try things out without investing 3 months to get something working before I can really test the idea. And so I am typing A LOT. Less code, but lots of markdown, prompts and config. My hands are hurting, I really wish I had a power tool for typing. Writing is always going to allow us to be more precise than speech, and is a tool for creative thought in its self. I can see how we might be bearish on our expectations around new adoptees, but I think there's pressure to get more out of our editors too. Two of my recent projects have been vscode extensions, because I'm needing more help from my editor, not less: https://www.appsoftware.com/blog/fixing-agent-llm-context-de..., https://www.appsoftware.com/blog/as-notes-turn-vs-code-into-...

arcanemachiner 4 hours ago | parent [-]

Start using speech to text more. You likely have the hardware needed to run a Whisper model locally.

gbro3n 3 hours ago | parent [-]

I will give a go. But my rambling mumblings to Gemini on my phone sor far confirm that I write with more clarity than I speak

igor47 7 hours ago | parent | prev | next [-]

Agreed on the config. I just launch a Claude code in my vimrc directory now if I want to change anything about my setup or have any questions about how to do something.

Also, I love running a tmux pane for vim, and then like 4 or 5 more -- a few Claude code instances, one for the dev environment, one for interacting with jj/git or other random commands. So easy to switch between tasks. My main annoyance with my setup is that my Bluetooth trackball times out after a period of inactivity, and when I eventually need to use the pointer again there's a lag while it reconnects...

pjmlp 4 hours ago | parent | prev | next [-]

I lived in XEmacs between 1995 and 2005, because in many UNIX variants having an IDE was a foreign word, not even something that could provide the affordances of a Turbo Pascal with Turbo Vision based IDE for MS-DOS.

Between Emacs, the improved XEmacs, and vi, the answer was obvious at the time, I joined the Emacs faction with XEmacs.

Mastered elisp good enough, had my configuration scripts, go to know enough vi to handle telneting (or sshing) into random UNIX servers without anything else installed.

Both are still kind of stuck in time, going back to them in random UNIX distribution feels like I am back in that UNIX decade.

lelanthran 6 hours ago | parent | prev | next [-]

Yeah, I use Slime in vim to drive programs (like psql) via their stdin/stdout, so an "agent" that does stdin/stdout only for UI is perfect.

If I ever write my own agent, it will be in this fashion.

-----------------

[1] I have a `scratchpad.sql` file filled with whatever sql snippets I am testing and have `psql mydbname` in a vertical split. Doing C-c C-c in the scratchpad sends the paragraph to the psql instance.

small_model an hour ago | parent | prev | next [-]

Not sure these and other editors have a future when the SOTA models can generate code better than 99% of the best devs in the world 100x faster, 10x cheaper and never get tired or want pesky time off. Maybe the use case it to view code while humans are still required in the loop (I think they just about still are) or to edit a commit msg.

marwanet 4 hours ago | parent | prev | next [-]

I suspect terminals will stick around longer than people expect. Not because they’re ideal, but because they compose well with everything else.

dsrtslnd23 4 hours ago | parent | prev | next [-]

I think a terminal is still the perfect UI for coding agents on desktop systems. But now that I have running agents in background that only sometimes require some extra input on the go - I hate the terminal use on the go: terminus or other mobile app + virtual keyboard is horrible to use. For that I envision a better interface.

lorenzohess 6 hours ago | parent | prev | next [-]

Agreed.

We should also consider whether the rise of AI for any type of implementation task will reduce the number of new Emacs and Vim users, thereby limiting and ultimately killing the communities' growth.

I came to Vim, and then Emacs, because I wanted a tool for coding that I could configure exactly how I liked. If AI does my coding for me, my need for a custom editor will decrease. More generally speaking, if AI can do any type of implementation task -- coding, task management, email, etc -- my need for software customized for those things will decrease.

If people don't need custom software, many fewer people may seek out and find Emacs and Vim.

Who will maintain them and evangelize once today's generation cannot?

nine_k 6 hours ago | parent [-]

If implementation of anything is easy, far fewer people would be needed to keep the projects alive.

AI is okay at doing simple things, but it needs to be overseen. Even before any viable AI, I used to read code more than to write. And Emacs is a good tool for that.

Then, Emacs specifically has a killer app, Org mode. For me, it's about as important as good programming modes, if not more

More importantly, Emacs is a platform (as is Neovim, and VS Code). It adjusts to the needs of the user and the moment.

AltruisticGapHN an hour ago | parent | prev | next [-]

You can have Vim bindings in vscode.

worksonmine 17 minutes ago | parent [-]

The keybindings are just the tip of the iceberg for most vim users.

stephc_int13 5 hours ago | parent | prev | next [-]

How much of this article was AI written? I can sense the AI smell all over the place, also I found it way too long with little substance, but maybe that’s just me.

acron0 4 hours ago | parent | next [-]

Bozhidar always writes like this. I can see why you would think it's AI style but I would vote that it isn't. Look at some of his pre-AI blogs, if you care to.

bozhidar 10 minutes ago | parent [-]

Guilty as charged! :D Short essays are definitely not my forte. (and this one is definitely longer than I wanted it to be, but in my typical style I kept adding to it after I wrote the initial version, and I'll probably add even more content after I go over all the discussion here)

bozhidar an hour ago | parent | prev | next [-]

Well, I guess that means I'm still a pretty poor writer. :D (I'm the author of the article) These days I do use AI to touch up my grammar and fix my typos, but I'm still write my articles myself and you feel that the article lacks substance - that's on me.

For me essays are something very personal, so it'd hard for the AI agent to read my mind about my thoughts on a subject.

operatingthetan 5 hours ago | parent | prev | next [-]

At this point a lot of the articles on this site are just a 'prompt' for us to have a discussion about.

bozhidar 13 minutes ago | parent [-]

Well put! To me - it always felt like this here. I have serious doubts that most people even read the articles linked to HN discussions.

gbro3n 4 hours ago | parent | prev [-]

I didn't get that feeling. But it is long, which is a bit of an AI smell. That said, I think use of AI in writing might not always be a negative. On a couple of documentation pieces I have used AI to provide better structure to writing that I've started and check for technical correctness parts of a document where I need to check my terminology. As long as the original idea is human and AI helps to make the signal clearer, I'm ok with it.

keithnz 4 hours ago | parent | prev | next [-]

vim (neovim these days) for me is my text editor I use to look at code when dealing with AI, more often than not I'm working on a bug list as I test things. I haven't opened my IDE (Jetbrains tools) for nearly 2 weeks now. Only thing I often want is to be able to run sql queries, I used datagrip for that... Now I'm writing my own tui sql tool that is lightning quick and has most of the features I like from data grip, plus a bunch of new things that make my life easier. I've made it work as a MCP server also so that I can get my agent to directly inject queries and I can browse the result sets easily. I feel like the terminal, because its text based and super great at manipulating text is such a perfect match for these AI agents. But, yes, the need for code editing itself is really limited.

athrowaway3z 5 hours ago | parent | prev | next [-]

I have been an emacs user for almost a decade now.

My laptop taskbar is: terminal, filebrowser, emacs, firefox.

With emacsd running to make startup instance.

This week I removed emacsd service and Emacs from my taskbar because I had more miss-clicks - accidentally opening it - than I had need for it in the past few months.

layer8 3 hours ago | parent [-]

What’s interesting is that as an Emacs user and caring about instant startup, you use clicks to open things instead of keyboard shortcuts.

gitaarik 4 days ago | parent | prev | next [-]

With the idea of the recent HN article that files are the common media of communication between humans and LLM's, it's still useful to have direct file-skills; to be able to read raw files the LLM outputs, or give it input through files, and able to manipulate the files efficiently. You can use an LLM to prompt to search through the files and all that, but for such basic things it's worth learning it yourself, if you do it often.

lenkite 5 hours ago | parent | prev | next [-]

If AI companies don't break even and continue to remain in 2 digit billions and more growing debt, all these are nice cookies that can be taken away at any time with a 5-10x increase in price.

baokaola 5 hours ago | parent | prev | next [-]

I find Emacs better than ever in the age of AI. Install agent-shell to run Claude Code inside Emacs and give it a skill to run Emacs Lisp using emacsclient. Voila - now you have all the integration you could ever need if you are a little resourceful.

Claude Code can now introspect the entire editor and it can manipulate everything. You can have it build whatever features are missing - it will even debug those features for you, live in the editor.

I recently came back to Emacs from VSCode and ended up just letting Claude build me the features I was missing, mainly related to tabs and project management.

I think Emacs has unique advantages in the age of LLMs, you can just mold it like clay.

4b11b4 8 hours ago | parent | prev | next [-]

learning and using and customizing emacs has never been better

getting a bibliography and citation workflow up and running in org is incredibly easy. Use a model to read the first page of your PDFs dir and add bibtex entries...

then you just build your static site around that

please don't write with a model. We want your own prose

jaypatelani 3 hours ago | parent | prev | next [-]

Hmm.. asistant i can't escape this screen what is it?

A.i: this is vi text editor.

Human: exit from it and open word processor.

A.i: rm -rf /

Human: good job exiting. Now where's my word processor? ....

Hello? Where's my word processor? Brint it on screen.

Can you hear me ?

emporas 6 hours ago | parent | prev | next [-]

In my mind I had the opposite picture than the one the article portrays.

Emacs was lagging behind common IDEs, like IntelliJ and VsCode, cause big companies put thousands of developers to combine many features into one integrated package and everything works together providing a very smooth experience compared to Emacs (and Vim probably).

Now IDEs are useless. I personally haven't felt the need to goto_definition or autocomplete variable names for almost 2 years.

Now programming becomes closer to plain text writing and editing and it levels the playing fields for all editors.

Also Emacs can run Rust plugins, the user is not limited to Elisp. Not very convenient but possible.

globular-toast 4 hours ago | parent [-]

> Now IDEs are useless. I personally haven't felt the need to goto_definition or autocomplete variable names for almost 2 years.

So you are vibe coding? Some of us still check every line of code generated and an IDE definitely helps with that. Even more so when you need to take control.

codemac 6 hours ago | parent | prev | next [-]

emacsclient + codex has been a game changer.

I probably add or change a feature in emacs once a day, or every other day. I've been using emacs for some insane amount of time, maybe 20 years? And still I had more customization to go.

Emacs and programs with it's level of programmatic user customization will survive the AI period in my opinion. Anything static will falter.

globular-toast 4 hours ago | parent | prev | next [-]

Emacs is a true bicycle for the mind. It sets you free in many ways, always wanting to be the tool that simply allows you to do your job more efficiently and effectively.

LLMs are like living with a depressed person who doesn't see the point in doing anything because it's all just been done before. Who cares if you do a good job? Just recycle some shit that others have done and it'll be passable. This isn't a bicycle for the mind, it's just going to drag you into depression with it.

dvrp 3 hours ago | parent | prev | next [-]

¿Por qué no los dos?

imiric 6 hours ago | parent | prev | next [-]

> Part of the case for Emacs and Vim has always been that they make you faster at writing and editing code.

That was a side-effect of using software that is deeply customizable, but not the main goal. It comes from being comfortable with your tools to the point of relying on muscle memory to use them. The main benefit to me has always been comfort. My favorite commands are a keystroke away, I know how the tool will react and what it's doing at any moment, I know all of its quirks, etc.

None of that changes in the age of "AI". This new technology won't replace computing for me. My hurdle to adopting "agentic" workflows has nothing to do with my choice of tools, and everything with not trusting the companies and ecosystems around this new tech, especially during this insane hype cycle. I've been slowly adopting parts of the stack I'm comfortable with, because, again, my comfort trumps anything else.

Besides, if anything, a deeply customizable platform like Emacs is ideal for building any type of workflow. There are already great packages for LLM integration, and I don't think Emacs users are missing out on anything. The fact "AI" companies decide to build their moats with custom tooling is not a problem I care about. Apple has been pushing their idea of what computing should look like for decades, and it has never appealed to me. I don't miss something I don't want.

Anyway, confusing article. The author acknowledges all of these points, but also the alternative scenarios. Both cannot be true for the same person. There will always be people who enjoy using Emacs and Vim because of their customizability, not necessarily their features. And there will always be people who just want to use a supported and official product, without any tinkering. Emacs and Vim will outlast this hype cycle just fine.

Thanks for all your work, batsov! I do hope you stick around these communities. :)

submeta 3 hours ago | parent | prev | next [-]

For me, AI increased my NeoVim usage. Claude Code and Codex made me go full cli. I run several sessions in multiple tabs in WezTerm, using Tmux, Tmuxinator, and excellent tui based file manager named Yazi in left pane, opening files in NeoVim, running Claude Code in right split. With this setup I work on several projects in parallel. Use lazygit as git client. Everything in cli, super fast.

Initially I went with Cursor, but the terminal setup feels way faster, more natural.

komali2 4 hours ago | parent | prev | next [-]

> Imagine an AI assistant that can read your org-mode agenda, draft email replies in mu4e, help you write commit messages in Magit, and refactor code in your source buffers – all within the same environment, sharing context. No other editor architecture makes this kind of deep, cross-domain integration as natural as Emacs does.

I've been a devout emacs amateur for 10 years, and recently learned nvim/lazy.vim because I was tired of web dev kinda sucking in emacs. Sure, you can get a setup with lint-on-save, inline TS errors, and all the other bells and whistles you get in vscode working on a react-tsx project, but then when you `helm-projectile-switch-project` to a vue project, suddenly you have to get a whole new config set up. And oops, for whatever reason, tab spacing isn't being pulled from the editor config for this directory...

But like the author says, LLMs fixed that. I pointed Warp at my emacs config, said my problems, and said "fix plz," and it did. No more "oops," just "fix plz" whenever I'm editing rust, or svelte, or golang, or whatever else for the first time in emacs.

I'm very excited for the possibility in the portion I quoted. I moved away from mu4e and org mode because managing it all was getting tedious: too much time procrastinating by tweaking org configs. Too many emails not rendered properly in mu4e or fat fingered by me and lost. But in world+llm, that's not really a problem anymore. I haven't migrated back to org mode yet but I did an experiment recently asking claude to set up org similar to my trilium set up, and it did a passable enough job that I was convinced it's possible.

So, now I'm back in emacs, trying out the various LLM tools, doing poorly at getting anything other than copilot to work well, and waiting with patience and desperation for someone to make an LLM completion experience in emacs that has a multiline completion experience at least 50% as good as Cursor's.

shevy-java 5 hours ago | parent | prev | next [-]

> The learning curve argument gets harder to justify too. “Spend six months learning Emacs and you’ll be 10x faster” is a tough sell when a junior developer with Cursor can scaffold an entire application in an afternoon.

IF this is the case. But is it?

I have some doubts because to me it seems as if domain knowledge is shifted onto an AI. Then you become dependent on the AI. Is AI really better than a skilled human though? After all, if AI is doing the work and the human providing the input to it as guide, it should be possible to cut away the human completely. So Skynet 3.0 does not need humans. But when it does, then something doesn't work in that explanation - AI must thus not be "smart enough".

dude250711 41 minutes ago | parent | prev [-]

Emacs and Vim in the Age of Slop