diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/nvim/syntax.c | 9 | ||||
| -rw-r--r-- | src/nvim/testdir/test_syntax.vim | 78 | ||||
| -rw-r--r-- | src/nvim/version.c | 6 | 
3 files changed, 85 insertions, 8 deletions
| diff --git a/src/nvim/syntax.c b/src/nvim/syntax.c index 8de81f02df..c19442925c 100644 --- a/src/nvim/syntax.c +++ b/src/nvim/syntax.c @@ -5867,9 +5867,12 @@ static void syntime_report(void)      }    } -  /* sort on total time */ -  qsort(ga.ga_data, (size_t)ga.ga_len, sizeof(time_entry_T), -      syn_compare_syntime); +  // Sort on total time. Skip if there are no items to avoid passing NULL +  // pointer to qsort(). +  if (ga.ga_len > 1) { +    qsort(ga.ga_data, (size_t)ga.ga_len, sizeof(time_entry_T), +          syn_compare_syntime); +  }    MSG_PUTS_TITLE(_(            "  TOTAL      COUNT  MATCH   SLOWEST     AVERAGE   NAME               PATTERN")); diff --git a/src/nvim/testdir/test_syntax.vim b/src/nvim/testdir/test_syntax.vim index 05e930d984..6c084dd2a7 100644 --- a/src/nvim/testdir/test_syntax.vim +++ b/src/nvim/testdir/test_syntax.vim @@ -50,7 +50,7 @@ func Test_syn_iskeyword()    setlocal isk-=_    call assert_equal('DLTD_BY', GetSyntaxItem('DLTD'))    /\<D\k\+\>/:norm! ygn -  let b2=@0 +  let b2 = @0    call assert_equal('DLTD', @0)    syn iskeyword clear @@ -77,10 +77,84 @@ func Test_syntax_after_reload()    call delete('Xsomefile')  endfunc +func Test_syntime() +  if !has('profile') +    return +  endif + +  syntax on +  syntime on +  let a = execute('syntime report') +  call assert_equal("\nNo Syntax items defined for this buffer", a) + +  view ../memfile_test.c +  setfiletype cpp +  redraw +  let a = execute('syntime report') +  call assert_match('^  TOTAL *COUNT *MATCH *SLOWEST *AVERAGE *NAME *PATTERN', a) +  call assert_match(' \d*\.\d* \+[^0]\d* .* cppRawString ', a) +  call assert_match(' \d*\.\d* \+[^0]\d* .* cppNumber ', a) + +  syntime off +  syntime clear +  let a = execute('syntime report') +  call assert_match('^  TOTAL *COUNT *MATCH *SLOWEST *AVERAGE *NAME *PATTERN', a) +  call assert_notmatch('.* cppRawString *', a) +  call assert_notmatch('.* cppNumber*', a) +  call assert_notmatch('[1-9]', a) + +  call assert_fails('syntime abc', 'E475') + +  syntax clear +  let a = execute('syntime report') +  call assert_equal("\nNo Syntax items defined for this buffer", a) + +  bd +endfunc + +func Test_syntax_list() +  syntax on +  let a = execute('syntax list') +  call assert_equal("\nNo Syntax items defined for this buffer", a) + +  view ../memfile_test.c +  setfiletype c + +  let a = execute('syntax list') +  call assert_match('cInclude*', a) +  call assert_match('cDefine', a) + +  let a = execute('syntax list cDefine') +  call assert_notmatch('cInclude*', a) +  call assert_match('cDefine', a) +  call assert_match(' links to Macro$', a) + +  call assert_fails('syntax list ABCD', 'E28:') +  call assert_fails('syntax list @ABCD', 'E392:') + +  syntax clear +  let a = execute('syntax list') +  call assert_equal("\nNo Syntax items defined for this buffer", a) + +  bd +endfunc +  func Test_syntax_completion() +  call feedkeys(":syn \<C-A>\<C-B>\"\<CR>", 'tx') +  call assert_equal('"syn case clear cluster conceal enable include iskeyword keyword list manual match off on region reset spell sync', @:) + +  call feedkeys(":syn case \<C-A>\<C-B>\"\<CR>", 'tx') +  call assert_equal('"syn case ignore match', @:) +    call feedkeys(":syn spell \<C-A>\<C-B>\"\<CR>", 'tx')    call assert_equal('"syn spell default notoplevel toplevel', @:)    call feedkeys(":syn sync \<C-A>\<C-B>\"\<CR>", 'tx')    call assert_equal('"syn sync ccomment clear fromstart linebreaks= linecont lines= match maxlines= minlines= region', @:) -endfunc + +  call feedkeys(":syn list \<C-A>\<C-B>\"\<CR>", 'tx') +  call assert_match('^"syn list Boolean Character ', @:) + +  call feedkeys(":syn match \<C-A>\<C-B>\"\<CR>", 'tx') +  call assert_match('^"syn match Boolean Character ', @:) +endfunc
\ No newline at end of file diff --git a/src/nvim/version.c b/src/nvim/version.c index 8015d7520d..e35109a67e 100644 --- a/src/nvim/version.c +++ b/src/nvim/version.c @@ -948,7 +948,7 @@ static const int included_patches[] = {    158,    157,    156, -  // 155, +  155,    // 154,    // 153,    // 152 NA @@ -971,8 +971,8 @@ static const int included_patches[] = {    135,    134,    133, -  // 132, -  // 131, +  132, +  131,    // 130 NA    // 129 NA    128, | 
