blob: 306039bc74d5ea90036ca035816a2558c117e574 (
plain)
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
|
" Vim syntax file
" Language: Spice circuit simulator input netlist
" Maintainer: Noam Halevy <Noam.Halevy.motorola.com>
" Last Change: 2012 Jun 01
" (Dominique Pelle added @Spell)
"
" This is based on sh.vim by Lennart Schultz
" but greatly simplified
" quit when a syntax file was already loaded
if exists("b:current_syntax")
finish
endif
" spice syntax is case INsensitive
syn case ignore
syn keyword spiceTodo contained TODO
syn match spiceComment "^ \=\*.*$" contains=@Spell
syn match spiceComment "\$.*$" contains=@Spell
" Numbers, all with engineering suffixes and optional units
"==========================================================
"floating point number, with dot, optional exponent
syn match spiceNumber "\<[0-9]\+\.[0-9]*\(e[-+]\=[0-9]\+\)\=\(meg\=\|[afpnumkg]\)\="
"floating point number, starting with a dot, optional exponent
syn match spiceNumber "\.[0-9]\+\(e[-+]\=[0-9]\+\)\=\(meg\=\|[afpnumkg]\)\="
"integer number with optional exponent
syn match spiceNumber "\<[0-9]\+\(e[-+]\=[0-9]\+\)\=\(meg\=\|[afpnumkg]\)\="
" Misc
"=====
syn match spiceWrapLineOperator "\\$"
syn match spiceWrapLineOperator "^+"
syn match spiceStatement "^ \=\.\I\+"
" Matching pairs of parentheses
"==========================================
syn region spiceParen transparent matchgroup=spiceOperator start="(" end=")" contains=ALLBUT,spiceParenError
syn region spiceSinglequote matchgroup=spiceOperator start=+'+ end=+'+
" Errors
"=======
syn match spiceParenError ")"
" Syncs
" =====
syn sync minlines=50
" Define the default highlighting.
" Only when an item doesn't have highlighting yet
hi def link spiceTodo Todo
hi def link spiceWrapLineOperator spiceOperator
hi def link spiceSinglequote spiceExpr
hi def link spiceExpr Function
hi def link spiceParenError Error
hi def link spiceStatement Statement
hi def link spiceNumber Number
hi def link spiceComment Comment
hi def link spiceOperator Operator
let b:current_syntax = "spice"
" insert the following to $VIM/syntax/scripts.vim
" to autodetect HSpice netlists and text listing output:
"
" " Spice netlists and text listings
" elseif getline(1) =~ 'spice\>' || getline("$") =~ '^\.end'
" so <sfile>:p:h/spice.vim
" vim: ts=8
|