mirror of
https://github.com/vim/vim
synced 2025-03-15 06:17:51 +01:00
Update to the ConTeXt runtime files. Changes: 1. shared syntax files updated with `mtxrun --script interface --vim` using the latest ConTeXt LMTX. 2. fixed reference to `make` tag in the help file. 3. added `keepend` to mitigate issues with embedded Lua syntax (see below). 4. the latest revision date of each ConTeXt runtime file has been updated to the date of this commit. The issue about embedded Lua was reported by a user: >Take the following valid ConTeXt file: > \starttext > \ctxlua{context("Text generated from Lua.")} > \ctxlua{context("Another text generated from Lua.")} > \stoptext >On my Vim installation (including when I start Vim with `--clean`), the >closing bracket and curly braces on line 2 are highlighted red and the >syntax highlighting after that is off. >I was trying to dig a little bit into what was going on, using the >`synID()` and `synIDattr()` functions. It appears that the closing >bracket on line 2 is matched as a `luaParentError` instead of the end >of the `luaParen` region. Therefore, the `luaParen` region continues >all the way to the end of the file. The closing curly brace on line >2 is matched as a `luaError`, the 2nd `\ctxlua` on line 3 as >`luaParen`, etc. >This issue doesn't occur in a plain Lua file, where the closing bracket >is correctly matched as the end of the `luaParen` region. So it seems >that something goes wrong when the Lua syntax file is included in the >ConTeXt one. By adding `keepend`, the right parenthesis for some reason is still highlighted as a `luaParenError`, but at least the right curly brace should correctly end the Lua block. From what I've seen, I think it is very difficult to embed Lua syntax properly without help from the Lua syntax file (that is, without patching it). It has global rules such as: syn match luaParenError ")" syn match luaError "}" which make it difficult, if not impossible, to contain Lua syntax without `keepend` (and its limitations). Signed-off-by: Lifepillar <lifepillar@lifepillar.me> Signed-off-by: Christian Brabandt <cb@256bit.org>
100 lines
2.5 KiB
VimL
100 lines
2.5 KiB
VimL
vim9script
|
|
|
|
# Language: ConTeXt typesetting engine
|
|
# Maintainer: Nicola Vitacolonna <nvitacolonna@gmail.com>
|
|
# Former Maintainers: Nikolai Weibull <now@bitwi.se>
|
|
# Latest Revision: 2023 Dec 26
|
|
|
|
# Typesetting {{{
|
|
import autoload './typeset.vim'
|
|
|
|
export def ConTeXtCmd(path: string): list<string>
|
|
var cmd = ['mtxrun', '--script', 'context', '--nonstopmode', '--autogenerate']
|
|
if !empty(get(g:, 'context_extra_options', ''))
|
|
cmd += g:context_extra_options
|
|
endif
|
|
cmd->add(path)
|
|
return cmd
|
|
enddef
|
|
|
|
export def Typeset(bufname: string, env = {}, Cmd = ConTeXtCmd): bool
|
|
return typeset.TypesetBuffer(bufname, Cmd, env, 'ConTeXt')
|
|
enddef
|
|
|
|
export def JobStatus()
|
|
typeset.JobStatus('ConTeXt')
|
|
enddef
|
|
|
|
export def StopJobs()
|
|
typeset.StopJobs('ConTeXt')
|
|
enddef
|
|
|
|
export def Log(bufname: string)
|
|
execute 'edit' typeset.LogPath(bufname)
|
|
enddef
|
|
# }}}
|
|
|
|
# Completion {{{
|
|
def BinarySearch(base: string, keywords: list<string>): list<string>
|
|
const pat = '^' .. base
|
|
const len = len(keywords)
|
|
var res = []
|
|
var lft = 0
|
|
var rgt = len
|
|
|
|
# Find the leftmost index matching base
|
|
while lft < rgt
|
|
var i = (lft + rgt) / 2
|
|
if keywords[i] < base
|
|
lft = i + 1
|
|
else
|
|
rgt = i
|
|
endif
|
|
endwhile
|
|
|
|
while lft < len && keywords[lft] =~ pat
|
|
add(res, keywords[lft])
|
|
lft += 1
|
|
endwhile
|
|
|
|
return res
|
|
enddef
|
|
|
|
var isMetaPostBlock = false
|
|
|
|
var MP_KEYWORDS: list<string> = []
|
|
var CTX_KEYWORDS: list<string> = []
|
|
|
|
# Complete only MetaPost keywords in MetaPost blocks, and complete only
|
|
# ConTeXt keywords otherwise.
|
|
export def Complete(findstart: number, base: string): any
|
|
if findstart == 1
|
|
if len(synstack(line("."), 1)) > 0 && synIDattr(synstack(line("."), 1)[0], "name") ==# 'contextMPGraphic'
|
|
isMetaPostBlock = true
|
|
return match(getline('.'), '\S\+\%' .. col('.') .. 'c')
|
|
endif
|
|
|
|
# Complete only \commands starting with a backslash
|
|
isMetaPostBlock = false
|
|
var pos = match(getline('.'), '\\\zs\S\+\%' .. col('.') .. 'c')
|
|
return (pos == -1) ? -3 : pos
|
|
endif
|
|
|
|
if isMetaPostBlock
|
|
if empty(MP_KEYWORDS)
|
|
MP_KEYWORDS = sort(syntaxcomplete#OmniSyntaxList(['mf\w\+', 'mp\w\+']))
|
|
endif
|
|
return BinarySearch(base, MP_KEYWORDS)
|
|
endif
|
|
|
|
if empty(CTX_KEYWORDS)
|
|
CTX_KEYWORDS = sort(syntaxcomplete#OmniSyntaxList([
|
|
'context\w\+', 'texAleph', 'texEtex', 'texLuatex', 'texOmega',
|
|
'texPdftex', 'texTex', 'texXeTeX'
|
|
]))
|
|
endif
|
|
return BinarySearch(base, CTX_KEYWORDS)
|
|
enddef
|
|
# }}}
|
|
|
|
# vim: sw=2 fdm=marker
|