1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
|
" 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:
" quit when a syntax file was already loaded
if 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.
" Only when an item doesn't have highlighting yet
" Sub Links:
hi def link virataDefSubstError virataPreProcError
hi def link virataDefSubst virataPreProc
hi def link virataInAlter virataOperator
hi def link virataInExec virataOperator
hi def link virataInExport virataOperator
hi def link virataInImport virataOperator
hi def link virataInInstance virataOperator
hi def link virataInMake virataOperator
hi def link virataInModule virataOperator
hi def link virataInProcess virataOperator
hi def link virataInMacAddr virataHexNumber
" Comment Group:
hi def link virataComment Comment
hi def link virataSpclComment SpecialComment
hi def link virataInCommentTodo Todo
" Constant Group:
hi def link virataString String
hi def link virataStringError Error
hi def link virataCharacter Character
hi def link virataSpclChar Special
hi def link virataDecNumber Number
hi def link virataHexNumber Number
hi def link virataSizeNumber Number
hi def link virataNumberError Error
" Identifier Group:
hi def link virataIdentError Error
" PreProc Group:
hi def link virataPreProc PreProc
hi def link virataDefine Define
hi def link virataInclude Include
hi def link virataPreCondit PreCondit
hi def link virataPreProcError Error
hi def link virataPreProcWarn Todo
" Directive Group:
hi def link virataStatement Statement
hi def link virataCfgStatement Statement
hi def link virataOperator Operator
hi def link virataDirective Keyword
let b:current_syntax = "virata"
" vim:ts=8:sw=2:noet:
|