Thanks a lot for taking the time to address my questions.
This reply helps a lot. I start to understand some of the benefits of using vim. Not having to move my wrists can definitely speed up things tremendously.
Could you please share an example of "mastering macros allows a super-efficient way of refactoring code and custom changes where a simple multi-cursor concept won't do". I still don't have a good picture of what that can be.
Sure: imagine a situation where you write some javascript code and would like to change them all to async and add an optional parameter to them as well.
With any other tool you'd have to go one by one, maybe you'll be able to search for function and maybe be able to add the prefix of async but how about a last optional argument?
With Vim the logic for a macro would be this:
Search for all functions: /function
Start recording to a specific register:qq means record to register q, qw - the same for w
Add a preceding async: I async <space> (cap I means "insert at the beginning of the line)
Go to normal mode: <esc>
Find the closing arguments line by f) (*f*ind forward the char ))
Insert the argument: i somearg? (*i*nsert the arg with optional ?)
Go to normal mode: <esc>
Go to next appearance of function: n
Stop recording: q
Now, if you @q Vim will perform all of the above on the second appearance of function and will end on the next one. if you @@ it will do once again the last used macro.
If you 50@q you'll run this 50 times more. Assuming you have less than 50 of them, and that function is generic enough in JS to indicate a function and will not appear anywhere else in the file (in other case you have to fix your initial search target), you've quickly editted a file regardless of the size with the exact change you wanted.
While this may seem very specific, I can't stress enough how useful this is. When you deal with huge json or yaml files this is like a magic wand.
You can also combine this with NERDTree to visually walk through any other file (maybe even with specific naming) to edit multiple ones.
You can even edit your macro by reading the register q and saving it again (will not explain here unless you really want to dive into it) and use it later, or just fix stuff.
Thanks a lot once again for taking the time to share insights with me. I really appreciate it.
As you mention, I find this example pretty specific. I don't write JavaScript, so I wouldn't know about adding "async" to many functions at the same time. But I can't imagine when I would add the same optional argument to many contiguous functions at the same time. Do you have a real life example of some vim-specific refactoring that you did recently?
About processing large json or xml files, this has never happened to me, and I guess this is pretty rare for standard software engineers.
Don't get me wrong, I am not trying to argue here, or prove that vim is not useful. I am really genuinely interested in understand specifically what benefits it can offer me, and other typical software engineers.
No worries at all! I totally get you.
I think what's important here is that you learn what you need. If you don't feel you have repetitive refactoring work then there's no need for you to dive into it.
Macros in Vim are a relatively very easy thing to learn so I think spending the hour and adding them to your arsenal of Vim magic is a good thing.
I think I find myself using a macro once a day. Sometimes it could probably done with a regex replacements statement (%s/<pattern-to-replace>/<replacement>/g) and sometimes with multiple cursors which I find to be more dangerous then helpful.
About not feeling that I have a need, I think one does not need to feel the need. Very often, one doesn't image that one could go faster. This is why although I don't imagine how I could be faster, I would love to get examples that I don't picture yet.
About refactorings, I never use multiple cursors. However I very often use IDEs' rename variable, rename field, rename method, rename class, move class, etc, tools
One example I used today: I'm building our product's backend and am testing it both with unit tests and mocks of calls and both with sending real-life requests from postman.
The request is a 100 line JSON, and we agreed yesterday about removing a specific nested field from specific locations in the request. I've created a macro that searches for the constant field about each set of actual fields needed deletion (/<field>/) then, I created automation for deleting it (this was specifically "go 3 lines down, remove the trailing comma, then delete the line below" since this should be a valid JSON). So: 3jEx (3 lines down, End of line, delete char), and jdd (line down delete line). Now, all I had to do is find the next (n) appearance of my search index, and run the macro as the number of nested objects I have (<#_of_objects>@@)
Thanks a lot again for your reply! I really appreciate your taking the time to share your experience.
I am not exactly sure, but wouldn't see be doable with a simple search and replace with regular expressions in an IDE? Something that would take a variable number of white space before your field, and an optional comma if the next character is not a closing bracket?
Depends, sometimes it is sometimes it isn't, regex on its own when trying to achieve complex solutions is hard.
Many times a macro is just a faster simpler solution which allows you to think like a human being, and sometimes the only way is a macro. Search and replace is a single specific use-case, not a substitute to all macro powers.
After thinking about all of this, my conclusion is the following:
I don't see how macros can change much my productivity
not having to move my wrists to the arrows, and using mainly the home row instead, is conversely a killer feature, which I can see making me a lot faster
the problem I have with switching is the following. Muscles only have a single memory. If I switch my muscle memory to vim, it means I will be very slow outside of vim. Which means either I have to go to vim every time I want to type anything, such as replying to each email, or I have to suffer frustration each time I type something outside of vim. If there was a way to change system-wide input settings to use an "embedded vim", I would definitely make the switch
I guess the situation is a bit the same as with switching to a Dvorak keyboard layout. I tried it before, and then I realized that I couldn't set it up on my phone, so I was super slow and frustrated on my phone. I moved back to a standard keyboard layout just because of that.
Basically I agree with the last 2 statements. With the first one not fully but I can only send you to the docs where you may find something I didn't say :)
About the "problem" with moving out of Vim, I agree but you'd be surprised to know that since Vim is deeply integrated a long time into any *nix system it's convention keys can be found almost anywhere. Even modern mail clients like SuperHuman integrated Vim shortcuts by default...
Personally I use the same for everything, even my MacOS desktops are configured to switch with Vim hjkl.
Another example is the terminal which can be set with set -o vi to provide Vim motions within the lines.
Thanks again very much for taking the time to clear things out for me. I really feel lucky to receive such guidance.
One crucial point for me is the ability to use Google Docs and Gmail. I tried looking online but so far haven't found any really good solution. VimAnywhere seems to be good for short non-formatted input fields, but not very convenient with Google Docs.
Would you by any chance have something to suggest?
Thanks a lot again!
For further actions, you may consider blocking this person and/or reporting abuse
We're a place where coders share, stay up-to-date and grow their careers.
Thanks a lot for taking the time to address my questions.
This reply helps a lot. I start to understand some of the benefits of using vim. Not having to move my wrists can definitely speed up things tremendously.
Could you please share an example of "mastering macros allows a super-efficient way of refactoring code and custom changes where a simple multi-cursor concept won't do". I still don't have a good picture of what that can be.
Thanks a lot again!
Hey Vic,
Sure: imagine a situation where you write some javascript code and would like to change them all to
asyncand add an optional parameter to them as well.With any other tool you'd have to go one by one, maybe you'll be able to search for
functionand maybe be able to add the prefix ofasyncbut how about a last optional argument?With Vim the logic for a macro would be this:
functions:/functionqqmeans record to registerq,qw- the same forwasync:I async <space>(cap I means "insert at the beginning of the line)<esc>f)(*f*ind forward the char))i somearg?(*i*nsert the arg with optional?)<esc>function:nqNow, if you
@qVim will perform all of the above on the second appearance offunctionand will end on the next one. if you@@it will do once again the last used macro.If you
50@qyou'll run this 50 times more. Assuming you have less than 50 of them, and thatfunctionis generic enough in JS to indicate a function and will not appear anywhere else in the file (in other case you have to fix your initial search target), you've quickly editted a file regardless of the size with the exact change you wanted.While this may seem very specific, I can't stress enough how useful this is. When you deal with huge json or yaml files this is like a magic wand.
You can also combine this with NERDTree to visually walk through any other file (maybe even with specific naming) to edit multiple ones.
You can even edit your macro by reading the register
qand saving it again (will not explain here unless you really want to dive into it) and use it later, or just fix stuff.Thanks a lot once again for taking the time to share insights with me. I really appreciate it.
As you mention, I find this example pretty specific. I don't write JavaScript, so I wouldn't know about adding "async" to many functions at the same time. But I can't imagine when I would add the same optional argument to many contiguous functions at the same time. Do you have a real life example of some vim-specific refactoring that you did recently?
About processing large json or xml files, this has never happened to me, and I guess this is pretty rare for standard software engineers.
Don't get me wrong, I am not trying to argue here, or prove that vim is not useful. I am really genuinely interested in understand specifically what benefits it can offer me, and other typical software engineers.
Thanks again very much for your help!
Hey Vic!
No worries at all! I totally get you.
I think what's important here is that you learn what you need. If you don't feel you have repetitive refactoring work then there's no need for you to dive into it.
Macros in Vim are a relatively very easy thing to learn so I think spending the hour and adding them to your arsenal of Vim magic is a good thing.
I think I find myself using a macro once a day. Sometimes it could probably done with a regex replacements statement (
%s/<pattern-to-replace>/<replacement>/g) and sometimes with multiple cursors which I find to be more dangerous then helpful.Thanks again for your reply.
About not feeling that I have a need, I think one does not need to feel the need. Very often, one doesn't image that one could go faster. This is why although I don't imagine how I could be faster, I would love to get examples that I don't picture yet.
About refactorings, I never use multiple cursors. However I very often use IDEs' rename variable, rename field, rename method, rename class, move class, etc, tools
Hey Vic,
One example I used today: I'm building our product's backend and am testing it both with unit tests and mocks of calls and both with sending real-life requests from postman.
The request is a 100 line JSON, and we agreed yesterday about removing a specific nested field from specific locations in the request. I've created a macro that searches for the constant field about each set of actual fields needed deletion (
/<field>/) then, I created automation for deleting it (this was specifically "go 3 lines down, remove the trailing comma, then delete the line below" since this should be a valid JSON). So:3jEx(3 lines down, End of line, delete char), andjdd(line down delete line). Now, all I had to do is find the next (n) appearance of my search index, and run the macro as the number of nested objects I have (<#_of_objects>@@)Thanks a lot again for your reply! I really appreciate your taking the time to share your experience.
I am not exactly sure, but wouldn't see be doable with a simple search and replace with regular expressions in an IDE? Something that would take a variable number of white space before your field, and an optional comma if the next character is not a closing bracket?
Depends, sometimes it is sometimes it isn't, regex on its own when trying to achieve complex solutions is hard.
Many times a macro is just a faster simpler solution which allows you to think like a human being, and sometimes the only way is a macro. Search and replace is a single specific use-case, not a substitute to all macro powers.
Thanks for the swift reply!
After thinking about all of this, my conclusion is the following:
I guess the situation is a bit the same as with switching to a Dvorak keyboard layout. I tried it before, and then I realized that I couldn't set it up on my phone, so I was super slow and frustrated on my phone. I moved back to a standard keyboard layout just because of that.
Hey Vic,
Basically I agree with the last 2 statements. With the first one not fully but I can only send you to the docs where you may find something I didn't say :)
About the "problem" with moving out of Vim, I agree but you'd be surprised to know that since Vim is deeply integrated a long time into any *nix system it's convention keys can be found almost anywhere. Even modern mail clients like SuperHuman integrated Vim shortcuts by default...
Personally I use the same for everything, even my MacOS desktops are configured to switch with Vim
hjkl.Another example is the terminal which can be set with
set -o vito provide Vim motions within the lines.The same goes for IDEs obviously and many more...
Thanks again very much for taking the time to clear things out for me. I really feel lucky to receive such guidance.
One crucial point for me is the ability to use Google Docs and Gmail. I tried looking online but so far haven't found any really good solution. VimAnywhere seems to be good for short non-formatted input fields, but not very convenient with Google Docs.
Would you by any chance have something to suggest?
Thanks a lot again!