diff options
-rw-r--r-- | README.md | 49 | ||||
-rw-r--r-- | doc/tags | 2 | ||||
-rw-r--r-- | doc/vim-karlmarks.txt | 22 | ||||
-rw-r--r-- | plugin/vim-karlmarks.vim | 29 |
4 files changed, 102 insertions, 0 deletions
diff --git a/README.md b/README.md new file mode 100644 index 0000000..e3eedcf --- /dev/null +++ b/README.md | |||
@@ -0,0 +1,49 @@ | |||
1 | # karlmarks | ||
2 | |||
3 | A teaching plugin for Vim. It uses the `signcolumn` to display currently active | ||
4 | `marks`. These are mostly used as jump locations and some are set by Vim | ||
5 | automatically during the edit sessions. Also user defined marks are shown. | ||
6 | These can be set with `m[a-z]`, e.g. `ma` sets mark `a` and this plugin would | ||
7 | display its line and you can jump to that line with ```a``. Captital letters | ||
8 | even allow jumps between files and session persistent marks. | ||
9 | |||
10 | Chances are that you have learned only some of the marks Vim has to offer. This | ||
11 | plugin will remember you to use more and once you have that on disk you can | ||
12 | always deinstall it again. | ||
13 | |||
14 | |||
15 | ## Prerequirements | ||
16 | |||
17 | I recommend you use this in your `~/.vim/vimrc` | ||
18 | |||
19 | set signcolumn=yes | ||
20 | |||
21 | because if you set it to `signcolumn=auto` it will flicker when you change | ||
22 | the window. | ||
23 | |||
24 | |||
25 | ## Installation | ||
26 | |||
27 | Download the [zip file](https://git.entwicklerseite.de/vim-recently-used/snapshot/vim-recently-used-master.zip) | ||
28 | and extract it inside `~/.vim/pack/coderonline/start/`. | ||
29 | |||
30 | ### Example | ||
31 | |||
32 | mkdir ~/.vim/pack/coderonline/start/ | ||
33 | cd ~/.vim/pack/coderonline/start/ | ||
34 | # download plugin in that directory: | ||
35 | curl -o vim-recently-used.zip https://git.entwicklerseite.de/vim-recently-used/snapshot/vim-recently-used-master.zip | ||
36 | # unzip the zip file | ||
37 | unzip vim-recently-used.zip | ||
38 | # remove zip file (not needed any more) | ||
39 | rm vim-recently-used.zip | ||
40 | |||
41 | |||
42 | ## Deinstallation | ||
43 | |||
44 | Remove the folder `~/.vim/pack/coderonline/start/vim-karlmarks` (if you named | ||
45 | it as suggested in the Installation section) | ||
46 | |||
47 | ### Exmaple | ||
48 | rm -irv ~/.vim/pack/coderonline/start/vim-karlmarks | ||
49 | |||
diff --git a/doc/tags b/doc/tags new file mode 100644 index 0000000..9ff07ee --- /dev/null +++ b/doc/tags | |||
@@ -0,0 +1,2 @@ | |||
1 | karlmarks vim-karlmarks.txt /*karlmarks* | ||
2 | vim-karlmarks vim-karlmarks.txt /*vim-karlmarks* | ||
diff --git a/doc/vim-karlmarks.txt b/doc/vim-karlmarks.txt new file mode 100644 index 0000000..7867b67 --- /dev/null +++ b/doc/vim-karlmarks.txt | |||
@@ -0,0 +1,22 @@ | |||
1 | *vim-karlmarks* A Vim teaching plugin to show common marks in signcolumn | ||
2 | |||
3 | ============================================================================== | ||
4 | USAGE INSTRUCTIONS *karlmarks* | ||
5 | |||
6 | Install the plugin and have `signcolumn=yes` in your vimrc. The plugin uses | ||
7 | a CursorHold autocmd to dynamically display signs int he signcolumn. If | ||
8 | you ever want to remove this plugin, find this text file in your vim | ||
9 | configuration folder with | ||
10 | |||
11 | :echo expand("%:p:h:h") | ||
12 | |||
13 | and delete the folder. If you want to copy its name to the clipboard you | ||
14 | can use: | ||
15 | |||
16 | :let @+=expand("%:p:h:h") | ||
17 | |||
18 | I hope this plugin helped you to memorize more of the default marks which Vim | ||
19 | has to offer. | ||
20 | |||
21 | |||
22 | vim:tw=78:ts=8:ft=help:norl: | ||
diff --git a/plugin/vim-karlmarks.vim b/plugin/vim-karlmarks.vim new file mode 100644 index 0000000..f0699e1 --- /dev/null +++ b/plugin/vim-karlmarks.vim | |||
@@ -0,0 +1,29 @@ | |||
1 | let g:markerbar_additional = '"' " position in buffer when left | ||
2 | let g:markerbar_additional .= '<>' " start/end last selection | ||
3 | let g:markerbar_additional .= '{}' " start/end paragraph | ||
4 | let g:markerbar_additional .= '()' " start/end sentence | ||
5 | let g:markerbar_additional .= '[]' " start/end sentence | ||
6 | let g:markerbar_additional .= '.' " last change | ||
7 | let g:markerbar_additional .= "^" " insert mode stopped | ||
8 | let g:markerbar_additional .= "'`" | ||
9 | |||
10 | function! KarlMarks() | ||
11 | for c in map(split(g:markerbar_additional, '\zs'), "char2nr(v:val)") + | ||
12 | \ range(char2nr('a'), char2nr('z')) + | ||
13 | \ range(char2nr('A'), char2nr('Z')) + | ||
14 | \ range(char2nr('0'), char2nr('9')) | ||
15 | |||
16 | let p = getpos("'".nr2char(c)) | ||
17 | |||
18 | if (p[0] == 0 || p[0] == winbufnr(0)) && p[1] > 0 | ||
19 | exec "sign unplace ".c | ||
20 | exec "sign define mark_".c." text=".nr2char(c)." texthl=SignColumn" | ||
21 | exec "sign place ".c." name=mark_".c." line=".p[1]." buffer=".winbufnr(0) | ||
22 | endif | ||
23 | endfor | ||
24 | endfunction | ||
25 | |||
26 | autocmd CursorHold * call KarlMarks() | ||
27 | |||
28 | " important for distraction free reading while changing windows | ||
29 | " setlocal signcolumn=yes | ||