" Vim syntax file
" Language: Virata AConfig Configuration Script
" Maintainer: Manuel M.H. Stol <mmh.stol@gmx.net>
" Last Change: 2003 May 11
" Vim URL: http://www.vim.org/lang.html
" Virata URL: http://www.globespanvirata.com/
" Virata AConfig Configuration Script syntax
" Can be detected by: 1) Extension .hw, .sw, .pkg and .module
" 2) The file name pattern "mk.*\.cfg"
" 3) The string "Virata" in the first 5 lines
" Setup Syntax:
if version < 600
" Clear old syntax settings
syn clear
elseif exists("b:current_syntax")
finish
endif
" Virata syntax is case insensitive (mostly)
syn case ignore
" Comments:
" Virata comments start with %, but % is not a keyword character
syn region virataComment start="^%" start="\s%"lc=1 keepend end="$" contains=@virataGrpInComments
syn region virataSpclComment start="^%%" start="\s%%"lc=1 keepend end="$" contains=@virataGrpInComments
syn keyword virataInCommentTodo contained TODO FIXME XXX[XXXXX] REVIEW TBD
syn cluster virataGrpInComments contains=virataInCommentTodo
syn cluster virataGrpComments contains=@virataGrpInComments,virataComment,virataSpclComment
" Constants:
syn match virataStringError +["]+
syn region virataString start=+"+ skip=+\(\\\\\|\\"\)+ end=+"+ oneline contains=virataSpclCharError,virataSpclChar,@virataGrpDefSubsts
syn match virataCharacter +'[^']\{-}'+ contains=virataSpclCharError,virataSpclChar
syn match virataSpclChar contained +\\\(x\x\+\|\o\{1,3}\|['\"?\\abefnrtv]\)+
syn match virataNumberError "\<\d\{-1,}\I\{-1,}\>"
syn match virataNumberError "\<0x\x*\X\x*\>"
syn match virataNumberError "\<\d\+\.\d*\(e[+-]\=\d\+\)\=\>"
syn match virataDecNumber "\<\d\+U\=L\=\>"
syn match virataHexNumber "\<0x\x\+U\=L\=\>"
syn match virataSizeNumber "\<\d\+[BKM]\>"he=e-1
syn match virataSizeNumber "\<\d\+[KM]B\>"he=e-2
syn cluster virataGrpNumbers contains=virataNumberError,virataDecNumber,virataHexNumber,virataSizeNumber
syn cluster virataGrpConstants contains=@virataGrpNumbers,virataStringError,virataString,virataCharacter,virataSpclChar
" Identifiers:
syn match virataIdentError contained "\<\D\S*\>"
syn match virataIdentifier contained "\<\I\i\{-}\(\-\i\{-1,}\)*\>" contains=@virataGrpDefSubsts
syn match virataFileIdent contained "\F\f*" contains=@virataGrpDefSubsts
syn cluster virataGrpIdents contains=virataIdentifier,virataIdentError
syn cluster virataGrpFileIdents contains=virataFileIdent,virataIdentError
" Statements:
syn match virataStatement "^\s*Config\(\(/Kernel\)\=\.\(hs\=\|s\)\)\=\>"
syn match virataStatement "^\s*Config\s\+\I\i\{-}\(\-\i\{-1,}\)*\.\(hs\=\|s\)\>"
syn match virataStatement "^\s*Make\.\I\i\{-}\(\-\i\{-1}\)*\>" skipwhite nextgroup=@virataGrpIdents
syn match virataStatement "^\s*Make\.c\(at\)\=++\s"me=e-1 skipwhite nextgroup=@virataGrpIdents
syn match virataStatement "^\s*\(Architecture\|GetEnv\|Reserved\|\(Un\)\=Define\|Version\)\>" skipwhite nextgroup=@virataGrpIdents
syn match virataStatement "^\s*\(Hardware\|ModuleSource\|\(Release\)\=Path\|Software\)\>" skipwhite nextgroup=@virataGrpFileIdents
syn match virataStatement "^\s*\(DefaultPri\|Hydrogen\)\>" skipwhite nextgroup=virataDecNumber,virataNumberError
syn match virataStatement "^\s*\(NoInit\|PCI\|SysLink\)\>"
syn match virataStatement "^\s*Allow\s\+\(ModuleConfig\)\>"
syn match virataStatement "^\s*NoWarn\s\+\(Export\|Parse\=able\|Relative]\)\>"
syn match virataStatement "^\s*Debug\s\+O\(ff\|n\)\>"
" Import (Package <exec>|Module <name> from <dir>)
syn region virataImportDef transparent matchgroup=virataStatement start="^\s*Import\>" keepend end="$" contains=virataInImport,virataModuleDef,virataNumberError,virataStringError,@virataGrpDefSubsts
syn match virataInImport contained "\<\(Module\|Package\|from\)\>" skipwhite nextgroup=@virataGrpFileIdents
" Export (Header <header file>|SLibrary <obj file>)
syn region virataExportDef transparent matchgroup=virataStatement start="^\s*Export\>" keepend end="$" contains=virataInExport,virataNumberError,virataStringError,@virataGrpDefSubsts
syn match virataInExport contained "\<\(Header\|[SU]Library\)\>" skipwhite nextgroup=@virataGrpFileIdents
" Process <name> is <dir/exec>
syn region virataProcessDef transparent matchgroup=virataStatement start="^\s*Process\>" keepend end="$" contains=virataInProcess,virataInExec,virataNumberError,virataStringError,@virataGrpDefSubsts,@virataGrpIdents
syn match virataInProcess contained "\<is\>"
" Instance <name> of <module>
syn region virataInstanceDef transparent matchgroup=virataStatement start="^\s*Instance\>" keepend end="$" contains=virataInInstance,virataNumberError,virataStringError,@virataGrpDefSubsts,@virataGrpIdents
syn match virataInInstance contained "\<of\>"
" Module <name> from <dir>
syn region virataModuleDef transparent matchgroup=virataStatement start="^\s*\(Package\|Module\)\>" keepend end="$" contains=virataInModule,virataNumberError,virataStringError,@virataGrpDefSubsts
syn match virataInModule contained "^\s*Package\>"hs=e-7 skipwhite nextgroup=@virataGrpIdents
syn match virataInModule contained "^\s*Module\>"hs=e-6 skipwhite nextgroup=@virataGrpIdents
syn match virataInModule contained "\<from\>" skipwhite nextgroup=@virataGrpFileIdents
" Colour <name> from <dir>
syn region virataColourDef transparent matchgroup=virataStatement start="^\s*Colour\>" keepend end="$" contains=virataInColour,virataNumberError,virataStringError,@virataGrpDefSubsts
syn match virataInColour contained "^\s*Colour\>"hs=e-6 skipwhite nextgroup=@virataGrpIdents
syn match virataInColour contained "\<from\>" skipwhite nextgroup=@virataGrpFileIdents
" Link {<link cmds>}
" Object {Executable [<ExecOptions>]}
syn match virataStatement "^\s*\(Link\|Object\)"
" Executable <name> [<ExecOptions>]
syn region virataExecDef transparent matchgroup=virataStatement start="^\s*Executable\>" keepend end="$" contains=virataInExec,virataNumberError,virataStringError
syn match virataInExec contained "^\s*Executable\>" skipwhite nextgroup=@virataGrpDefSubsts,@virataGrpIdents
syn match virataInExec contained "\<\(epilogue\|pro\(logue\|cess\)\|qhandler\)\>" skipwhite nextgroup=@virataGrpDefSubsts,@virataGrpIdents
syn match virataInExec contained "\<\(priority\|stack\)\>" skipwhite nextgroup=@virataGrpDefSubsts,@virataGrpNumbers
" Message <name> {<msg format>}
" MessageId <number>
syn match virataStatement "^\s*Message\(Id\)\=\>" skipwhite nextgroup=@virataGrpNumbers
" MakeRule <make suffix=file> {<make cmds>}
syn region virataMakeDef transparent matchgroup=virataStatement start="^\s*MakeRule\>" keepend end="$" contains=virataInMake,@virataGrpDefSubsts
syn case match
syn match virataInMake contained "\<N\>"
syn case ignore
" (Append|Edit|Copy)Rule <make suffix=file> <subst cmd>
syn match virataStatement "^\s*\(Append\|Copy\|Edit\)Rule\>"
" AlterRules in <file> <subst cmd>
syn region virataAlterDef transparent matchgroup=virataStatement start="^\s*AlterRules\>" keepend end="$" contains=virataInAlter,@virataGrpDefSubsts
syn match virataInAlter contained "\<in\>" skipwhite nextgroup=@virataGrpIdents
" Clustering
syn cluster virataGrpInStatmnts contains=virataInImport,virataInExport,virataInExec,virataInProcess,virataInAlter,virataInInstance,virataInModule,virataInColour
syn cluster virataGrpStatements contains=@virataGrpInStatmnts,virataStatement,virataImportDef,virataExportDef,virataExecDef,virataProcessDef,virataAlterDef,virataInstanceDef,virataModuleDef,virataColourDef
" MkFlash.Cfg File Statements:
syn region virataCfgFileDef transparent matchgroup=virataCfgStatement start="^\s*Dir\>" start="^\s*\a\{-}File\>" start="^\s*OutputFile\d\d\=\>" start="^\s*\a\w\{-}[NP]PFile\>" keepend end="$" contains=@virataGrpFileIdents
syn region virataCfgSizeDef transparent matchgroup=virataCfgStatement start="^\s*\a\{-}Size\>" start="^\s*ConfigInfo\>" keepend end="$" contains=@virataGrpNumbers,@virataGrpDefSubsts,virataIdentError
syn region virataCfgNumberDef transparent matchgroup=virataCfgStatement start="^\s*FlashchipNum\(b\(er\=\)\=\)\=\>" start="^\s*Granularity\>" keepend end="$" contains=@virataGrpNumbers,@virataGrpDefSubsts
syn region virataCfgMacAddrDef transparent matchgroup=virataCfgStatement start="^\s*MacAddress\>" keepend end="$" contains=virataNumberError,virataStringError,virataIdentError,virataInMacAddr,@virataGrpDefSubsts
syn match virataInMacAddr contained "\x[:]\x\{1,2}\>"lc=2
syn match virataInMacAddr contained "\s\x\{1,2}[:]\x"lc=1,me=e-1,he=e-2 nextgroup=virataInMacAddr
syn match virataCfgStatement "^\s*Target\>" skipwhite nextgroup=@virataGrpIdents
syn cluster virataGrpCfgs contains=virataCfgStatement,virataCfgFileDef,virataCfgSizeDef,virataCfgNumberDef,virataCfgMacAddrDef,virataInMacAddr
" PreProcessor Instructions:
" Defines
syn match virataDefine "^\s*\(Un\)\=Set\>" skipwhite nextgroup=@virataGrpIdents
syn match virataInclude "^\s*Include\>" skipwhite nextgroup=@virataGrpFileIdents
syn match virataDefSubstError "[^$]\$"lc=1
syn match virataDefSubstError "\$\(\w\|{\(.\{-}}\)\=\)"
syn case match
syn match virataDefSubst "\$\(\d\|[DINORS]\|{\I\i\{-}\(\-\i\{-1,}\)*}\)"
syn case ignore
" Conditionals
syn cluster virataGrpCntnPreCon contains=ALLBUT,@virataGrpInComments,@virataGrpFileIdents,@virataGrpInStatmnts
syn region virataPreConDef transparent matchgroup=virataPreCondit start="^\s*If\>" end="^\s*Endif\>" contains=@virataGrpCntnPreCon
syn match virataPreCondit contained "^\s*Else\(\s\+If\)\=\>"
syn region virataPreConDef transparent matchgroup=virataPreCondit start="^\s*ForEach\>" end="^\s*Done\>" contains=@virataGrpCntnPreCon
" Pre-Processors
syn region virataPreProc start="^\s*Error\>" start="^\s*Warning\>" oneline end="$" contains=@virataGrpConstants,@virataGrpDefSubsts
syn cluster virataGrpDefSubsts contains=virataDefSubstError,virataDefSubst
syn cluster virataGrpPreProcs contains=@virataGrpDefSubsts,virataDefine,virataInclude,virataPreConDef,virataPreCondit,virataPreProc
" Synchronize Syntax:
syn sync clear
syn sync minlines=50 "for multiple region nesting
" Define the default highlighting.
" For version 5.7 and earlier: only when not done already
" For version 5.8 and later : only when an item doesn't have highlighting yet
if version >= 508 || !exists("did_virata_syntax_inits")
if version < 508
let did_virata_syntax_inits = 1
command -nargs=+ HiLink hi link <args>
else
command -nargs=+ HiLink hi def link <args>
endif
" Sub Links:
HiLink virataDefSubstError virataPreProcError
HiLink virataDefSubst virataPreProc
HiLink virataInAlter virataOperator
HiLink virataInExec virataOperator
HiLink virataInExport virataOperator
HiLink virataInImport virataOperator
HiLink virataInInstance virataOperator
HiLink virataInMake virataOperator
HiLink virataInModule virataOperator
HiLink virataInProcess virataOperator
HiLink virataInMacAddr virataHexNumber
" Comment Group:
HiLink virataComment Comment
HiLink virataSpclComment SpecialComment
HiLink virataInCommentTodo Todo
" Constant Group:
HiLink virataString String
HiLink virataStringError Error
HiLink virataCharacter Character
HiLink virataSpclChar Special
HiLink virataDecNumber Number
HiLink virataHexNumber Number
HiLink virataSizeNumber Number
HiLink virataNumberError Error
" Identifier Group:
HiLink virataIdentError Error
" PreProc Group:
HiLink virataPreProc PreProc
HiLink virataDefine Define
HiLink virataInclude Include
HiLink virataPreCondit PreCondit
HiLink virataPreProcError Error
HiLink virataPreProcWarn Todo
" Directive Group:
HiLink virataStatement Statement
HiLink virataCfgStatement Statement
HiLink virataOperator Operator
HiLink virataDirective Keyword
delcommand HiLink
endif
let b:current_syntax = "virata"
" vim:ts=8:sw=2:noet: