I found a different solution to the "getting around the screen" problem: set your keyboard repeat rate to 100 keys/s.
Upside: works anywhere, much lighter mental load, relatively easy to learn and adjust to.
Downside: some programs (ironically, mainly Emacs) can't keep up, and scrolling becomes choppy.
On Linux this is quite easy. When I was using Windows, there was no good solution for USB keyboards, so I hacked up a driver to do it: https://github.com/CyberShadow/KeyboardEmperor (signing keys not included).
Incidentally, high keyboard repeat rates is an important reason why I prefer spaces over tabs —- so that the horizontal cursor speed remains constant. (I’m serious.)
also, you can reduce the delay so that repetitions start sooner. With some practice and care you can reduce the delay to about 0.15 seconds and learn to fly over your keyboard
xset r rate 150 255 # delay=150 (milliseconds) rate=255 (keys per second)
at this point it's faster and easier to click left arrow than ^A, but of course it's not for everybody...
I once had someone tell me that they could edit text faster with a mouse than I could from the keyboard with Emacs. I should send this article to them. Smh
Emacs’ biggest drawback is that you are never using it to the fullest—an issue this article makes painfully clear to me. I guess it’s time to break out my config and tweak it… for the third time today…
This is a simplification of Unix history, but is in accordance with the fact that the first eager knon programmer) users of Unix were the people typing patents applications at Bell Labs.
See e.g. "unix, a history and a memoir" by Brian kernigan
I was thinking of it being sold to management as a typesetting system because Bell didn't do OS development. Unfortunately I don't have a reference immediately at hand.
That's funny. Not at all related but the Sidewinder heat-seeking missile got its budget from the fuses department, because it was "an intelligent fuse". (That's where it got its budget, but formally it was sold to management as "a rocket with fire control inside" because China Lake was allowed to work on rockets and fire control – they were expressly forbidden to work on guided missiles.)
"What if you simply arrive at the perfect time to every flight, neither too early nor too late?"
Nobody can ever do that, so it's pointless to ask.
(I suppose that if you built your own editor this might be true, but if you have your own plane then you're never early or late to your flight either.)
> Emacs’ biggest drawback is that you are never using it to the fullest
I think that this is actually a strength.
If you're using your editor to its fullest, then that means that there's no more room for you to improve. If your editor is simple, then its "fullest" isn't very good. If your editor is complex, then it took you a long time to get to its "fullest", and you hit diminishing returns a while ago.
Emacs is great because the skill gap is ridiculously high, while the skill curve isn't very sharp (Emacs' modeless editing is straight-up easier to learn than vim's modal editing, whatever other people might say), so wherever you are, you can always learn a little bit more, and be a little bit more productive...or continue to work with what you have.
That is - you can stop learning Emacs exactly when you want to - no sooner, no later. If you have a relatively simple editing task, you can just start it up, use the arrow keys to navigate, then save and quit (three keybindings total? find-file, save-buffer, save-buffers-kill-terminal). If you're anticipating starting a career in programming, you can learn and improve your skill with it (and your config) continuously for decades. I don't know of any other tool that's as good at this as Emacs is.
On a tangent, I would propose to you that Emacs' greatest weakness is that it doesn't come configured out of the box. It's way easier to set up VSCode to do Python than it is Emacs, and that's going to be the final factor for a large fraction of programmers. If two editors are equally flexible (which isn't actually the case with Emacs vs. VSCode, but bear with me), the one with the better out-of-the-box experience will win. (and this is why I think that starter kits like Doom and Spacemacs are the only way for Emacs to survive)
I should have added a "/s" in there. :) I'm 100% with you on basically everything you've said. I totally agree that the biggest weakness is how bad the default Emacs experience is. I used vanilla Emacs in a terminal for years until I discovered I could install packages. What a world that opened up.
> Emacs’ biggest drawback is that you are never using it to the fullest
I disagree, this is not a linear question. Emacs supports many different styles of working, and you aren't required to use anything to it's fullest. You might be using avy and other manipulation packages, or clicking around with the mouse (perhaps with your own commands bound to special kinds of mouse clicks) and it would be just as OK. You might always learn something tomorrow, but that shouldn't keep you from going on today.
Woah, really?? The only things I know about Scientology are SF writer on boat, snakes, something is called an e-meter, someth8ng about volcanos, and that they harassed my friend Keith for years.
Emacs really is an automation tool for text buffers/palette, the fact that code is text too is just incidental. Other wise the kind of tasks emacs is better suited for is changing text programmatically.
While Emacs doesn't have intelligent code awareness out of the box the way vscode does, its powers lie in providing out of the box commands to easily manipulate text.
To truly harness the power of emacs one has to get good good at thinking in terms of text. I tried org-mode but eventually realized emacs is actually restrictive when compared to using plain pen and paper.
Emacs definitely has its use cases, and is really in some way the original Perl. Or at least the Perl equivalent of a text buffer.
Oh man I had no idea you could perform actions with avy! Also didn't know you could jump between different screens. All I did was jump to spots, do something, then jump back. The teleport thing is going to be fun: "get over here" yanks line
I've got my avy configured to jump around by never using the pinkies. I use avy to move to any char in any Emacs "windows" and I also use it very extensively for many "menus" / drop-down lists, to quickly jump to a selection. For example I use it with counsel (from the same author, as mentioned in TFA), say I open the list of recently opened-file, I'll then "avy" to the one I want to re-open. Or I counsel-rg (calling ripgrep from Emacs, with the candidates shown using counsel): then I visually pick the one I want and I "avy" to it.
This is magical.
I know I could configure/use it for more stuff so I'll study TFA.
Hmm. I think I might be missing something — I've been using ace-jump to jump to any character for years now. I tried avy and it is significantly less efficient, requiring me to type 4 characters instead of 1 or 2 with ace-jump.
I just tried this out in conjunction with evil-mode and… it's perfect. `d <avy-jump command>` will delete from your cursor to the point you jump to. Might not be everyone's cup of tea, but boy is this going to be fun for me to use!
I've tried Avy a bit, but I prefer displaying line numbers and jumping with Evil. While the former needs typing, looking, and typing again, the latter requires only looking and typing.
out of curiosity, if the blog post itself an org-mode output?
if yes then :
1. What tools did you use for the images?
2. That's a neat sidebar. custom ya-snippets?
3. Would love to take a leaf out of your dotfiles/.emacsd
Thanks. The blog is generated by Hugo from org using ox-hugo[1]. The sidebar is part of the Hugo Cactus theme[2], which I modified a bit for my use.
The "flow charts" were made in Inkscape. No custom (ya)snippets are in use. (My Emacs configuration is linked to on the home page of the blog, but there isn't anything particularly interesting about it.)
If you do find out how the page is translated from org to the html/css we see, could you please let me know? I agree about the page, I think it looks great.
> As someone who has only experience with vim and not Emacs, are there any advantages to Emacs or is it just „different“?
As someone who uses both, there are clear advantages to each one. A Vim power-user spending time learning Emacs will not be wasting their time (and vice-versa, of course).
IMO, Vim is slightly faster to use when you want to navigate the file, making changes as you go, while Emacs is slightly better at programmatically automating common tasks.
> I hear this a lot, can you give some concrete examples?
You can get a good example of what is possible by using org mode for a little while.
For example, keystroke <TAB> on an issue marked as TODO moves it to the next state IN-PROGRESS, <TAB> again moves it to the next state DONE and changes the color from red to green, and if you continue <TAB>ing you will cycle through all states.
That's the default 3 states.
If you don't like the default states, at the top of your file you can simply list the state progression in plain text like this:
#+TODO: TODO INVESTIGATING IN-PROGESS BLOCKED | DONE
And now your <TAB>ing will cycle through those states.
Another example of the programmability of Emacs is when editing tables in org mode - it's so painless and intuitive to have text tables with columns all aligned as you move to the next column or row. That's also behaviour that is not hardwired into Emacs, it's simply some sort of hook that's registered when org mode is set up.
As a final example, here's a snippet from my .emacs file:
; Set the postamble for org html export
; %t stands for the title.
; %a stands for the author's name.
; %e stands for the author's email.
; %d stands for the date.
; %c will be replaced by `org-html-creator-string'.
; %v will be replaced by `org-html-validation-link'.
; %T will be replaced by the export time.
; %C will be replaced by the last modification time.
Those are callbacks - you don't get any more programmability than telling the application "call me back when the user requests an export, but only for HTML use these functions".
> I am really curious to know how Emacs and Vim fits in your daily workflow?
I use Vim primarily for writing code and code navigation. I use Emacs primarily for writing text and text navigation (for example, Emacs shortcuts for paragraph formatting and navigation are great (C-u M-q)). Emacs org mode is also great for maintaining tasklists, time-spent on tasks (it calculates that for you using a date-picker), reorganising the task hierarchy, etc.
Vim, even with plugins, doesn't come close to org mode.
I have heard many good things about org-mode.
Question:
- Have you ever used Vimwiki? I know it is no org-mode, but even I am a regular notetaker and I never felt it really lacked in anything, but yeah, it doesn't have task planning.
Well, Emacs is incredibly powerful, but it is just too much work to do anything, even regarding keystrokes and all the chords you have to remember. I have worked on Emacs too, but sometimes it is just not worth investing so much time and energy in Emacs if you can spend much fewer time in Vim and get a lot more done.
VimScript is aweful, sure, but with Neovim Lua support, you can do a lot more in a decent and fast language. Emacs has some great plugins and good LSP support (Also, available in Neovim/Vim and also native treesitter support too). There is barely anything in Emacs at this moment that really justifies investing so much time into it.
Even with this post, as an experienced Vimmer, I could basically do everything they are doing here, without installing any plugin and remembering all those obscure keystrokes.
Also, Emacs folks downvoting this, tell me if my logic is wrong, you will come up with NADA.
> Even with this post, as an experienced Vimmer, I could basically do everything they are doing here, without installing any plugin and remembering all those obscure keystrokes.
I thought so too[1], but I am willing to give the blog author the benefit of the doubt (that Avy is the fastest way). It also seems to me that with Avy the process is a little more uniform and consistent than the way I would do it in Vim (only a little, though).
[1] In Vim, I would do the Filter->Select->Act cycle as *'/<pattern>qq<modify-pattern><esc>q'* and then use 'n@q' for each modification, or 'nn' to skip to the next modification.
For simple patterns (for example, adding a parameter to a function call) I won't even bother with the recording, I'll do a flurry of 'n.' or 'nn'.
Upside: works anywhere, much lighter mental load, relatively easy to learn and adjust to.
Downside: some programs (ironically, mainly Emacs) can't keep up, and scrolling becomes choppy.
On Linux this is quite easy. When I was using Windows, there was no good solution for USB keyboards, so I hacked up a driver to do it: https://github.com/CyberShadow/KeyboardEmperor (signing keys not included).