forked from aniani/vim
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:
50
runtime/autoload/dist/ft.vim
vendored
50
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
|
|
||||||
elseif match(lines, qb64_preproc) > -1
|
|
||||||
setf qb64
|
|
||||||
elseif match(lines, ft_visual_basic_content) > -1
|
|
||||||
setf vb
|
setf vb
|
||||||
else
|
return
|
||||||
setf basic
|
elseif line =~ fb_preproc || line =~ fb_comment || line =~ fb_keywords
|
||||||
|
setf freebasic
|
||||||
|
return
|
||||||
|
elseif line =~ qb64_preproc
|
||||||
|
setf qb64
|
||||||
|
return
|
||||||
endif
|
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