mirror of
https://github.com/neovim/neovim.git
synced 2025-02-25 18:55:25 -06:00
vim-patch:8.2.4746: supercollider filetype not recognized (#18102)
Problem: Supercollider filetype not recognized.
Solution: Match file extentions and check file contents to detect
supercollider. (closes vim/vim#10142)
8cac20ed42
This commit is contained in:
parent
7d1142b7e7
commit
9938740ca6
22
runtime/autoload/dist/ft.vim
vendored
22
runtime/autoload/dist/ft.vim
vendored
@ -773,6 +773,28 @@ func dist#ft#SQL()
|
||||
endif
|
||||
endfunc
|
||||
|
||||
" This function checks the first 25 lines of file extension "sc" to resolve
|
||||
" detection between scala and SuperCollider
|
||||
func dist#ft#FTsc()
|
||||
for lnum in range(1, min([line("$"), 25]))
|
||||
if getline(lnum) =~# '[A-Za-z0-9]*\s:\s[A-Za-z0-9]\|var\s<\|classvar\s<\|\^this.*\||\w*|\|+\s\w*\s{\|\*ar\s'
|
||||
setf supercollider
|
||||
return
|
||||
endif
|
||||
endfor
|
||||
setf scala
|
||||
endfunc
|
||||
|
||||
" This function checks the first line of file extension "scd" to resolve
|
||||
" detection between scdoc and SuperCollider
|
||||
func dist#ft#FTscd()
|
||||
if getline(1) =~# '\%^\S\+(\d[0-9A-Za-z]*)\%(\s\+\"[^"]*\"\%(\s\+\"[^"]*\"\)\=\)\=$'
|
||||
setf scdoc
|
||||
else
|
||||
setf supercollider
|
||||
endif
|
||||
endfunc
|
||||
|
||||
" If the file has an extension of 't' and is in a directory 't' or 'xt' then
|
||||
" it is almost certainly a Perl test file.
|
||||
" If the first line starts with '#' and contains 'perl' it's probably a Perl
|
||||
|
@ -1630,16 +1630,22 @@ au BufNewFile,BufRead *.sass setf sass
|
||||
au BufNewFile,BufRead *.sa setf sather
|
||||
|
||||
" Scala
|
||||
au BufNewFile,BufRead *.scala,*.sc setf scala
|
||||
au BufNewFile,BufRead *.scala setf scala
|
||||
|
||||
" SBT - Scala Build Tool
|
||||
au BufNewFile,BufRead *.sbt setf sbt
|
||||
|
||||
" SuperCollider
|
||||
au BufNewFile,BufRead *.sc call dist#ft#FTsc()
|
||||
|
||||
au BufNewFile,BufRead *.quark setf supercollider
|
||||
|
||||
" scdoc
|
||||
au BufNewFile,BufRead *.scd call dist#ft#FTscd()
|
||||
|
||||
" Scilab
|
||||
au BufNewFile,BufRead *.sci,*.sce setf scilab
|
||||
|
||||
" scdoc
|
||||
au BufNewFile,BufRead *.scd setf scdoc
|
||||
|
||||
" SCSS
|
||||
au BufNewFile,BufRead *.scss setf scss
|
||||
|
@ -569,8 +569,6 @@ local extension = {
|
||||
sa = "sather",
|
||||
sbt = "sbt",
|
||||
scala = "scala",
|
||||
sc = "scala",
|
||||
scd = "scdoc",
|
||||
ss = "scheme",
|
||||
scm = "scheme",
|
||||
sld = "scheme",
|
||||
@ -644,6 +642,7 @@ local extension = {
|
||||
mata = "stata",
|
||||
ado = "stata",
|
||||
stp = "stp",
|
||||
quark = "supercollider",
|
||||
sface = "surface",
|
||||
svelte = "svelte",
|
||||
svg = "svg",
|
||||
@ -830,6 +829,8 @@ local extension = {
|
||||
r = function() vim.fn["dist#ft#FTr"]() end,
|
||||
rdf = function() vim.fn["dist#ft#Redif"]() end,
|
||||
rules = function() vim.fn["dist#ft#FTRules"]() end,
|
||||
sc = function() vim.fn["dist#ft#FTsc"]() end,
|
||||
scd = function() vim.fn["dist#ft#FTscd"]() end,
|
||||
sh = function() vim.fn["dist#ft#SetFileTypeSH"](vim.fn.getline(1)) end,
|
||||
shtml = function() vim.fn["dist#ft#FThtml"]() end,
|
||||
sql = function() vim.fn["dist#ft#SQL"]() end,
|
||||
|
@ -463,12 +463,11 @@ let s:filename_checks = {
|
||||
\ 'sass': ['file.sass'],
|
||||
\ 'sather': ['file.sa'],
|
||||
\ 'sbt': ['file.sbt'],
|
||||
\ 'scala': ['file.scala', 'file.sc'],
|
||||
\ 'scala': ['file.scala'],
|
||||
\ 'scheme': ['file.scm', 'file.ss', 'file.sld', 'file.rkt', 'file.rktd', 'file.rktl'],
|
||||
\ 'scilab': ['file.sci', 'file.sce'],
|
||||
\ 'screen': ['.screenrc', 'screenrc'],
|
||||
\ 'sexplib': ['file.sexp'],
|
||||
\ 'scdoc': ['file.scd'],
|
||||
\ 'scss': ['file.scss'],
|
||||
\ 'sd': ['file.sd'],
|
||||
\ 'sdc': ['file.sdc'],
|
||||
@ -516,6 +515,7 @@ let s:filename_checks = {
|
||||
\ 'stata': ['file.ado', 'file.do', 'file.imata', 'file.mata'],
|
||||
\ 'stp': ['file.stp'],
|
||||
\ 'sudoers': ['any/etc/sudoers', 'sudoers.tmp', '/etc/sudoers', 'any/etc/sudoers.d/file'],
|
||||
\ 'supercollider': ['file.quark'],
|
||||
\ 'surface': ['file.sface'],
|
||||
\ 'svg': ['file.svg'],
|
||||
\ 'svn': ['svn-commitfile.tmp', 'svn-commit-file.tmp', 'svn-commit.tmp'],
|
||||
@ -1470,6 +1470,54 @@ func Test_prg_file()
|
||||
filetype off
|
||||
endfunc
|
||||
|
||||
" Test dist#ft#FTsc()
|
||||
func Test_sc_file()
|
||||
filetype on
|
||||
|
||||
" SC file mehtods are defined 'Class : Method'
|
||||
call writefile(['SCNvimDocRenderer : SCDocHTMLRenderer {'], 'srcfile.sc')
|
||||
split srcfile.sc
|
||||
call assert_equal('supercollider', &filetype)
|
||||
bwipe!
|
||||
call delete('srcfile.sc')
|
||||
|
||||
" SC classes are defined with '+ Class {}'
|
||||
call writefile(['+ SCNvim {', '*methodArgs {|method|'], 'srcfile.sc')
|
||||
split srcfile.sc
|
||||
call assert_equal('supercollider', &filetype)
|
||||
bwipe!
|
||||
call delete('srcfile.sc')
|
||||
|
||||
" Some SC class files start with comment and define methods many lines later
|
||||
call writefile(['// Query', '//Method','^this {'], 'srcfile.sc')
|
||||
split srcfile.sc
|
||||
call assert_equal('supercollider', &filetype)
|
||||
bwipe!
|
||||
call delete('srcfile.sc')
|
||||
|
||||
" Some SC class files put comments between method declaration after class
|
||||
call writefile(['PingPong {', '//comment','*ar { arg'], 'srcfile.sc')
|
||||
split srcfile.sc
|
||||
call assert_equal('supercollider', &filetype)
|
||||
bwipe!
|
||||
call delete('srcfile.sc')
|
||||
|
||||
filetype off
|
||||
endfunc
|
||||
|
||||
" Test dist#ft#FTscd()
|
||||
func Test_scd_file()
|
||||
filetype on
|
||||
|
||||
call writefile(['ijq(1)'], 'srcfile.scd')
|
||||
split srcfile.scd
|
||||
call assert_equal('scdoc', &filetype)
|
||||
bwipe!
|
||||
call delete('srcfile.scd')
|
||||
|
||||
filetype off
|
||||
endfunc
|
||||
|
||||
func Test_src_file()
|
||||
filetype on
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user