![]() |
|
![]() |
| > The average developer averages 10 lines of finished code per day. And even with a raw 10x that amount to account for variance, changes, debugging etc, you'd be at 12 lines PER HOUR. Being generous at a full 80 chars per line, you have a maximum of 1000 keypresses per hour, or an average of one every 3 seconds. Even doubling your typing speed or keyboard response time would have no discernible effect.
Just my personal experience, it's not about how fast I can get my ideas down in writing (whether code or not), it's about how often I am broken out of the flow when typing. At one extreme, using your stats above of "10 finished lines of code per day", you could argue that using this keyboard (https://www.youtube.com/watch?v=9BnLbv6QYcA) should have no effect on your productivity, and yet no developer would make or support this argument. Small frictions add up; there's a joelonsoftware post that I read a long time ago about this[1], and it stuck for 24 years! The best editor/environment is the one that gets out of my way. One where I don't need to look things up on google. One in which I have already learned all the shortcuts, and don't need to relearn them to make the software useful. Emacs `M-x sql-connect` is much easier for me to do than to look up, in VS Code, what shortcut has been assigned to the extension I use that does the same thing, and then look it up again in a few years when that extension is no longer supported. Same for Vim commands. Using VS Code, or a full-fledged IDE[2] removes the whole command interface: I now need to remember dozens of key-chords, not a handful of verbs and a handful of nouns. I need to remember which menu, and which submenu needs to be clicked. Each time I want to do something in the IDE I switch focus from the code to the IDE. When in Vim or Emacs, that never happens! The "keyboard maximalism" isn't about speed == productivity, IME. It's about "friction == disruption". -------------------------------------------- [1] From https://www.joelonsoftware.com/2000/04/10/controlling-your-e... > So that’s what days were like. A bunch of tiny frustrations, and a bunch of tiny successes. But they added up. Even something which seems like a tiny, inconsequential frustration affects your mood. Your emotions don’t seem to care about the magnitude of the event, only the quality. > And I started to learn that the days when I was happiest were the days with lots of small successes and few small frustrations. [2] Which I use daily, btw. I'm not knocking the developers who use IDEs. |
![]() |
| I tend to keyboard minimalism myself: doing as little typing as is required to produce the code. I.e.: lots of keyboard macros. Thus reducing the cognitive load of typing to a minimum. |
![]() |
| To paraphrase an old quote, "every new text editor grows until it is bloated with collaboration and AI features."
Thank god we still have vim and Emacs. |
![]() |
| A lot of editors are being discussed here but I see nobody has mentioned Kate (KDE's Advanced Text Editor) [1] in the conversation yet, so I'm doing it. Kate is a very mature and capable editor, and even if I only use it on Linux I'm glad to know that it is also available on macOS and Windows. It natively supports LSP and has much, much more to offer in terms of project management, support for build system, support for working with Git (it's actually the only Git GUI that I found to be usable), SQL databases integration, and of course, advanced editing features. I started using it a few years back after a very long text editor journey: on Windows a bit more than 20 years ago: Notepad, HAPedit, then Notepad++ ; then I got a Mac and used TextMate (which introduced me to powerful text editors) for a few years ; then I switched to Linux ~15 years ago and used Gedit for a few months before diving head deep into Emacs and stayed fully there for… 12+ years (I actually still use it from time to time, but it's less and less the case and most importantly I stopped doing everything in it including my email, social networking, IRC, etc.) ; and now for a few years I've mainly been using Kate (and Kwrite for quick edits + Nano [2] in the terminal or on remote hosts). I even contributed a few features [3] to the project, KDE developers are very welcoming!
[2] I must say here too that Nano is actually an underappreciated gem. It supports a lot more features than people generally imagine: syntax hilighting, line numbering, auto-indent, multi buffers, mouse support, keyboard macros, … it's actually a decent simple code editor! [3] https://kate-editor.org/post/2022/2022-08-24-kate-new-featur... |
![]() |
| Yes, it's a great editor. It's one of the members of "Great, but Unknown Tools" group.
I use it for mainly writing small Go programs in these days. Bigger projects are promoted to Eclipse. |
![]() |
| I’m using Kate to write posts on https://oilshell.org! After a detour through many other tools, it’s great to find something open source and high quality.
I use vim to edit code, but I like copying and pasting paragraphs of prose with a mouse. I didn’t realize that until doing a lot of writing. |
![]() |
| Helix has been trying to implement a plugins system for like 2 years that should tell you everything you need to know about its future prospects |
![]() |
| Big fan of helix and am in this camp. Used to have a bunch of plugins for neovim, but in Helix, honestly just haven't felt the need for anything besides what it comes with. It's a great editor. |
![]() |
| Many helix users have their own fork to scratch that itch. I do too, and it's nice, but of course a little more maintenance than a set of scripts |
![]() |
| It can't really be simpler than Lua, come'on. Maybe if you already know Lisp, but for people who know C-like languages (Java, Javascript, C++) Lua should be much more "obvious". |
![]() |
| Just use https://astronvim.com/. I haven't touched my config for more than a month. With astronvim community, other people do the hard work.
I also tried the "pure" config from scratch way but its just way too much work to maintain, esp if you want all the goodies. Also, not an expert in Lua so my config sucked. Simply better to use an existing, well-maintained neovim distro. I tried all of them and liked astronvim the best. |
![]() |
| I don’t know. That feels perfectly reasonable for what I imagine is 99% of all developers, so while sad, I can imagine why that use case is not very high on their list of priorities. |
![]() |
| I assume all of these are some special combination of keys/modifiers? While I agree it’s less than ideal, at least you always know it’s going to happen if you are sort of familiar with Vim. |
![]() |
| > Every now and then I would update a plugin in Neovim and everything would break, and I would have to spend time fixing it instead of getting work done.
This is true, but only if you're not using one of the ready made distributions. I didn't switch to NeoVim until I discovered LazyVim and this amazing guide https://lazyvim-ambitious-devs.phillips.codes/. That changed everything. I just use LazyVim out of the box, as if it was a Jetbrains IDE. No config hassle, no issues with updates. It just works. Regarding Zed: It's a small niche they're trying to fill in a very competitive market. Currently they have the advantages of being the current cool thing. But that's not enough in the long run. If I would knew some killer feature, I'd go ahead and write it here. But that's the thing, I can't think of any. For simple, mainstream usage, VS Code is there. Ulimate IDE features: JetBrains IDEs. Ultimate productivity: LazyVim (or other NeoVim setups), ootb modal editing: Helix. |
![]() |
| I wouldn't mind the license fee as much if there was actually any development going on, but for the past 3-4 years, there has basically been 4-10 months between releases, and each release has been more or less bugfixes and rewrites [1]. There has been 4 updates in 3 years.
The issue tracker for ST has 1863 open issues, or 41% open vs closed issues [2], and the issue tracker for SM has 1055 open issues [3]. I have no problem paying for software, and i understand that most developers don't work for free, but with this software it doesn't even appear i'm paying for "work", and instead it appears to be more or less a passive source of income for the developer. As i wrote earlier, i'm not entirely sure what i'm gonna do, but given the slow pace of improvements to ST, i guess i can easily wait a couple of years before updating, if ever. [1]: https://www.sublimetext.com/blog/ |
![]() |
| The article specifically mentions following chris@machine, so I would assume that LunarVim was on their radar. But I agree, it seems odd that it wasn't mentioned in the article. |
![]() |
| Over the summer I got an interest in Kakoune and Helix and discovered a number of extensions for VSCode that enable modal editing(1), but not VIM-style per default. I got excited about this and ended up writing my own extension instead.
At this point, it supports most of the VIM subset that I care about, and I have added a number of new motions and modes that do clever things based on the AST. I am kicking myself for not doing this sooner and I think I need to write up a blog post about it. It's surprisingly easy. 1. e.g. https://marketplace.visualstudio.com/items?itemName=DCsunset... |
![]() |
| I feel like using this extension is a little buggy. Especially around undo / redo actions being captured in “format on save” type actions that happen thanks to jslint or other tools. |
![]() |
| > but always run into some annoying bug, usually due to an interaction with another extension or VSCode feature.
That has generally been my experience using VSCode, unfortunately. |
![]() |
| Yes, vscode-neovim makes VSCode's editor be Neovim. It works very well with other VSCode extensions. For example, you can type `gd` to go to the definition of a C++ identifier. |
![]() |
| I think that's the usual approach for Vim mode in other editors. But this extension in particular:
> This extension uses a fully embedded Neovim instance, no more half-complete Vim emulation! |
![]() |
| "It just works" is precisely why I use Jetbrains products. I'm amazed they are not that common in many developer communities. They are amazing tools. |
![]() |
| > Turns out some of my types were 80k characters long,
I know Rust uses name/symbol mangling but what sort of type declaration in Rust ends up with that long names ? |
![]() |
| They absolutely are the state of the art. At the same time, opening just three or four medium size projects brings the editor to it’s knees on my M3 Max.
I like having many projects open. |
![]() |
| Am I the only one scratching my head about how Zed will eventually monetize their business to satisfy the investors behind their $12M investment? |
![]() |
| My dealbreaker with Zed is that it takes away my autonomy and agency.
1. Zed downloads binaries without user input as soon as you open a file; think LSPs and linters. This is a hot topic and has been for a while.[0] I would rather my editor break (or even better, fail gracefully and helpfully), than obscure what amounts to being a significant action that I believe warrants user involvement. 2. I can't tell what gets sent to Zed's servers. I don't have time to audit all the code, but as an example, this PR, [Allow Al interactions to be proxied through Zed's server so you don't need an API key][1], has +3,628 -8,918 changes and even just by the title seems to suggest that using the Assistant feature may result in requests being sent to Zed's servers. This is a dealbreaker for me because, not only is this not documented anywhere, it seems in contradiction to the EULA. "User Content is transmitted from Your environment only if You collaborate with other Zed users by electing to share a project in the Editor. Once You share a project, Zed may transmit User Content consisting of file paths, file contents, and metadata regarding the code returned by language servers."[2] It doesn't mention if using the Assistant feature is part of the network based solution or that it's the same as "sharing a project," but I'm not an Editor-EULA lawyer. Arguably, this is true is any open source project, though my stance is generally to be more alert to privacy concerns with software from newly-backed pre-profitable startups. I don't want to spend my rare editor-tweaking time on nonconfigurable privacy and security control workarounds. Edit: As if on cue, another PR to seemingly default to sending data to zed.dev: https://github.com/zed-industries/zed/pull/16454 [0]: https://github.com/zed-industries/zed/issues/12589 [1]: https://github.com/zed-industries/zed/pull/7367 [2]: https://web.archive.org/web/20240718140959/https://zed.dev/e... |
![]() |
| I used Vim for around 15 years before switching to Neovim. I have no desire to go back.
In my experience Neovim is very reliable, even when building off `master`, which I did for a couple of years. |
![]() |
| Do you mind sharing that list of plugins you use? I have never used plugins with vim/neovim and only used them vanilla up to this point but interested in checking out the plugin ecosystem. |
![]() |
| >neovim is what happens when the javascript kids decide to "improve" one of the best editors ever created
I don't think that's accurate. Now, if OTOH you said "the Lua kids" then I'd probably agree. |
![]() |
| There are no Lua kids, i.e newbie programmers that start their career from Lua. The neovim Lua kids were JS kids all along, and brought their philosophy of churn over. |
![]() |
| It was a great sales pitch until the Linux and Apple comparison.
I can't take seriously someone, who says that Apple's stuff runs smoother (unless we are talking about useless animations). |
![]() |
| In my experience, yes. But you can't really expect a syntax highlighter to support every combination of template language and file language, so this seems reasonable enough. |
![]() |
| Heh, I saw this thread just recently:
https://www.reddit.com/r/webdev/comments/1euwht3/webstorm_is... Most discussions I've seen, including that one, say that VS Code is slower than most lightweight text editors but faster than most IDEs (including WebStorm which is IntelliJ). I don't personally have experience with IntelliJ, but in my experience VS Code is very noticeably faster than Eclipse. That linked thread also mentions that compared to IntelliJ, VS Code has better remote development, a less cluttered UI, better support for multiple languages in one project. And _many_ people mention the better performance. Personally, running an open-source project with a lot of contributors who are young or from third-world countries, it also matters a lot that VS Code is free. |
![]() |
| > VS Code is very noticeably faster than Eclipse
Even IntelliJ is noticably faster than Eclipse. This is a heavy indictment of Eclipse, not any other editors. |
![]() |
| I kinda lost hope for fleet when it just started loading the intellij core to do all relevant stuff. I wanted that new editor so it would be faster, not so that I can have slightly different chrome. |
![]() |
| The reason is simple: You write Java.
People using VS Code are writing JavaScript/TypeScript/Python that doesn't need full IDE features. And VS Code is much faster than Eclipse / IDEA kinds. |
![]() |
| > I’m sorry but having used both. VSCode is not faster
When you project your own experience over everyone else's it doesn't seem like you genuinely want to understand. |
I've never understood this. In over 30 years in the industry, I've not once held a job where my keyboard speed had a noticeable effect on my productivity. Even when I had to type one-handed for a month, my productivity was unchanged.
The average developer averages 10 lines of finished code per day. And even with a raw 10x that amount to account for variance, changes, debugging etc, you'd be at 12 lines PER HOUR. Being generous at a full 80 chars per line, you have a maximum of 1000 keypresses per hour, or an average of one every 3 seconds. Even doubling your typing speed or keyboard response time would have no discernible effect.
90% of software development happens in the mind. The small amount of time spent actually writing it out seems kinda silly to optimize for.