patch 9.0.0006: not all Visual Basic files are recognized
Problem: Not all Visual Basic files are recognized. Solution: Change detection of *.cls files. (Doug Kearns)
This commit is contained in:
		
							
								
								
									
										54
									
								
								runtime/autoload/dist/ft.vim
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										54
									
								
								runtime/autoload/dist/ft.vim
									
									
									
									
										vendored
									
									
								
							| @ -72,22 +72,35 @@ export def FTbas() | |||||||
|  |  | ||||||
|   # most frequent FreeBASIC-specific keywords in distro files |   # most frequent FreeBASIC-specific keywords in distro files | ||||||
|   var fb_keywords = '\c^\s*\%(extern\|var\|enum\|private\|scope\|union\|byref\|operator\|constructor\|delete\|namespace\|public\|property\|with\|destructor\|using\)\>\%(\s*[:=(]\)\@!' |   var fb_keywords = '\c^\s*\%(extern\|var\|enum\|private\|scope\|union\|byref\|operator\|constructor\|delete\|namespace\|public\|property\|with\|destructor\|using\)\>\%(\s*[:=(]\)\@!' | ||||||
|   var fb_preproc  = '\c^\s*\%(#\a\+\|option\s\+\%(byval\|dynamic\|escape\|\%(no\)\=gosub\|nokeyword\|private\|static\)\>\)' |   var fb_preproc  = '\c^\s*\%(' .. | ||||||
|  |                       # preprocessor | ||||||
|  |                       '#\s*\a\+\|' .. | ||||||
|  |                       # compiler option | ||||||
|  |                       'option\s\+\%(byval\|dynamic\|escape\|\%(no\)\=gosub\|nokeyword\|private\|static\)\>\|' .. | ||||||
|  |                       # metacommand | ||||||
|  |                       '\%(''\|rem\)\s*\$lang\>\|' .. | ||||||
|  |                       # default datatype | ||||||
|  |                       'def\%(byte\|longint\|short\|ubyte\|uint\|ulongint\|ushort\)\>' .. | ||||||
|  |                     '\)' | ||||||
|   var fb_comment  = "^\\s*/'" |   var fb_comment  = "^\\s*/'" | ||||||
|  |  | ||||||
|   # OPTION EXPLICIT, without the leading underscore, is common to many dialects |   # OPTION EXPLICIT, without the leading underscore, is common to many dialects | ||||||
|   var qb64_preproc = '\c^\s*\%($\a\+\|option\s\+\%(_explicit\|_\=explicitarray\)\>\)' |   var qb64_preproc = '\c^\s*\%($\a\+\|option\s\+\%(_explicit\|_\=explicitarray\)\>\)' | ||||||
|  |  | ||||||
|   var lines = getline(1, min([line("$"), 100])) |   for lnum in range(1, min([line("$"), 100])) | ||||||
|  |     var line = getline(lnum) | ||||||
|   if match(lines, fb_preproc) > -1 || match(lines, fb_comment) > -1 || match(lines, fb_keywords) > -1 |     if line =~ ft_visual_basic_content | ||||||
|     setf freebasic |       setf vb | ||||||
|   elseif match(lines, qb64_preproc) > -1 |       return | ||||||
|     setf qb64 |     elseif line =~ fb_preproc || line =~ fb_comment || line =~ fb_keywords | ||||||
|   elseif match(lines, ft_visual_basic_content) > -1 |       setf freebasic | ||||||
|     setf vb |       return | ||||||
|   else |     elseif line =~ qb64_preproc | ||||||
|     setf basic |       setf qb64 | ||||||
|   endif |       return | ||||||
|  |     endif | ||||||
|  |   endfor | ||||||
|  |   setf basic | ||||||
| enddef | enddef | ||||||
|  |  | ||||||
| export def FTbtm() | export def FTbtm() | ||||||
| @ -126,6 +139,23 @@ export def FTcfg() | |||||||
|   endif |   endif | ||||||
| enddef | enddef | ||||||
|  |  | ||||||
|  | export def FTcls() | ||||||
|  |   if exists("g:filetype_cls") | ||||||
|  |     exe "setf " .. g:filetype_cls | ||||||
|  |     return | ||||||
|  |   endif | ||||||
|  |  | ||||||
|  |   if getline(1) =~ '^%' | ||||||
|  |     setf tex | ||||||
|  |   elseif getline(1)[0] == '#' && getline(1) =~ 'rexx' | ||||||
|  |     setf rexx | ||||||
|  |   elseif getline(1) == 'VERSION 1.0 CLASS' | ||||||
|  |     setf vb | ||||||
|  |   else | ||||||
|  |     setf st | ||||||
|  |   endif | ||||||
|  | enddef | ||||||
|  |  | ||||||
| export def FTlpc() | export def FTlpc() | ||||||
|   if exists("g:lpc_syntax_for_c") |   if exists("g:lpc_syntax_for_c") | ||||||
|     var lnum = 1 |     var lnum = 1 | ||||||
|  | |||||||
| @ -143,6 +143,7 @@ variables can be used to overrule the filetype used for certain extensions: | |||||||
| 	*.asp		g:filetype_asp	|ft-aspvbs-syntax| |ft-aspperl-syntax| | 	*.asp		g:filetype_asp	|ft-aspvbs-syntax| |ft-aspperl-syntax| | ||||||
| 	*.bas		g:filetype_bas	|ft-basic-syntax| | 	*.bas		g:filetype_bas	|ft-basic-syntax| | ||||||
| 	*.cfg		g:filetype_cfg | 	*.cfg		g:filetype_cfg | ||||||
|  | 	*.cls		g:filetype_cls | ||||||
| 	*.csh		g:filetype_csh	|ft-csh-syntax| | 	*.csh		g:filetype_csh	|ft-csh-syntax| | ||||||
| 	*.dat		g:filetype_dat | 	*.dat		g:filetype_dat | ||||||
| 	*.frm		g:filetype_frm	|ft-form-syntax| | 	*.frm		g:filetype_frm	|ft-form-syntax| | ||||||
|  | |||||||
| @ -1798,16 +1798,11 @@ au BufNewFile,BufRead *.il,*.ils,*.cdf		setf skill | |||||||
| au BufNewFile,BufRead .slrnrc			setf slrnrc | au BufNewFile,BufRead .slrnrc			setf slrnrc | ||||||
| au BufNewFile,BufRead *.score			setf slrnsc | au BufNewFile,BufRead *.score			setf slrnsc | ||||||
|  |  | ||||||
| " Smalltalk (and TeX) | " Smalltalk | ||||||
| au BufNewFile,BufRead *.st			setf st | au BufNewFile,BufRead *.st			setf st | ||||||
| au BufNewFile,BufRead *.cls |  | ||||||
| 	\ if getline(1) =~ '^%' | | " Smalltalk (and Rexx, TeX, and Visual Basic) | ||||||
| 	\  setf tex | | au BufNewFile,BufRead *.cls                     call dist#ft#FTcls() | ||||||
| 	\ elseif getline(1)[0] == '#' && getline(1) =~ 'rexx' | |  | ||||||
| 	\  setf rexx | |  | ||||||
| 	\ else | |  | ||||||
| 	\  setf st | |  | ||||||
| 	\ endif |  | ||||||
|  |  | ||||||
| " Smarty templates | " Smarty templates | ||||||
| au BufNewFile,BufRead *.tpl			setf smarty | au BufNewFile,BufRead *.tpl			setf smarty | ||||||
|  | |||||||
| @ -837,7 +837,7 @@ func Test_bas_file() | |||||||
|  |  | ||||||
|   " Visual Basic |   " Visual Basic | ||||||
|  |  | ||||||
|   call writefile(['Attribute VB_NAME = "Testing"'], 'Xfile.bas') |   call writefile(['Attribute VB_NAME = "Testing"', 'Enum Foo', 'End Enum'], 'Xfile.bas') | ||||||
|   split Xfile.bas |   split Xfile.bas | ||||||
|   call assert_equal('vb', &filetype) |   call assert_equal('vb', &filetype) | ||||||
|   bwipe! |   bwipe! | ||||||
| @ -1719,5 +1719,45 @@ func Test_xpm_file() | |||||||
|   filetype off |   filetype off | ||||||
| endfunc | endfunc | ||||||
|  |  | ||||||
|  | func Test_cls_file() | ||||||
|  |   filetype on | ||||||
|  |  | ||||||
|  |   call writefile(['looks like Smalltalk'], 'Xfile.cls') | ||||||
|  |   split Xfile.cls | ||||||
|  |   call assert_equal('st', &filetype) | ||||||
|  |   bwipe! | ||||||
|  |  | ||||||
|  |   " Test dist#ft#FTcls() | ||||||
|  |  | ||||||
|  |   let g:filetype_cls = 'vb' | ||||||
|  |   split Xfile.cls | ||||||
|  |   call assert_equal('vb', &filetype) | ||||||
|  |   bwipe! | ||||||
|  |   unlet g:filetype_cls | ||||||
|  |  | ||||||
|  |   " TeX | ||||||
|  |  | ||||||
|  |   call writefile(['%'], 'Xfile.cls') | ||||||
|  |   split Xfile.cls | ||||||
|  |   call assert_equal('tex', &filetype) | ||||||
|  |   bwipe! | ||||||
|  |  | ||||||
|  |   " Rexx | ||||||
|  |  | ||||||
|  |   call writefile(['# rexx'], 'Xfile.cls') | ||||||
|  |   split Xfile.cls | ||||||
|  |   call assert_equal('rexx', &filetype) | ||||||
|  |   bwipe! | ||||||
|  |  | ||||||
|  |   " Visual Basic | ||||||
|  |  | ||||||
|  |   call writefile(['VERSION 1.0 CLASS'], 'Xfile.cls') | ||||||
|  |   split Xfile.cls | ||||||
|  |   call assert_equal('vb', &filetype) | ||||||
|  |   bwipe! | ||||||
|  |  | ||||||
|  |   call delete('Xfile.cls') | ||||||
|  |   filetype off | ||||||
|  | endfunc | ||||||
|  |  | ||||||
| " vim: shiftwidth=2 sts=2 expandtab | " vim: shiftwidth=2 sts=2 expandtab | ||||||
|  | |||||||
| @ -735,6 +735,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 */ | ||||||
|  | /**/ | ||||||
|  |     6, | ||||||
| /**/ | /**/ | ||||||
|     5, |     5, | ||||||
| /**/ | /**/ | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user