Skip to content

Commit

Permalink
Merge pull request #41 from blueyed/fix-jedi-call-signatures
Browse files Browse the repository at this point in the history
Handle jedi-vim call signatures when looking for colon in prev line
  • Loading branch information
blueyed committed May 12, 2015
2 parents 0e3cb9a + 7cb9a56 commit 955f7c0
Show file tree
Hide file tree
Showing 5 changed files with 98 additions and 11 deletions.
1 change: 1 addition & 0 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,4 +6,5 @@ before_script:
- "export DISPLAY=:99.0"
- "sh -e /etc/init.d/xvfb start"
- "bundle install"
- "vim --version"
script: bundle exec rspec
2 changes: 1 addition & 1 deletion Gemfile
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
source 'https://rubygems.org'
gem "vimrunner", "0.3.0"
gem "vimrunner", "0.3.1"
gem "rspec"
61 changes: 52 additions & 9 deletions indent/python.vim
Original file line number Diff line number Diff line change
Expand Up @@ -43,9 +43,25 @@ let s:paren_pairs = ['()', '{}', '[]']
let s:control_statement = '^\s*\(class\|def\|if\|while\|with\|for\|except\)\>'
let s:stop_statement = '^\s*\(break\|continue\|raise\|return\|pass\)\>'

" Skip strings and comments
" Skip strings and comments. Return 1 for chars to skip.
" jedi* refers to syntax definitions from jedi-vim for call signatures, which
" are inserted temporarily into the buffer.
let s:skip_special_chars = 'synIDattr(synID(line("."), col("."), 0), "name") ' .
\ '=~? "string\\|comment"'
\ '=~? "\\vstring|comment|jedi\\S"'

let s:skip_after_opening_paren = 'synIDattr(synID(line("."), col("."), 0), "name") ' .
\ '=~? "\\vcomment|jedi\\S"'

" Also ignore anything concealed.
" Wrapper around synconcealed for older Vim (7.3.429, used on Travis CI).
function! s:is_concealed(line, col)
let concealed = synconcealed(a:line, a:col)
return len(concealed) && concealed[0]
endfunction
if has('conceal')
let s:skip_special_chars .= '|| s:is_concealed(line("."), col("."))'
endif


let s:skip_search = 'synIDattr(synID(line("."), col("."), 0), "name") ' .
\ '=~? "comment"'
Expand Down Expand Up @@ -134,6 +150,27 @@ function! s:find_start_of_block(lnum, types)
return 0
endfunction

" Is "expr" true for every position in "lnum", beginning at "start"?
" (optionally up to a:1 / 4th argument)
function! s:match_expr_on_line(expr, lnum, start, ...)
let text = getline(a:lnum)
let end = a:0 ? a:1 : len(text)
if a:start > end
return 1
endif
let save_pos = getpos('.')
let r = 1
for i in range(a:start, end)
call cursor(a:lnum, i)
if !(eval(a:expr) || text[i-1] =~ '\s')
let r = 0
break
endif
endfor
call setpos('.', save_pos)
return r
endfunction

" Line up with open parenthesis/bracket/brace.
function! s:indent_like_opening_paren(lnum)
let [paren_lnum, paren_col] = s:find_opening_paren(a:lnum)
Expand All @@ -143,7 +180,8 @@ function! s:indent_like_opening_paren(lnum)
let text = getline(paren_lnum)
let base = indent(paren_lnum)

let nothing_after_opening_paren = text =~ '\%'.(paren_col + 1).'c\s*$'
let nothing_after_opening_paren = s:match_expr_on_line(
\ s:skip_after_opening_paren, paren_lnum, paren_col+1)
let starts_with_closing_paren = getline(a:lnum) =~ '^\s*[])}]'

if nothing_after_opening_paren
Expand Down Expand Up @@ -204,13 +242,18 @@ function! s:indent_like_previous_line(lnum)
call cursor(lnum, len(text))
let ignore_last_char = eval(s:skip_special_chars)

" Search for final colon that is not inside a string or comment.
while search(':\s*\%(#.*\)\?$', 'bcW', lnum)
if eval(s:skip_special_chars)
" Search for final colon that is not inside something to be ignored.
while search(':', 'bcW', lnum)
let curpos = getpos(".")[2]
if curpos == 1 | break | endif
if eval(s:skip_special_chars)
normal! h
continue
endif
if !s:match_expr_on_line(s:skip_special_chars, lnum, curpos)
return base + s:sw()
endif
normal! h
else
return base + s:sw()
endif
endwhile

if text =~ '\\$' && !ignore_last_char
Expand Down
38 changes: 38 additions & 0 deletions spec/indent/indent_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,21 @@
end
end

describe "when after an '{' that is followed by a comment" do
before { vim.feedkeys 'imydict = { # comment\<CR>' }

it "indent by one level" do
indent.should == shiftwidth
vim.feedkeys '1: 1,\<CR>'
indent.should == shiftwidth
end

it "lines up the closing parenthesis" do
vim.feedkeys '}'
indent.should == 0
end
end

describe "when using gq to reindent a '(' that is" do
before { vim.feedkeys 'itest(' }
it "something and has a string without spaces at the end" do
Expand Down Expand Up @@ -129,6 +144,15 @@
end
end

describe "when the previous line has a colon in a string" do
before { vim.feedkeys 'itest(":".join(["1","2"]))\<CR>' }
it "does not indent" do
vim.feedkeys 'if True:'
indent.should == 0
proposed_indent.should == 0
end
end

describe "when after an '(' that is followed by an unfinished string" do
before { vim.feedkeys 'itest("""' }

Expand Down Expand Up @@ -374,6 +398,20 @@
end
end

describe "when jedi-vim call signatures are used" do
before { vim.command 'syn match jediFunction "JEDI_CALL_SIGNATURE" keepend extend' }

it "ignores the call signature after a colon" do
vim.feedkeys 'iif True: JEDI_CALL_SIGNATURE\<CR>'
indent.should == shiftwidth
end

it "ignores the call signature after a function" do
vim.feedkeys 'idef f( JEDI_CALL_SIGNATURE\<CR>'
indent.should == shiftwidth * 2
end
end

def shiftwidth
@shiftwidth ||= vim.echo("exists('*shiftwidth') ? shiftwidth() : &sw").to_i
end
Expand Down
7 changes: 6 additions & 1 deletion spec/spec_helper.rb
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,13 @@
require 'vimrunner/rspec'

Vimrunner::RSpec.configure do |config|
# Use a single Vim instance for the test suite. Set to false to use an
# instance per test (slower, but can be easier to manage).
# FIXME: reuse_server = true seems to hang after a certain number of test cases
config.reuse_server = false
# - Travis CI hangs after 15 successful tests.
# - Locally it may hang also, with Vim and Xorg using 100% CPU.
# Therefore default to false in both cases.
config.reuse_server = ENV['CI'] ? false : false

config.start_vim do
vim = Vimrunner.start
Expand Down

0 comments on commit 955f7c0

Please sign in to comment.