Update batch editing notes
This commit is contained in:
parent
cd71a2c4c2
commit
5e1a845ec5
2 changed files with 114 additions and 85 deletions
|
@ -219,91 +219,7 @@ commands operate on entire lines at once
|
||||||
n
|
n
|
||||||
For all lines matching the regex, run the command sequence. `\` separate lines
|
For all lines matching the regex, run the command sequence. `\` separate lines
|
||||||
|
|
||||||
#### Batch editing with ex
|
See vim_batch_editing.md for practical application of this
|
||||||
Ex is vim's equivalent of `ed` and `ex` is symlinked as `vim -e` on many
|
|
||||||
systems. It's equivalent to vim's command line, similar to `ed`, though many
|
|
||||||
commands are different
|
|
||||||
|
|
||||||
$ ex file
|
|
||||||
$ vim -Nes file
|
|
||||||
Roughly equivalent ways of entering ex-mode. `Q` also works from within vim
|
|
||||||
|
|
||||||
:g/re/p Globally exectute a command on lines with /re/
|
|
||||||
:v/re/p Inverse of :g. Executes on all lines without /re/
|
|
||||||
:3,6co$ Copy lines [3,6] to the end of the document
|
|
||||||
:3m6 Move line 3 to line 6
|
|
||||||
:z=3 Pretty print lines in [-2,+2]
|
|
||||||
Some infrequently used vim commands are very important in ex-mode
|
|
||||||
|
|
||||||
:g/re/z3
|
|
||||||
Prints all the lines and line numbers that contain regex `re`
|
|
||||||
|
|
||||||
:g/bash/exe "normal! cfish\<esc>" | undo | nu
|
|
||||||
Changes every line with "bash" to "fish", undoes that, then prints the line
|
|
||||||
|
|
||||||
:g/string/nu | g/num/nu
|
|
||||||
Does NOT print all the lines with `string` or `num`. This prints all the lines
|
|
||||||
with `string` then reprints them if they also have `num`. `:g` only uses a new
|
|
||||||
line to delimit its commands from the next set!
|
|
||||||
|
|
||||||
Batch editing style (in bash):
|
|
||||||
1. Here-string: For only one command, here-strings are a quick and easy choice
|
|
||||||
|
|
||||||
$ for f in $(find ~/); do vim -Nes <<<"g/re/p"; done
|
|
||||||
Prints all lines with `re` in the home directory. Be careful chaining with `:g`
|
|
||||||
|
|
||||||
2. Here-ansi-c-string: Allows including c-style escape sequences
|
|
||||||
|
|
||||||
$ for f in $(find ~/); do vim -Nes <<< $'g/re/nu\n3'; done
|
|
||||||
Prints all lines with `re` then moves to line 3. Often can be avoided with `|`
|
|
||||||
|
|
||||||
3. Here-documents: Probably the best choice for quick batch edits
|
|
||||||
|
|
||||||
$ for file in $(fd -at type subs_)
|
|
||||||
do
|
|
||||||
vim -Nes $file <<'DOC'
|
|
||||||
g/^Stl/exe "norm! cStyle: new\<CR>\<esc>"
|
|
||||||
$ | a
|
|
||||||
# ex: ff=unix:
|
|
||||||
.
|
|
||||||
wq
|
|
||||||
DOC
|
|
||||||
done
|
|
||||||
|
|
||||||
Changes The style lines and appends a modeline to files found by `fd`
|
|
||||||
|
|
||||||
$ for file in ~/.bash*; do vim -Nes $file <<EOF
|
|
||||||
a
|
|
||||||
# ex: set syntax=bash:ff=unix:
|
|
||||||
.
|
|
||||||
wq
|
|
||||||
EOF
|
|
||||||
done
|
|
||||||
Adds a mode line to all bash dot files in the home directory
|
|
||||||
|
|
||||||
4. Sourced documents: Better for recurring batch edits
|
|
||||||
|
|
||||||
$ fd -a subs_ -x ex < change_font
|
|
||||||
$ fd -a subs_ -x vim -Nes < change_font
|
|
||||||
Changes font for all subtitle files. Similar to `vim -S $file`
|
|
||||||
|
|
||||||
#### Best practices
|
|
||||||
Use `-t file` in `fd`, otherwise `ex` may stop when it hits a directory
|
|
||||||
|
|
||||||
Recent version of `fd` seems to consume here-documents and strings. To avoid
|
|
||||||
this, use the bash `for` loop syntax as below:
|
|
||||||
|
|
||||||
$ for file in $(fd -at file .); do vim -Ne $f <<<$'nu'; done
|
|
||||||
|
|
||||||
Or with here-documents
|
|
||||||
$ for file in $(fd -at file .); do vim -Ne $f <<doc
|
|
||||||
nu
|
|
||||||
doc
|
|
||||||
done
|
|
||||||
|
|
||||||
#### Batch editing manually
|
|
||||||
fd -t file . -X awk '$0 ~ / ex:/ { print FILENAME }' | xargs -o vim
|
|
||||||
Open all files containing ` ex:` in vim as separate buffers
|
|
||||||
|
|
||||||
## Awk the programming language
|
## Awk the programming language
|
||||||
AWK is an old, though surprisingly useable stream-editing language. It's a POSIX
|
AWK is an old, though surprisingly useable stream-editing language. It's a POSIX
|
||||||
|
|
113
notes/vim/vim_batch_editing.md
Normal file
113
notes/vim/vim_batch_editing.md
Normal file
|
@ -0,0 +1,113 @@
|
||||||
|
# Quick help
|
||||||
|
```bash
|
||||||
|
for f in *.html; do nvim -Nes "$f" < ex_commands; done
|
||||||
|
for f in "$(rg -l homu)"; do nvim -Nes "$f" < ex_commands; done
|
||||||
|
|
||||||
|
for f in $(fd -tf -e html); do
|
||||||
|
nvim -Nes <<'EX'
|
||||||
|
g/^Stl/exe "norm! cStyle: new\<CR>\<esc>"
|
||||||
|
$ | a
|
||||||
|
# ex: ff=unix:
|
||||||
|
.
|
||||||
|
wq
|
||||||
|
EX
|
||||||
|
done
|
||||||
|
```
|
||||||
|
|
||||||
|
# Batch editing with ex
|
||||||
|
Ever needed to apply the same edit to several files? Well ex-mode is the only
|
||||||
|
generalized solution for this
|
||||||
|
|
||||||
|
Ex-mode is vim's equivalent of `ed` and `ex` is symlinked as `vim -e` on many
|
||||||
|
systems. Use the `-N` flag for a more familiar experience. Enter this mode while
|
||||||
|
in vim with `gQ`. Using the `ex` executable is slightly different from neovim's
|
||||||
|
implementation, notably neovim doesn't echo back with `nu` and `p`
|
||||||
|
|
||||||
|
```bash
|
||||||
|
ex file
|
||||||
|
vim -Nes file
|
||||||
|
```
|
||||||
|
|
||||||
|
Ex-mode uses vim's command-mode syntax, which is similar though different from
|
||||||
|
visual mode
|
||||||
|
|
||||||
|
```
|
||||||
|
:21 Goes to line 21. ^ and $ are for the first and last line
|
||||||
|
:10,20d Deletes lines 10 through 20, inclusive on both ends
|
||||||
|
:u[ndo] Undoes the last action
|
||||||
|
:g/re/p Globally exectute a command on lines with /re/
|
||||||
|
:v/re/p Inverse of :g. Executes on all lines without /re/
|
||||||
|
:3,6co$ Copy lines [3,6] to the end of the document
|
||||||
|
:3m6 Move line 3 to line 6
|
||||||
|
:z=3 Pretty print lines in [-2,+2]
|
||||||
|
```
|
||||||
|
|
||||||
|
Several commands can be chained with `|`, similar to `;` in bash
|
||||||
|
|
||||||
|
```
|
||||||
|
:g/bash/exe "normal! cfish\<esc>" | undo | nu
|
||||||
|
```
|
||||||
|
|
||||||
|
Changes every line with "bash" to "fish", undoes that, then prints the line
|
||||||
|
|
||||||
|
:g/string/nu | g/num/nu
|
||||||
|
Does NOT print all the lines with `string` or `num`. This prints all the lines
|
||||||
|
with `string` then reprints them if they also have `num`. `:g` only uses a new
|
||||||
|
line to delimit its commands from the next set!
|
||||||
|
|
||||||
|
## Batch editing styles:
|
||||||
|
1. Here-string: For only one command, here-strings are a quick and easy choice
|
||||||
|
```bash
|
||||||
|
for f in $(find ~/); do nvim -Nes <<<"%s/re/p | wq"; done
|
||||||
|
```
|
||||||
|
|
||||||
|
2. Here-ansi-c-string: Allows including c-style escape sequences
|
||||||
|
```bash
|
||||||
|
for f in $(find ~/); do vim -Nes <<< $'%s/re/nu\nwq'; done
|
||||||
|
```
|
||||||
|
|
||||||
|
3. Here-documents: The best choice for quick batch edits
|
||||||
|
```bash
|
||||||
|
for file in $(fd -at type subs_); do
|
||||||
|
nvim -Nes $file <<'DOC'
|
||||||
|
g/^Stl/exe "norm! cStyle: new\<CR>\<esc>"
|
||||||
|
$ | a
|
||||||
|
# ex: ff=unix:
|
||||||
|
.
|
||||||
|
wq
|
||||||
|
DOC
|
||||||
|
done
|
||||||
|
```
|
||||||
|
|
||||||
|
```bash
|
||||||
|
for file in ~/.bash*; do vim -Nes $file <<EOF
|
||||||
|
a
|
||||||
|
# ex: set syntax=bash:ff=unix:
|
||||||
|
.
|
||||||
|
wq
|
||||||
|
EOF
|
||||||
|
done
|
||||||
|
```
|
||||||
|
|
||||||
|
4. Sourced documents: Better for recurring batch edits. Similar to `nvim -S`
|
||||||
|
```bash
|
||||||
|
fd -a subs_ -x ex < change_font
|
||||||
|
fd -a subs_ -x nvim -Nes < change_font
|
||||||
|
|
||||||
|
for f in *.html; do nvim -Nes "$f" < ex_commands; done
|
||||||
|
for f in "$(rg -l homu)"; do nvim -Nes "$f" < ex_commands; done
|
||||||
|
```
|
||||||
|
|
||||||
|
## Best practices
|
||||||
|
Use `-t file` in `fd`, otherwise `ex` may stop when it hits a directory
|
||||||
|
|
||||||
|
Unless you're really confident, always use files to store commands, then first
|
||||||
|
try them out on copies of files you'd like to edit. It's often hard to debug an
|
||||||
|
edit in advance and there's no undo
|
||||||
|
|
||||||
|
## Batch editing manually
|
||||||
|
This isn't really a batch edit... though it's worth mentioning
|
||||||
|
|
||||||
|
```bash
|
||||||
|
fd -t file . -X rg --files-with-matches 'ex:' | xargs -o vim
|
||||||
|
```
|
Loading…
Reference in a new issue