Bram Moolenaar | b20545f | 2016-04-30 14:15:54 +0200 | [diff] [blame] | 1 | " Vim plugin for using Vim as manpager. |
| 2 | " Maintainer: Enno Nagel <ennonagel+vim@gmail.com> |
Bram Moolenaar | f269eab | 2022-10-03 18:04:35 +0100 | [diff] [blame] | 3 | " Last Change: 2022 Sep 30 |
Bram Moolenaar | b20545f | 2016-04-30 14:15:54 +0200 | [diff] [blame] | 4 | |
Bram Moolenaar | d592deb | 2022-06-17 15:42:40 +0100 | [diff] [blame] | 5 | " Set up the current buffer (likely read from stdin) as a manpage |
| 6 | command MANPAGER call s:ManPager() |
Bram Moolenaar | b20545f | 2016-04-30 14:15:54 +0200 | [diff] [blame] | 7 | |
Bram Moolenaar | 016188f | 2022-06-06 20:52:59 +0100 | [diff] [blame] | 8 | function s:ManPager() |
| 9 | " global options, keep these to a minimum to avoid side effects |
| 10 | if &compatible |
| 11 | set nocompatible |
| 12 | endif |
Bram Moolenaar | 7254067 | 2018-02-09 22:00:53 +0100 | [diff] [blame] | 13 | if exists('+viminfofile') |
| 14 | set viminfofile=NONE |
Bram Moolenaar | b20545f | 2016-04-30 14:15:54 +0200 | [diff] [blame] | 15 | endif |
Bram Moolenaar | d592deb | 2022-06-17 15:42:40 +0100 | [diff] [blame] | 16 | syntax on |
Bram Moolenaar | b20545f | 2016-04-30 14:15:54 +0200 | [diff] [blame] | 17 | |
Bram Moolenaar | d592deb | 2022-06-17 15:42:40 +0100 | [diff] [blame] | 18 | " Make this an unlisted, readonly scratch buffer |
| 19 | setlocal buftype=nofile noswapfile bufhidden=hide nobuflisted readonly |
| 20 | |
Bram Moolenaar | d592deb | 2022-06-17 15:42:40 +0100 | [diff] [blame] | 21 | " Ensure text width matches window width |
| 22 | setlocal foldcolumn& nofoldenable nonumber norelativenumber |
| 23 | |
| 24 | " In case Vim was invoked with -M |
| 25 | setlocal modifiable |
Bram Moolenaar | b20545f | 2016-04-30 14:15:54 +0200 | [diff] [blame] | 26 | |
Bram Moolenaar | 7254067 | 2018-02-09 22:00:53 +0100 | [diff] [blame] | 27 | " Emulate 'col -b' |
Bram Moolenaar | 6aa5729 | 2021-08-14 21:25:52 +0200 | [diff] [blame] | 28 | silent! keepj keepp %s/\v(.)\b\ze\1?//ge |
| 29 | |
| 30 | " Remove ansi sequences |
| 31 | silent! keepj keepp %s/\v\e\[%(%(\d;)?\d{1,2})?[mK]//ge |
Bram Moolenaar | b20545f | 2016-04-30 14:15:54 +0200 | [diff] [blame] | 32 | |
Bram Moolenaar | 7254067 | 2018-02-09 22:00:53 +0100 | [diff] [blame] | 33 | " Remove empty lines above the header |
| 34 | call cursor(1, 1) |
| 35 | let n = search(".*(.*)", "c") |
| 36 | if n > 1 |
| 37 | exe "1," . n-1 . "d" |
| 38 | endif |
Bram Moolenaar | 7254067 | 2018-02-09 22:00:53 +0100 | [diff] [blame] | 39 | |
Bram Moolenaar | d592deb | 2022-06-17 15:42:40 +0100 | [diff] [blame] | 40 | " Finished preprocessing the buffer, prevent any further modifications |
| 41 | setlocal nomodified nomodifiable |
| 42 | |
| 43 | " Set filetype to man even if ftplugin is disabled |
Bram Moolenaar | f269eab | 2022-10-03 18:04:35 +0100 | [diff] [blame] | 44 | setlocal filetype=man |
Bram Moolenaar | d592deb | 2022-06-17 15:42:40 +0100 | [diff] [blame] | 45 | runtime ftplugin/man.vim |
Bram Moolenaar | b20545f | 2016-04-30 14:15:54 +0200 | [diff] [blame] | 46 | endfunction |