Merge branch 'hack/autopaste'
[vim-kana.git] / runtime / syntax / hercules.vim
blob02d8e9bb78bea599c41a8f02747b7484aed9cf29
1 " Vim syntax file
2 " Language:     Hercules
3 " Maintainer:   Dana Edwards <Dana_Edwards@avanticorp.com>
4 " Extensions:   *.vc,*.ev,*.rs
5 " Last change:  Nov. 9, 2001
6 " Comment:      Hercules physical IC design verification software ensures
7 "               that an IC's physical design matches its logical design and
8 "               satisfies manufacturing rules.
10 " For version 5.x: Clear all syntax items
11 " For version 6.x: Quit when a syntax file was already loaded
12 if version < 600
13   syntax clear
14 elseif exists("b:current_syntax")
15   finish
16 endif
18 " Ignore case
19 syn case ignore
21 " Hercules runset sections
22 syn keyword   herculesType        header assign_property alias assign
23 syn keyword   herculesType        options preprocess_options
24 syn keyword   herculesType        explode_options technology_options
25 syn keyword   herculesType        drc_options database_options
26 syn keyword   herculesType        text_options lpe_options evaccess_options
27 syn keyword   herculesType        check_point compare_group environment
28 syn keyword   herculesType        grid_check include layer_stats load_group
29 syn keyword   herculesType        restart run_only self_intersect set snap
30 syn keyword   herculesType        system variable waiver
32 " Hercules commands
33 syn keyword   herculesStatement   attach_property boolean cell_extent
34 syn keyword   herculesStatement   common_hierarchy connection_points
35 syn keyword   herculesStatement   copy data_filter alternate delete
36 syn keyword   herculesStatement   explode explode_all fill_pattern find_net
37 syn keyword   herculesStatement   flatten
38 syn keyword   herculesStatement   level negate polygon_features push
39 syn keyword   herculesStatement   rectangles relocate remove_overlap reverse select
40 syn keyword   herculesStatement   select_cell select_contains select_edge select_net size
41 syn keyword   herculesStatement   text_polygon text_property vertex area cut
42 syn keyword   herculesStatement   density enclose external inside_edge
43 syn keyword   herculesStatement   internal notch vectorize center_to_center
44 syn keyword   herculesStatement   length mask_align moscheck rescheck
45 syn keyword   herculesStatement   analysis buildsub init_lpe_db capacitor
46 syn keyword   herculesStatement   device gendev nmos pmos diode npn pnp
47 syn keyword   herculesStatement   resistor set_param save_property
48 syn keyword   herculesStatement   connect disconnect text  text_boolean
49 syn keyword   herculesStatement   replace_text create_ports label graphics
50 syn keyword   herculesStatement   save_netlist_database lpe_stats netlist
51 syn keyword   herculesStatement   spice graphics_property graphics_netlist
52 syn keyword   herculesStatement   write_milkyway multi_rule_enclose
53 syn keyword   herculesStatement   if error_property equate compare
54 syn keyword   herculesStatement   antenna_fix c_thru dev_connect_check
55 syn keyword   herculesStatement   dev_net_count device_count net_filter
56 syn keyword   herculesStatement   net_path_check ratio process_text_opens
58 " Hercules keywords
59 syn keyword   herculesStatement   black_box_file block compare_dir equivalence
60 syn keyword   herculesStatement   format gdsin_dir group_dir group_dir_usage
61 syn keyword   herculesStatement   inlib layout_path outlib output_format
62 syn keyword   herculesStatement   output_layout_path schematic schematic_format
63 syn keyword   herculesStatement   scheme_file output_block else
64 syn keyword   herculesStatement   and or not xor andoverlap inside outside by to
65 syn keyword   herculesStatement   with connected connected_all texted_with texted
66 syn keyword   herculesStatement   by_property cutting edge_touch enclosing inside
67 syn keyword   herculesStatement   inside_hole interact touching vertex
69 " Hercules comments
70 syn region    herculesComment           start="/\*" skip="/\*" end="\*/" contains=herculesTodo
71 syn match     herculesComment           "//.*" contains=herculesTodo
73 " Preprocessor directives
74 syn match     herculesPreProc "^#.*"
75 syn match     herculesPreProc "^@.*"
76 syn match     herculesPreProc "macros"
78 " Hercules COMMENT option
79 syn match     herculesCmdCmnt "comment.*=.*"
81 " Spacings, Resolutions, Ranges, Ratios, etc.
82 syn match     herculesNumber          "-\=\<[0-9]\+L\=\>\|0[xX][0-9]\+\>"
84 " Parenthesis sanity checker
85 syn region    herculesZone       matchgroup=Delimiter start="(" matchgroup=Delimiter end=")" transparent contains=ALLBUT,herculesError,herculesBraceError,herculesCurlyError
86 syn region    herculesZone       matchgroup=Delimiter start="{" matchgroup=Delimiter end="}" transparent contains=ALLBUT,herculesError,herculesBraceError,herculesParenError
87 syn region    herculesZone       matchgroup=Delimiter start="\[" matchgroup=Delimiter end="]" transparent contains=ALLBUT,herculesError,herculesCurlyError,herculesParenError
88 syn match     herculesError      "[)\]}]"
89 syn match     herculesBraceError "[)}]"  contained
90 syn match     herculesCurlyError "[)\]]" contained
91 syn match     herculesParenError "[\]}]" contained
93 " Hercules output format
94 "syn match  herculesOutput "([0-9].*)"
95 "syn match  herculesOutput "([0-9].*\;.*)"
96 syn match     herculesOutput "perm\s*=.*(.*)"
97 syn match     herculesOutput "temp\s*=\s*"
98 syn match     herculesOutput "error\s*=\s*(.*)"
100 "Modify the following as needed.  The trade-off is performance versus functionality.
101 syn sync      lines=100
103 " Define the default highlighting.
104 " For version 5.7 and earlier: only when not done already
105 " For version 5.8 and later: only when an item doesn't have highlighting yet
106 if version >= 508 || !exists("did_hercules_syntax_inits")
107   if version < 508
108     let did_hercules_syntax_inits = 1
109     " Default methods for highlighting.
110     command -nargs=+ HiLink hi link <args>
111   else
112     command -nargs=+ HiLink hi def link <args>
113   endif
115   HiLink herculesStatement  Statement
116   HiLink herculesType       Type
117   HiLink herculesComment    Comment
118   HiLink herculesPreProc    PreProc
119   HiLink herculesTodo       Todo
120   HiLink herculesOutput     Include
121   HiLink herculesCmdCmnt    Identifier
122   HiLink herculesNumber     Number
123   HiLink herculesBraceError herculesError
124   HiLink herculesCurlyError herculesError
125   HiLink herculesParenError herculesError
126   HiLink herculesError      Error
128   delcommand HiLink
129 endif
131 let b:current_syntax = "hercules"
133 " vim: ts=8