runtime(compilers): ensure compiler! sets global options (#14336)
Previously some options were only set locally by &l:makeprg/errorformat This suffices for :compiler (without a trailing bang) but falls short for :compiler! that sets &g:makeprg/errorformat as well Also apply kind suggestions by @dkearns and @lifepillar Signed-off-by: Konfekt <Konfekt@users.noreply.github.com> Signed-off-by: Doug Kearns <dougkearns@gmail.com> Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
		| @ -1,7 +1,8 @@ | |||||||
| " Vim compiler file | " Vim compiler file | ||||||
| " Compiler:             BDF to PCF Conversion | " Compiler:             BDF to PCF Conversion | ||||||
| " Previous Maintainer:  Nikolai Weibull <now@bitwi.se> | " Previous Maintainer:  Nikolai Weibull <now@bitwi.se> | ||||||
| " Latest Revision:      2006-04-19 | " Contributors:         Enno Nagel | ||||||
|  | " Last Change:          2024 Mar 29 | ||||||
|  |  | ||||||
| if exists("current_compiler") | if exists("current_compiler") | ||||||
|   finish |   finish | ||||||
| @ -11,9 +12,12 @@ let current_compiler = "bdf" | |||||||
| let s:cpo_save = &cpo | let s:cpo_save = &cpo | ||||||
| set cpo-=C | set cpo-=C | ||||||
|  |  | ||||||
| setlocal makeprg=bdftopcf\ $* | if exists(":CompilerSet") != 2 " Older Vim always used :setlocal | ||||||
|  |   command -nargs=* CompilerSet setlocal <args> | ||||||
|  | endif | ||||||
|  |  | ||||||
| setlocal errorformat=%ABDF\ %trror\ on\ line\ %l:\ %m, | CompilerSet makeprg=bdftopcf\ $* | ||||||
|  | CompilerSet errorformat=%ABDF\ %trror\ on\ line\ %l:\ %m, | ||||||
|       \%-Z%p^, |       \%-Z%p^, | ||||||
|       \%Cbdftopcf:\ bdf\ input\\,\ %f\\,\ corrupt, |       \%Cbdftopcf:\ bdf\ input\\,\ %f\\,\ corrupt, | ||||||
|       \%-G%.%# |       \%-G%.%# | ||||||
|  | |||||||
| @ -3,7 +3,8 @@ vim9script | |||||||
| # Language:           ConTeXt typesetting engine | # Language:           ConTeXt typesetting engine | ||||||
| # Maintainer:         Nicola Vitacolonna <nvitacolonna@gmail.com> | # Maintainer:         Nicola Vitacolonna <nvitacolonna@gmail.com> | ||||||
| # Former Maintainers: Nikolai Weibull <now@bitwi.se> | # Former Maintainers: Nikolai Weibull <now@bitwi.se> | ||||||
| # Latest Revision:    2023 Dec 26 | # Contributors:       Enno Nagel | ||||||
|  | # Last Change:        2024 Mar 29 | ||||||
|  |  | ||||||
| if exists("g:current_compiler") | if exists("g:current_compiler") | ||||||
|   finish |   finish | ||||||
| @ -19,7 +20,8 @@ g:current_compiler = 'context' | |||||||
|  |  | ||||||
| if get(b:, 'context_ignore_makefile', get(g:, 'context_ignore_makefile', 0)) || | if get(b:, 'context_ignore_makefile', get(g:, 'context_ignore_makefile', 0)) || | ||||||
|   (!filereadable('Makefile') && !filereadable('makefile')) |   (!filereadable('Makefile') && !filereadable('makefile')) | ||||||
|   &l:makeprg =  join(context.ConTeXtCmd(shellescape(expand('%:p:t'))), ' ') |   var makeprg =  join(context.ConTeXtCmd(shellescape(expand('%:p:t'))), ' ') | ||||||
|  |   execute 'CompilerSet makeprg=' .. escape(makeprg, ' ') | ||||||
| else | else | ||||||
|   g:current_compiler = 'make' |   g:current_compiler = 'make' | ||||||
| endif | endif | ||||||
|  | |||||||
| @ -1,8 +1,8 @@ | |||||||
| " Vim compiler file | " Vim compiler file | ||||||
| " Compiler:    Mono C# Compiler | " Compiler:     Mono C# Compiler | ||||||
| " Maintainer:  Jarek Sobiecki <harijari@go2.pl> | " Maintainer:   Jarek Sobiecki <harijari@go2.pl> | ||||||
| " Last Updated By: Peter Collingbourne | " Contributors: Peter Collingbourne and Enno Nagel | ||||||
| " Latest Revision: 2012 Jul 19 | " Last Change:  2024 Mar 29 | ||||||
|  |  | ||||||
| if exists("current_compiler") | if exists("current_compiler") | ||||||
|   finish |   finish | ||||||
| @ -12,7 +12,12 @@ let current_compiler = "mcs" | |||||||
| let s:cpo_save = &cpo | let s:cpo_save = &cpo | ||||||
| set cpo-=C | set cpo-=C | ||||||
|  |  | ||||||
| setlocal errorformat= | if exists(":CompilerSet") != 2 " Older Vim always used :setlocal | ||||||
|  |   command -nargs=* CompilerSet setlocal <args> | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | CompilerSet makeprg=mcs | ||||||
|  | CompilerSet errorformat= | ||||||
|          \%D%.%#Project\ \"%f/%[%^/\"]%#\"%.%#, |          \%D%.%#Project\ \"%f/%[%^/\"]%#\"%.%#, | ||||||
|          \%X%.%#Done\ building\ project\ \"%f/%[%^/\"]%#\"%.%#, |          \%X%.%#Done\ building\ project\ \"%f/%[%^/\"]%#\"%.%#, | ||||||
|          \%-G%\\s%.%#, |          \%-G%\\s%.%#, | ||||||
|  | |||||||
| @ -1,7 +1,8 @@ | |||||||
| " Vim Compiler File | " Vim Compiler File | ||||||
| " Compiler:	Modelsim Vcom | " Compiler:	Modelsim Vcom | ||||||
| " Maintainer:	Paul Baleme <pbaleme@mail.com> | " Maintainer:	Paul Baleme <pbaleme@mail.com> | ||||||
| " Last Change:	September 8, 2003 | " Contributors: Enno Nagel | ||||||
|  | " Last Change:	2024 Mar 29 | ||||||
| " Thanks to:    allanherriman@hotmail.com | " Thanks to:    allanherriman@hotmail.com | ||||||
|  |  | ||||||
| if exists("current_compiler") | if exists("current_compiler") | ||||||
| @ -13,8 +14,9 @@ if exists(":CompilerSet") != 2		" older Vim always used :setlocal | |||||||
|   command -nargs=* CompilerSet setlocal <args> |   command -nargs=* CompilerSet setlocal <args> | ||||||
| endif | endif | ||||||
|  |  | ||||||
| "setlocal errorformat=\*\*\ %tRROR:\ %f(%l):\ %m,%tRROR:\ %f(%l):\ %m,%tARNING\[%*[0-9]\]:\ %f(%l):\ %m,\*\*\ %tRROR:\ %m,%tRROR:\ %m,%tARNING\[%*[0-9]\]:\ %m | CompilerSet makeprg=vcom | ||||||
|  |  | ||||||
|  | "setlocal errorformat=\*\*\ %tRROR:\ %f(%l):\ %m,%tRROR:\ %f(%l):\ %m,%tARNING\[%*[0-9]\]:\ %f(%l):\ %m,\*\*\ %tRROR:\ %m,%tRROR:\ %m,%tARNING\[%*[0-9]\]:\ %m | ||||||
| "setlocal errorformat=%tRROR:\ %f(%l):\ %m,%tARNING\[%*[0-9]\]:\ %m | "setlocal errorformat=%tRROR:\ %f(%l):\ %m,%tARNING\[%*[0-9]\]:\ %m | ||||||
| CompilerSet errorformat=\*\*\ %tRROR:\ %f(%l):\ %m,\*\*\ %tRROR:\ %m,\*\*\ %tARNING:\ %m,\*\*\ %tOTE:\ %m,%tRROR:\ %f(%l):\ %m,%tARNING\[%*[0-9]\]:\ %f(%l):\ %m,%tRROR:\ %m,%tARNING\[%*[0-9]\]:\ %m | CompilerSet errorformat=\*\*\ %tRROR:\ %f(%l):\ %m,\*\*\ %tRROR:\ %m,\*\*\ %tARNING:\ %m,\*\*\ %tOTE:\ %m,%tRROR:\ %f(%l):\ %m,%tARNING\[%*[0-9]\]:\ %f(%l):\ %m,%tRROR:\ %m,%tARNING\[%*[0-9]\]:\ %m | ||||||
|  |  | ||||||
|  | |||||||
| @ -1,7 +1,8 @@ | |||||||
| " Vim compiler file | " Vim compiler file | ||||||
| " Compiler:	powershell | " Compiler:	powershell | ||||||
| " URL: https://github.com/PProvost/vim-ps1 | " URL: https://github.com/PProvost/vim-ps1 | ||||||
| " Last Change: 2020 Mar 30 | " Contributors: Enno Nagel | ||||||
|  | " Last Change: 2024 Mar 29 | ||||||
|  |  | ||||||
| if exists("current_compiler") | if exists("current_compiler") | ||||||
|   finish |   finish | ||||||
| @ -37,7 +38,7 @@ let g:ps1_efm_show_error_categories = get(g:, 'ps1_efm_show_error_categories', 0 | |||||||
|  |  | ||||||
| " Use absolute path because powershell requires explicit relative paths | " Use absolute path because powershell requires explicit relative paths | ||||||
| " (./file.ps1 is okay, but # expands to file.ps1) | " (./file.ps1 is okay, but # expands to file.ps1) | ||||||
| let &l:makeprg = g:ps1_makeprg_cmd .' %:p:S' | let makeprg = g:ps1_makeprg_cmd .. ' %:p:S' | ||||||
|  |  | ||||||
| " Parse file, line, char from callstacks: | " Parse file, line, char from callstacks: | ||||||
| "     Write-Ouput : The term 'Write-Ouput' is not recognized as the name of a | "     Write-Ouput : The term 'Write-Ouput' is not recognized as the name of a | ||||||
| @ -50,6 +51,8 @@ let &l:makeprg = g:ps1_makeprg_cmd .' %:p:S' | |||||||
| "         + CategoryInfo          : ObjectNotFound: (Write-Ouput:String) [], CommandNotFoundException | "         + CategoryInfo          : ObjectNotFound: (Write-Ouput:String) [], CommandNotFoundException | ||||||
| "         + FullyQualifiedErrorId : CommandNotFoundException | "         + FullyQualifiedErrorId : CommandNotFoundException | ||||||
|  |  | ||||||
|  | execute 'CompilerSet makeprg=' .. escape(makeprg, ' ') | ||||||
|  |  | ||||||
| " Showing error in context with underlining. | " Showing error in context with underlining. | ||||||
| CompilerSet errorformat=%+G+%m | CompilerSet errorformat=%+G+%m | ||||||
| " Error summary. | " Error summary. | ||||||
|  | |||||||
| @ -1,7 +1,8 @@ | |||||||
| " Vim compiler file | " Vim compiler file | ||||||
| " Compiler:     TeX | " Compiler:     TeX | ||||||
| " Maintainer:   Artem Chuprina <ran@ran.pp.ru> | " Maintainer:   Artem Chuprina <ran@ran.pp.ru> | ||||||
| " Last Change:  2012 Apr 30 | " Contributors: Enno Nagel | ||||||
|  | " Last Change:  2024 Mar 29 | ||||||
|  |  | ||||||
| if exists("current_compiler") | if exists("current_compiler") | ||||||
| 	finish | 	finish | ||||||
| @ -27,7 +28,8 @@ if exists('b:tex_ignore_makefile') || exists('g:tex_ignore_makefile') || | |||||||
| 	else | 	else | ||||||
| 		let current_compiler = "latex" | 		let current_compiler = "latex" | ||||||
| 	endif | 	endif | ||||||
| 	let &l:makeprg=current_compiler.' -interaction=nonstopmode' | 	let makeprg=current_compiler .. ' -interaction=nonstopmode' | ||||||
|  | 	execute 'CompilerSet makeprg=' .. escape(makeprg, ' ') | ||||||
| else | else | ||||||
| 	let current_compiler = 'make' | 	let current_compiler = 'make' | ||||||
| endif | endif | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user