1
Jianw
9 天以前 70f29da38121b9a467841253e3268feb5df02902
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
-- Copyright 2006-2018 Mitchell mitchell.att.foicica.com. See License.txt.
-- VHDL LPeg lexer.
 
local lexer = require('lexer')
local token, word_match = lexer.token, lexer.word_match
local P, R, S = lpeg.P, lpeg.R, lpeg.S
 
local lex = lexer.new('vhdl')
 
-- Whitespace.
lex:add_rule('whitespace', token(lexer.WHITESPACE, lexer.space^1))
 
-- Keywords.
lex:add_rule('keyword', token(lexer.KEYWORD, word_match[[
  access after alias all architecture array assert attribute begin block body
  buffer bus case component configuration constant disconnect downto else elsif
  end entity exit file for function generate generic group guarded if impure in
  inertial inout is label library linkage literal loop map new next null of on
  open others out package port postponed procedure process pure range record
  register reject report return select severity signal shared subtype then to
  transport type unaffected units until use variable wait when while with
  note warning error failure
  and nand or nor xor xnor rol ror sla sll sra srl mod rem
  abs not false true
]]))
 
-- Functions.
lex:add_rule('function', token(lexer.FUNCTION, word_match[[
  rising_edge shift_left shift_right rotate_left rotate_right resize std_match
  to_integer to_unsigned to_signed unsigned signed to_bit to_bitvector
  to_stdulogic to_stdlogicvector to_stdulogicvector
]]))
 
-- Types.
lex:add_rule('type', token(lexer.TYPE, word_match[[
  bit bit_vector character boolean integer real time string severity_level
  positive natural signed unsigned line text std_logic std_logic_vector
  std_ulogic std_ulogic_vector qsim_state qsim_state_vector qsim_12state
  qsim_12state_vector qsim_strength mux_bit mux_vectory reg_bit reg_vector
  wor_bit wor_vector
]]))
 
-- Constants.
lex:add_rule('constant', token(lexer.CONSTANT, word_match[[
  EVENT BASE LEFT RIGHT LOW HIGH ASCENDING IMAGE VALUE POS VAL SUCC VAL POS PRED
  VAL POS LEFTOF RIGHTOF LEFT RIGHT LOW HIGH RANGE REVERSE LENGTH ASCENDING
  DELAYED STABLE QUIET TRANSACTION EVENT ACTIVE LAST LAST LAST DRIVING DRIVING
  SIMPLE INSTANCE PATH
]]))
 
-- Identifiers.
lex:add_rule('identifier', token(lexer.IDENTIFIER, (lexer.alpha + "'") *
                                                   (lexer.alnum + S("_'"))^1))
 
-- Strings.
local sq_str = lexer.delimited_range("'", true, true)
local dq_str = lexer.delimited_range('"', true)
lex:add_rule('string', token(lexer.STRING, sq_str + dq_str))
 
-- Comments.
lex:add_rule('comment', token(lexer.COMMENT, '--' * lexer.nonnewline^0))
 
-- Numbers.
lex:add_rule('number', token(lexer.NUMBER, lexer.float + lexer.integer))
 
-- Operators.
lex:add_rule('operator', token(lexer.OPERATOR, S('=/!:;<>+-/*%&|^~()')))
 
return lex