aboutsummaryrefslogtreecommitdiffhomepage
path: root/lexlua/fennel.lua
blob: 19db55bea5941e18c195b254aae5b483c30b3da9 (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
-- Copyright 2006-2020 Mitchell mitchell.att.foicica.com. See License.txt.
-- Fennel LPeg lexer.
-- Contributed by Momohime Honda.

local lexer = require('lexer')
local token, word_match = lexer.token, lexer.word_match
local P, S = lpeg.P, lpeg.S

local lex = lexer.new('fennel', {inherit = lexer.load('lua')})

-- Whitespace.
lex:add_rule('whitespace', token(lexer.WHITESPACE, lexer.space^1))

-- Keywords.
lex:modify_rule('keyword', token(lexer.KEYWORD, word_match[[
  % * + - ->> -> -?>> -?> .. . // / : <= < = >= > ^ ~= λ
  and comment do doc doto each eval-compiler fn for global hashfn if include
  lambda length let local lua macro macros match not not= or partial quote
  require-macros set set-forcibly! tset values var when while
]]))

-- Identifiers.
local initial = lexer.alpha + S"|$%&#*+-./:<=>?~^_λ!"
local subsequent = initial + lexer.digit
lex:modify_rule('identifier', token(lexer.IDENTIFIER, initial * subsequent^0))

-- Strings.
lex:modify_rule('string', token(lexer.STRING, lexer.range('"')))

-- Comments.
lex:modify_rule('comment', token(lexer.COMMENT, lexer.to_eol(';')))

-- Ignore these rules.
lex:modify_rule('label', P(false))
lex:modify_rule('operator', P(false))

return lex