-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add blog post about Vim's Command-line window
- Loading branch information
1 parent
8c86178
commit eb92136
Showing
7 changed files
with
113 additions
and
0 deletions.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,113 @@ | ||
--- | ||
title: Vim's Missing Feature Isn't Really Missing | ||
author: Qasim Warraich | ||
comments: true | ||
date: 2023-12-29 | ||
--- | ||
|
||
Since it's near the end of 2023, I am sure everyone is quite busy with family | ||
and other festive obligations. I am going to keep this one short and introduce you | ||
to one Vim feature that, if you don't use it already, will have you excited to | ||
get back to your beloved editor in 2024. | ||
|
||
<!--more--> | ||
|
||
## An Addiction | ||
|
||
data:image/s3,"s3://crabby-images/c13ad/c13add240f9d0c422c84aecdaf4aa220bfb64480" alt="`:w` everywhere" | ||
|
||
If you are anything like me, then Vim is so deeply ingrained in you that you | ||
find yourself accidentally typing `:w` or its friends in all sorts of text | ||
inputs. Vim motions have taken over your brain to the point that you find it | ||
difficult to type in “traditional” text inputs. Perhaps your Vim addiction is | ||
so bad that you have Vi mode configured everywhere you can. | ||
|
||
You feel like a well-oiled machine, navigating your browser, your file system, | ||
and even editing commands in your shell using Vim motions. However, when you | ||
hit `:` to enter your beloved Vim's | ||
[Command-line-mode](https://neovim.io/doc/user/cmdline.html) and want to follow | ||
up with something more than `w` or `q`, something feels off. You make a typo or | ||
forget a flag, and there it is. Your fingers seek awkwardly for the arrow keys, | ||
you're reaching for your backspace, and every time you inadvertently hit | ||
escape, it's game over. | ||
|
||
## Command-line Window | ||
|
||
The so-called, [Command-line-window](https://neovim.io/doc/user/cmdline.html#cmdline-window) (`:h | ||
command-line-window`) is one of the less talked-about Vim features, and one that | ||
I personally discovered sometime ago by pure chance. | ||
|
||
It is a special window in Vim that allows you to edit text for `command-line` | ||
operations in the same way you edit text normally in Vim. This allows you to | ||
circumvent the awkwardness of searching for arrow keys or using backspace, | ||
allowing you to use the Vim motions you are so comfortable with, in even more | ||
contexts. Additionally, the `command-line-window` is also populated with your | ||
command or search history from previous operations, allowing you to modify a | ||
recently run command or search using Vim motions. Another advantage of using | ||
`command-line-window` is that you can also hook into your non-native | ||
autocompletion suggestions for `command-line` operations. | ||
|
||
The command-line-window can be accessed in several ways: | ||
|
||
- `q:` : Opens `command-line-window` populated with your recent `Ex` commands | ||
- `q/` or `q?` : Opens `command-line-window` populated with your recent | ||
searches. Hitting enter executes a search using the `/` or `?` behaviour. | ||
- `CTRL+f` : Brings up the `command-line-window` when you are already in | ||
`command-line-mode`. | ||
|
||
## In Action | ||
|
||
Here are some interesting ways you can integrate `command-line-window` into | ||
your Vim workflow. Keep in mind that these are toy examples intended to seed ideas | ||
as to how you may use `command-line-window` in more complex circumstances. | ||
|
||
### Command History | ||
|
||
data:image/s3,"s3://crabby-images/da3da/da3dae8e618abc49bba0cb4b7e4fc71a0dc36965" alt="Command-line window `Ex` history command" | ||
_`Command-line-window` is activated using `q:`. The last `:h` command is then | ||
modified using Vim motions and reissued with `Enter`._ | ||
|
||
### Search History | ||
|
||
data:image/s3,"s3://crabby-images/8c900/8c90046ce5af1aff6b9180956d962ad0095560ab" alt="Command-line window search history command" | ||
_`Command-line-window` is activated using `q/`. A previous search term is then | ||
modified using Vim motions and reissued with `Enter`._ | ||
|
||
### Filter Command | ||
|
||
data:image/s3,"s3://crabby-images/18aee/18aee9d8855633b51b39ba0c9f5cf5c55fde1024" alt="Command-line window modify filter command" | ||
_`Command-line-window` is activated using `CTRL+f` while already in | ||
`Command-line-mode`. This is then used to insert a missing flag into our | ||
`filter` command using Vim motions._ | ||
|
||
### LSP Rename | ||
|
||
data:image/s3,"s3://crabby-images/10369/103696971cbf81950dfd77215c6394202c3d0689" alt="Command-line window LSP rename" | ||
_`Command-line-window` is activated using `CTRL+f` after Neovim's | ||
`vim.lsp.buf.rename` is triggered. Now we can access our recent history of | ||
renames and also use Vim motions to pick a new name for the variable._ | ||
|
||
### Netrw | ||
|
||
data:image/s3,"s3://crabby-images/922b9/922b9e096fda3e4de1af84a042ea80b113766f40" alt="Command-line window Netrw" | ||
_`Command-line-window` is activated using `CTRL+f` after the rename command on | ||
a directory inside `netrw` is issued. The file can now be conveniently renamed | ||
using Vim motions._ | ||
|
||
## Happy Vim-ing in 2024 | ||
|
||
The potential use cases for `command-line-window` go well beyond these simple | ||
examples. Nonetheless, I hope this was a useful introduction to a feature that | ||
bridges a gap that was always missing (and, frankly, irritating) for me in Vim. | ||
|
||
This post is dedicated to the late Bram Moolenaar, who passed away in August 2023. Bram was the creator and | ||
[BDFL](https://en.wikipedia.org/wiki/Benevolent_dictator_for_life) of Vim. Vim | ||
is licensed as [“charityware”](https://en.wikipedia.org/wiki/Careware) and as | ||
conveyed by the call to “Help poor children in Uganda!” in Vim's welcome | ||
message, Bram encouraged users to donate to the [ICCF | ||
Holland](https://www.iccf-holland.org/) charity he founded. If your end-of-year | ||
bonus has you feeling generous, I encourage you to spread the wealth to those | ||
who are less fortunate than people like us, people who spend an obnoxious | ||
amount of time obsessing over text editors. | ||
|
||
Happy new year! |