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 | d592deb | 2022-06-17 15:42:40 +0100 | [diff] [blame] | 3 | " Last Change: 2022 Jun 17 |
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 | |
| 21 | " Is this useful? Should allow for using K on word with a colon. |
| 22 | setlocal iskeyword+=: |
| 23 | |
| 24 | " Ensure text width matches window width |
| 25 | setlocal foldcolumn& nofoldenable nonumber norelativenumber |
| 26 | |
| 27 | " In case Vim was invoked with -M |
| 28 | setlocal modifiable |
Bram Moolenaar | b20545f | 2016-04-30 14:15:54 +0200 | [diff] [blame] | 29 | |
Bram Moolenaar | 7254067 | 2018-02-09 22:00:53 +0100 | [diff] [blame] | 30 | " Emulate 'col -b' |
Bram Moolenaar | 6aa5729 | 2021-08-14 21:25:52 +0200 | [diff] [blame] | 31 | silent! keepj keepp %s/\v(.)\b\ze\1?//ge |
| 32 | |
| 33 | " Remove ansi sequences |
| 34 | silent! keepj keepp %s/\v\e\[%(%(\d;)?\d{1,2})?[mK]//ge |
Bram Moolenaar | b20545f | 2016-04-30 14:15:54 +0200 | [diff] [blame] | 35 | |
Bram Moolenaar | 7254067 | 2018-02-09 22:00:53 +0100 | [diff] [blame] | 36 | " Remove empty lines above the header |
| 37 | call cursor(1, 1) |
| 38 | let n = search(".*(.*)", "c") |
| 39 | if n > 1 |
| 40 | exe "1," . n-1 . "d" |
| 41 | endif |
Bram Moolenaar | 7254067 | 2018-02-09 22:00:53 +0100 | [diff] [blame] | 42 | |
Bram Moolenaar | d592deb | 2022-06-17 15:42:40 +0100 | [diff] [blame] | 43 | " Finished preprocessing the buffer, prevent any further modifications |
| 44 | setlocal nomodified nomodifiable |
| 45 | |
| 46 | " Set filetype to man even if ftplugin is disabled |
| 47 | setlocal iskeyword+=: filetype=man |
| 48 | runtime ftplugin/man.vim |
Bram Moolenaar | b20545f | 2016-04-30 14:15:54 +0200 | [diff] [blame] | 49 | endfunction |