aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJustin M. Keyes <justinkz@gmail.com>2015-09-19 17:44:23 -0400
committerJustin M. Keyes <justinkz@gmail.com>2015-09-23 00:06:26 -0400
commit45724e2c4148aaddfbb83909d2d637a760e57710 (patch)
treea012201141b3a9a9fc9144dcfed44d89609cd426
parent4fb75d61c2c52ac25de96763788775f5e2d27dd7 (diff)
downloadrneovim-45724e2c4148aaddfbb83909d2d637a760e57710.tar.gz
rneovim-45724e2c4148aaddfbb83909d2d637a760e57710.tar.bz2
rneovim-45724e2c4148aaddfbb83909d2d637a760e57710.zip
man.vim: man#get_page(): parse page and section.
- Eliminate man#pre_get_page(). - Temporarily remove () from 'iskeyword' to avoid spurious \k match.
-rw-r--r--runtime/autoload/man.vim62
-rw-r--r--runtime/ftplugin/man.vim7
2 files changed, 34 insertions, 35 deletions
diff --git a/runtime/autoload/man.vim b/runtime/autoload/man.vim
index 885d77b645..79977641dd 100644
--- a/runtime/autoload/man.vim
+++ b/runtime/autoload/man.vim
@@ -11,52 +11,54 @@ catch /E145:/
" Ignore the error in restricted mode
endtry
-function man#pre_get_page(cnt)
- if a:cnt == 0
- let old_isk = &iskeyword
- if &ft == 'man'
- setlocal iskeyword+=(,)
- endif
- let str = expand('<cword>')
- let &l:iskeyword = old_isk
- let page = substitute(str, '(*\(\k\+\).*', '\1', '')
- let sect = substitute(str, '\(\k\+\)(\([^()]*\)).*', '\2', '')
- if match(sect, '^[0-9 ]\+$') == -1
- let sect = ''
- endif
- if sect == page
+" Expects a string like 'access' or 'access(2)'.
+function s:parse_page_and_section(str)
+ try
+ let save_isk = &iskeyword
+ setlocal iskeyword-=(,)
+ let page = substitute(a:str, '(*\(\k\+\).*', '\1', '')
+ let sect = substitute(a:str, '\(\k\+\)(\([^()]*\)).*', '\2', '')
+ if sect == page || -1 == match(sect, '^[0-9 ]\+$')
let sect = ''
endif
- else
- let sect = a:cnt
- let page = expand('<cword>')
- endif
- call man#get_page(sect, page)
+ catch
+ let &l:iskeyword = save_isk
+ echoerr 'man.vim: failed to parse: "'.a:str.'"'
+ endtry
+
+ return [page, sect]
endfunction
function man#get_page(...)
- if a:0 >= 2
- let sect = a:1
- let page = a:2
- elseif a:0 >= 1
- let sect = ''
- let page = a:1
- else
+ if a:0 == 0
+ echoerr 'argument required'
return
+ elseif a:0 > 2
+ echoerr 'too many arguments'
+ return
+ elseif a:0 == 2
+ let [sect, page] = [a:1, a:2]
+ elseif type(1) == type(a:1)
+ let [page, sect] = ['<cword>', a:1]
+ else
+ let [page, sect] = [a:1, '']
endif
- " To support: nmap K :Man <cword>
if page == '<cword>'
let page = expand('<cword>')
endif
- if sect != '' && s:FindPage(sect, page) == 0
+ let [page, sect] = s:parse_page_and_section(page)
+
+ if sect !=# '' && s:FindPage(sect, page) == 0
let sect = ''
endif
+
if s:FindPage(sect, page) == 0
echo "\nNo manual entry for '".page."'"
return
endif
+
exec 'let s:man_tag_buf_'.s:man_tag_depth.' = '.bufnr('%')
exec 'let s:man_tag_lin_'.s:man_tag_depth.' = '.line('.')
exec 'let s:man_tag_col_'.s:man_tag_depth.' = '.col('.')
@@ -65,14 +67,14 @@ function man#get_page(...)
" Use an existing "man" window if it exists, otherwise open a new one.
if &filetype != 'man'
let thiswin = winnr()
- exe "norm! \<C-W>b"
+ wincmd b
if winnr() > 1
exe "norm! " . thiswin . "\<C-W>w"
while 1
if &filetype == 'man'
break
endif
- exe "norm! \<C-W>w"
+ wincmd w
if thiswin == winnr()
break
endif
diff --git a/runtime/ftplugin/man.vim b/runtime/ftplugin/man.vim
index a35966f6a9..38c6c7d71e 100644
--- a/runtime/ftplugin/man.vim
+++ b/runtime/ftplugin/man.vim
@@ -14,21 +14,18 @@ if exists('$MANPAGER')
let $MANPAGER = ''
endif
-" allow dot and dash in manual page name.
setlocal iskeyword+=\.,-,(,)
-" Avoid warning for editing the dummy file twice
setlocal buftype=nofile noswapfile
-
setlocal nomodifiable readonly bufhidden=hide nobuflisted
setlocal tabstop=8 colorcolumn=0
if !exists("g:no_plugin_maps") && !exists("g:no_man_maps")
- nnoremap <silent> <buffer> <C-]> :call man#pre_get_page(v:count)<CR>
+ nnoremap <silent> <buffer> <C-]> :call man#get_page(v:count)<CR>
nnoremap <silent> <buffer> <C-T> :call man#pop_page()<CR>
nnoremap <silent> <nowait><buffer> q <C-W>c
if &keywordprg !=# ':Man'
- nnoremap <silent> <buffer> K :call man#pre_get_page(v:count)<CR>
+ nnoremap <silent> <buffer> K :call man#get_page(v:count)<CR>
endif
endif