aboutsummaryrefslogtreecommitdiffhomepage
path: root/lexlua/verilog.lua
diff options
context:
space:
mode:
authormitchell <unknown>2018-03-11 23:04:41 -0400
committermitchell <unknown>2018-03-11 23:04:41 -0400
commit519b7328b66c4c84f03893a31e4be5ba6b1395f2 (patch)
tree2055cd79006357e94c185f341d0df17b9a8769eb /lexlua/verilog.lua
parentc0373e036e965a70045971e2abc582cb4bf12a4e (diff)
downloadscintilla-mirror-519b7328b66c4c84f03893a31e4be5ba6b1395f2.tar.gz
Added optional Lua lexer support.
This support is disabled by default and must be enabled via compile-time option.
Diffstat (limited to 'lexlua/verilog.lua')
-rw-r--r--lexlua/verilog.lua86
1 files changed, 86 insertions, 0 deletions
diff --git a/lexlua/verilog.lua b/lexlua/verilog.lua
new file mode 100644
index 000000000..63af4c61c
--- /dev/null
+++ b/lexlua/verilog.lua
@@ -0,0 +1,86 @@
+-- Copyright 2006-2018 Mitchell mitchell.att.foicica.com. See License.txt.
+-- Verilog 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('verilog')
+
+-- Whitespace.
+lex:add_rule('whitespace', token(lexer.WHITESPACE, lexer.space^1))
+
+-- Keywords.
+lex:add_rule('keyword', token(lexer.KEYWORD, word_match[[
+ always assign begin case casex casez default deassign disable else end endcase
+ endfunction endgenerate endmodule endprimitive endspecify endtable endtask for
+ force forever fork function generate if initial join macromodule module
+ negedge posedge primitive repeat release specify table task wait while
+ -- Compiler directives.
+ `include `define `undef `ifdef `ifndef `else `endif `timescale `resetall
+ `signed `unsigned `celldefine `endcelldefine `default_nettype
+ `unconnected_drive `nounconnected_drive `protect `endprotect `protected
+ `endprotected `remove_gatename `noremove_gatename `remove_netname
+ `noremove_netname `expand_vectornets `noexpand_vectornets
+ `autoexpand_vectornets
+ -- Signal strengths.
+ strong0 strong1 pull0 pull1 weak0 weak1 highz0 highz1 small medium large
+]]))
+
+-- Function.
+lex:add_rule('function', token(lexer.FUNCTION, word_match[[
+ $stop $finish $time $stime $realtime $settrace $cleartrace $showscopes
+ $showvars $monitoron $monitoroff $random $printtimescale $timeformat $display
+ -- Built-in primitives.
+ and nand or nor xor xnor buf bufif0 bufif1 not notif0 notif1 nmos pmos cmos
+ rnmos rpmos rcmos tran tranif0 tranif1 rtran rtranif0 rtranif1 pullup pulldown
+]]))
+
+-- Types.
+lex:add_rule('type', token(lexer.TYPE, word_match[[
+ integer reg time realtime defparam parameter event wire wand wor tri triand
+ trior tri0 tri1 trireg vectored scalared input output inout supply0 supply1
+]]))
+
+-- Identifiers.
+lex:add_rule('identifier', token(lexer.IDENTIFIER, lexer.word))
+
+-- Strings.
+lex:add_rule('string', token(lexer.STRING, lexer.delimited_range('"')))
+
+-- Comments.
+local line_comment = '//' * lexer.nonnewline^0
+local block_comment = '/*' * (lexer.any - '*/')^0 * P('*/')^-1
+lex:add_rule('comment', token(lexer.COMMENT, line_comment + block_comment))
+
+-- Numbers.
+local bin_suffix = S('bB') * S('01_xXzZ')^1
+local oct_suffix = S('oO') * S('01234567_xXzZ')^1
+local dec_suffix = S('dD') * S('0123456789_xXzZ')^1
+local hex_suffix = S('hH') * S('0123456789abcdefABCDEF_xXzZ')^1
+lex:add_rule('number', token(lexer.NUMBER, (lexer.digit + '_')^1 +
+ "'" * (bin_suffix + oct_suffix +
+ dec_suffix + hex_suffix)))
+
+-- Operators.
+lex:add_rule('operator', token(lexer.OPERATOR, S('=~+-/*<>%&|^~,:;()[]{}')))
+
+-- Fold points.
+lex:add_fold_point(lexer.KEYWORD, 'case', 'endcase')
+lex:add_fold_point(lexer.KEYWORD, 'casex', 'endcase')
+lex:add_fold_point(lexer.KEYWORD, 'casez', 'endcase')
+lex:add_fold_point(lexer.KEYWORD, 'function', 'endfunction')
+lex:add_fold_point(lexer.KEYWORD, 'fork', 'join')
+lex:add_fold_point(lexer.KEYWORD, 'table', 'endtable')
+lex:add_fold_point(lexer.KEYWORD, 'task', 'endtask')
+lex:add_fold_point(lexer.KEYWORD, 'generate', 'endgenerate')
+lex:add_fold_point(lexer.KEYWORD, 'specify', 'endspecify')
+lex:add_fold_point(lexer.KEYWORD, 'primitive', 'endprimitive')
+lex:add_fold_point(lexer.KEYWORD, 'module', 'endmodule')
+lex:add_fold_point(lexer.KEYWORD, 'begin', 'end')
+lex:add_fold_point(lexer.OPERATOR, '(', ')')
+lex:add_fold_point(lexer.OPERATOR, '{', '}')
+lex:add_fold_point(lexer.COMMENT, '/*', '*/')
+lex:add_fold_point(lexer.COMMENT, '//', lexer.fold_line_comments('//'))
+
+return lex