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