patch 8.2.3399: Octave files are not recognized

Problem:    Octave files are not recognized.
Solution:   Detect Octave files. (Doug Kearns)
This commit is contained in:
Bram Moolenaar
2021-09-03 19:21:36 +02:00
parent af631f61bc
commit deba5eb195
5 changed files with 116 additions and 5 deletions

View File

@ -264,6 +264,13 @@ func dist#ft#ProtoCheck(default)
endfunc endfunc
func dist#ft#FTm() func dist#ft#FTm()
if exists("g:filetype_m")
exe "setf " . g:filetype_m
return
endif
let octave_block_terminators = '\<end\%(_try_catch\|classdef\|enumeration\|events\|for\|function\|if\|methods\|parfor\|properties\|switch\|while\)\>'
let n = 1 let n = 1
let saw_comment = 0 " Whether we've seen a multiline comment leader. let saw_comment = 0 " Whether we've seen a multiline comment leader.
while n < 100 while n < 100
@ -278,6 +285,13 @@ func dist#ft#FTm()
setf objc setf objc
return return
endif endif
if line =~ '^\s*\%(#\|%!\|[#%]{\=\s*$\)' ||
\ line =~ '^\s*unwind_protect\>' ||
\ line =~ '\%(^\|;\)\s*' .. octave_block_terminators
setf octave
return
endif
" TODO: could be Matlab or Octave
if line =~ '^\s*%' if line =~ '^\s*%'
setf matlab setf matlab
return return
@ -298,11 +312,8 @@ func dist#ft#FTm()
" or Murphi based on the comment leader. Assume the former as it is more " or Murphi based on the comment leader. Assume the former as it is more
" common. " common.
setf objc setf objc
elseif exists("g:filetype_m")
" Use user specified default filetype for .m
exe "setf " . g:filetype_m
else else
" Default is matlab " Default is Matlab
setf matlab setf matlab
endif endif
endfunc endfunc

View File

@ -146,6 +146,7 @@ can be used to overrule the filetype used for certain extensions:
*.inc g:filetype_inc *.inc g:filetype_inc
*.w g:filetype_w |ft-cweb-syntax| *.w g:filetype_w |ft-cweb-syntax|
*.i g:filetype_i |ft-progress-syntax| *.i g:filetype_i |ft-progress-syntax|
*.m g:filetype_m |ft-mathematica-syntax|
*.p g:filetype_p |ft-pascal-syntax| *.p g:filetype_p |ft-pascal-syntax|
*.pp g:filetype_pp |ft-pascal-syntax| *.pp g:filetype_pp |ft-pascal-syntax|
*.sh g:bash_is_sh |ft-sh-syntax| *.sh g:bash_is_sh |ft-sh-syntax|

View File

@ -1029,7 +1029,7 @@ au BufNewFile,BufRead *.markdown,*.mdown,*.mkd,*.mkdn,*.mdwn,*.md setf markdown
" Mason " Mason
au BufNewFile,BufRead *.mason,*.mhtml,*.comp setf mason au BufNewFile,BufRead *.mason,*.mhtml,*.comp setf mason
" Mathematica, Matlab, Murphi or Objective C " Mathematica, Matlab, Murphi, Objective C or Octave
au BufNewFile,BufRead *.m call dist#ft#FTm() au BufNewFile,BufRead *.m call dist#ft#FTm()
" Mathematica notebook " Mathematica notebook
@ -1175,6 +1175,9 @@ au BufNewFile,BufRead *.ml,*.mli,*.mll,*.mly,.ocamlinit,*.mlt,*.mlp,*.mlip,*.mli
" Occam " Occam
au BufNewFile,BufRead *.occ setf occam au BufNewFile,BufRead *.occ setf occam
" Octave
au BufNewFile,BufRead octave.conf,.octaverc,octaverc setf octave
" Omnimark " Omnimark
au BufNewFile,BufRead *.xom,*.xin setf omnimark au BufNewFile,BufRead *.xom,*.xin setf omnimark

View File

