aboutsummaryrefslogtreecommitdiffhomepage
path: root/lexlua/pascal.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/pascal.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/pascal.lua')
-rw-r--r--lexlua/pascal.lua62
1 files changed, 62 insertions, 0 deletions
diff --git a/lexlua/pascal.lua b/lexlua/pascal.lua
new file mode 100644
index 000000000..495175f4c
--- /dev/null
+++ b/lexlua/pascal.lua
@@ -0,0 +1,62 @@
+-- Copyright 2006-2018 Mitchell mitchell.att.foicica.com. See License.txt.
+-- Pascal 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('pascal')
+
+-- Whitespace.
+lex:add_rule('whitespace', token(lexer.WHITESPACE, lexer.space^1))
+
+-- Keywords.
+lex:add_rule('keyword', token(lexer.KEYWORD, word_match([[
+ and array as at asm begin case class const constructor destructor
+ dispinterface div do downto else end except exports file final finalization
+ finally for function goto if implementation in inherited initialization inline
+ interface is label mod not object of on or out packed procedure program
+ property raise record repeat resourcestring set sealed shl shr static string
+ then threadvar to try type unit unsafe until uses var while with xor
+ absolute abstract assembler automated cdecl contains default deprecated dispid
+ dynamic export external far forward implements index library local message
+ name namespaces near nodefault overload override package pascal platform
+ private protected public published read readonly register reintroduce requires
+ resident safecall stdcall stored varargs virtual write writeln writeonly
+ false nil self true
+]], true)))
+
+-- Functions.
+lex:add_rule('function', token(lexer.FUNCTION, word_match([[
+ chr ord succ pred abs round trunc sqr sqrt arctan cos sin exp ln odd eof eoln
+]], true)))
+
+-- Types.
+lex:add_rule('type', token(lexer.TYPE, word_match([[
+ shortint byte char smallint integer word longint cardinal boolean bytebool
+ wordbool longbool real single double extended comp currency pointer
+]], true)))
+
+-- Strings.
+lex:add_rule('string', token(lexer.STRING,
+ S('uUrR')^-1 *
+ lexer.delimited_range("'", true, true)))
+
+-- Identifiers.
+lex:add_rule('identifier', token(lexer.IDENTIFIER, lexer.word))
+
+-- Comments.
+local line_comment = '//' * lexer.nonnewline_esc^0
+local bblock_comment = '{' * (lexer.any - '}')^0 * P('}')^-1
+local pblock_comment = '(*' * (lexer.any - '*)')^0 * P('*)')^-1
+lex:add_rule('comment', token(lexer.COMMENT, line_comment + bblock_comment +
+ pblock_comment))
+
+-- Numbers.
+lex:add_rule('number', token(lexer.NUMBER, (lexer.float + lexer.integer) *
+ S('LlDdFf')^-1))
+
+-- Operators.
+lex:add_rule('operator', token(lexer.OPERATOR, S('.,;^@:=<>+-/*()[]')))
+
+return lex