patch 8.2.4746: supercollider filetype not recognized
Problem:    Supercollider filetype not recognized.
Solution:   Match file extentions and check file contents to detect
            supercollider. (closes #10142)
			
			
This commit is contained in:
		
				
					committed by
					
						 Bram Moolenaar
						Bram Moolenaar
					
				
			
			
				
	
			
			
			
						parent
						
							aae9762b2c
						
					
				
				
					commit
					8cac20ed42
				
			
							
								
								
									
										22
									
								
								runtime/autoload/dist/ft.vim
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										22
									
								
								runtime/autoload/dist/ft.vim
									
									
									
									
										vendored
									
									
								
							| @ -769,6 +769,28 @@ export def SQL() | ||||
|   endif | ||||
| enddef | ||||
|  | ||||
| # This function checks the first 25 lines of file extension "sc" to resolve | ||||
| # detection between scala and SuperCollider | ||||
| export def 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 | ||||
| enddef | ||||
|  | ||||
| # This function checks the first line of file extension "scd" to resolve | ||||
| # detection between scdoc and SuperCollider | ||||
| export def FTscd() | ||||
|   if getline(1) =~# '\%^\S\+(\d[0-9A-Za-z]*)\%(\s\+\"[^"]*\"\%(\s\+\"[^"]*\"\)\=\)\=$' | ||||
|     setf scdoc | ||||
|   else | ||||
|     setf supercollider | ||||
|   endif | ||||
| enddef | ||||
|  | ||||
| # 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 | ||||
|  | ||||
| @ -1634,16 +1634,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 | ||||
|  | ||||
| @ -464,12 +464,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'], | ||||
| @ -517,6 +516,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'], | ||||
| @ -1497,6 +1497,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 | ||||
|  | ||||
|  | ||||
| @ -746,6 +746,8 @@ static char *(features[]) = | ||||
|  | ||||
| static int included_patches[] = | ||||
| {   /* Add new patch number below this line */ | ||||
| /**/ | ||||
|     4746, | ||||
| /**/ | ||||
|     4745, | ||||
| /**/ | ||||
|  | ||||
		Reference in New Issue
	
	Block a user