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:
Bram Moolenaar
2022-06-29 14:39:12 +01:00
parent 040674129f
commit 8b5901e2f9
5 changed files with 90 additions and 22 deletions

View File

@ -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

View File

@ -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|

View File

@ -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

View File

@ -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

View File

@ -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,
/**/ /**/