Merge pull request #23564 from neovim/backport-23175-to-release-0.9

[Backport release-0.9] vim-patch:9.0.1464: strace filetype detection is expensive
This commit is contained in:
zeertzjq
2023-05-10 15:21:05 +08:00
committed by GitHub
2 changed files with 15 additions and 2 deletions

View File

@@ -1550,8 +1550,15 @@ local patterns_text = {
['^SNNS pattern definition file'] = 'snnspat',
['^SNNS result file'] = 'snnsres',
['^%%.-[Vv]irata'] = { 'virata', { start_lnum = 1, end_lnum = 5 } },
['[0-9:%.]* *execve%('] = 'strace',
['^__libc_start_main'] = 'strace',
function(lines)
if
-- inaccurate fast match first, then use accurate slow match
(lines[1]:find('execve%(') and lines[1]:find('^[0-9:%.]* *execve%('))
or lines[1]:find('^__libc_start_main')
then
return 'strace'
end
end,
-- VSE JCL
['^\\* $$ JOB\\>'] = { 'vsejcl', { vim_regex = true } },
['^// *JOB\\>'] = { 'vsejcl', { vim_regex = true } },

View File

@@ -734,6 +734,11 @@ func Test_filetype_detection()
filetype off
endfunc
" Content lines that should not result in filetype detection
let s:false_positive_checks = {
\ '': [['test execve("/usr/bin/pstree", ["pstree"], 0x7ff0 /* 63 vars */) = 0']],
\ }
" Filetypes detected from the file contents by scripts.vim
let s:script_checks = {
\ 'virata': [['% Virata'],
@@ -826,6 +831,7 @@ func Run_script_detection(test_dict)
endfunc
func Test_script_detection()
call Run_script_detection(s:false_positive_checks)
call Run_script_detection(s:script_checks)
call Run_script_detection(s:script_env_checks)
endfunc