@ -295,6 +295,7 @@ let s:filename_checks = {
\ 'lss': ['file.lss'], \ 'lss': ['file.lss'],
\ 'lua': ['file.lua', 'file.rockspec', 'file.nse'], \ 'lua': ['file.lua', 'file.rockspec', 'file.nse'],
\ 'lynx': ['lynx.cfg'], \ 'lynx': ['lynx.cfg'],
\ 'matlab': ['file.m'],
\ 'm3build': ['m3makefile', 'm3overrides'], \ 'm3build': ['m3makefile', 'm3overrides'],
\ 'm3quake': ['file.quake', 'cm3.cfg'], \ 'm3quake': ['file.quake', 'cm3.cfg'],
\ 'm4': ['file.at'], \ 'm4': ['file.at'],
@ -351,6 +352,7 @@ let s:filename_checks = {
\ 'obj': ['file.obj'], \ 'obj': ['file.obj'],
\ 'ocaml': ['file.ml', 'file.mli', 'file.mll', 'file.mly', '.ocamlinit', 'file.mlt', 'file.mlp', 'file.mlip', 'file.mli.cppo', 'file.ml.cppo'], \ 'ocaml': ['file.ml', 'file.mli', 'file.mll', 'file.mly', '.ocamlinit', 'file.mlt', 'file.mlp', 'file.mlip', 'file.mli.cppo', 'file.ml.cppo'],
\ 'occam': ['file.occ'], \ 'occam': ['file.occ'],
\ 'octave': ['octaverc', '.octaverc', 'octave.conf'],
\ 'omnimark': ['file.xom', 'file.xin'], \ 'omnimark': ['file.xom', 'file.xin'],
\ 'opam': ['opam', 'file.opam', 'file.opam.template'], \ 'opam': ['opam', 'file.opam', 'file.opam.template'],
\ 'openroad': ['file.or'], \ 'openroad': ['file.or'],
@ -851,4 +853,96 @@ func Test_dsl_file()
filetype off filetype off
endfunc endfunc
func Test_m_file()
filetype on
call writefile(['looks like Matlab'], 'Xfile.m')
split Xfile.m
call assert_equal('matlab', &filetype)
bwipe!
let g:filetype_m = 'octave'
split Xfile.m
call assert_equal('octave', &filetype)
bwipe!
unlet g:filetype_m
" Test dist#ft#FTm()
" Objective-C
call writefile(['// Objective-C line comment'], 'Xfile.m')
split Xfile.m
call assert_equal('objc', &filetype)
bwipe!
call writefile(['/* Objective-C block comment */'], 'Xfile.m')
split Xfile.m
call assert_equal('objc', &filetype)
bwipe!
call writefile(['#import "test.m"'], 'Xfile.m')
split Xfile.m
call assert_equal('objc', &filetype)
bwipe!
" Octave
call writefile(['# Octave line comment'], 'Xfile.m')
split Xfile.m
call assert_equal('octave', &filetype)
bwipe!
call writefile(['#{', 'Octave block comment', '#}'], 'Xfile.m')
split Xfile.m
call assert_equal('octave', &filetype)
bwipe!
call writefile(['%{', 'Octave block comment', '%}'], 'Xfile.m')
split Xfile.m
call assert_equal('octave', &filetype)
bwipe!
call writefile(['%!test "Octave test"'], 'Xfile.m')
split Xfile.m
call assert_equal('octave', &filetype)
bwipe!
call writefile(['unwind_protect'], 'Xfile.m')
split Xfile.m
call assert_equal('octave', &filetype)
bwipe!
call writefile(['function test(); 42; endfunction'], 'Xfile.m')
split Xfile.m
call assert_equal('octave', &filetype)
bwipe!
" Mathematica
call writefile(['(* Mathematica comment'], 'Xfile.m')
split Xfile.m
call assert_equal('mma', &filetype)
bwipe!
" Murphi
call writefile(['-- Murphi comment'], 'Xfile.m')
split Xfile.m
call assert_equal('murphi', &filetype)
bwipe!
call writefile(['/* Murphi block comment */', 'Type'], 'Xfile.m')
split Xfile.m
call assert_equal('murphi', &filetype)
bwipe!
call writefile(['Type'], 'Xfile.m')
split Xfile.m
call assert_equal('murphi', &filetype)
bwipe!
call delete('Xfile.m')
filetype off
endfunc
" vim: shiftwidth=2 sts=2 expandtab " vim: shiftwidth=2 sts=2 expandtab

View File

@ -755,6 +755,8 @@ static char *(features[]) =
static int included_patches[] = static int included_patches[] =
{ /* Add new patch number below this line */ { /* Add new patch number below this line */
/**/
3399,
/**/ /**/
3398, 3398,
/**/ /**/