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.
-- Applescript 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('applescript')
 
-- Whitespace.
lex:add_rule('whitespace', token(lexer.WHITESPACE, lexer.space^1))
 
-- Keywords.
lex:add_rule('keyword', token(lexer.KEYWORD, word_match[[
  script property prop end copy to set global local on to of in given with
  without return continue tell if then else repeat times while until from exit
  try error considering ignoring timeout transaction my get put into is
  -- References.
  each some every whose where id index first second third fourth fifth sixth
  seventh eighth ninth tenth last front back st nd rd th middle named through
  thru before after beginning the
  -- Commands.
  close copy count delete duplicate exists launch make move open print quit
  reopen run save saving
  -- Operators.
  div mod and not or as contains equal equals isn't
]], true))
 
-- Constants.
lex:add_rule('constant', token(lexer.CONSTANT, word_match[[
  case diacriticals expansion hyphens punctuation
  -- Predefined variables.
  it me version pi result space tab anything
  -- Text styles.
  bold condensed expanded hidden italic outline plain shadow strikethrough
  subscript superscript underline
  -- Save options.
  ask no yes
  -- Booleans.
  false true
  -- Date and time.
  weekday monday mon tuesday tue wednesday wed thursday thu friday fri saturday
  sat sunday sun month january jan february feb march mar april apr may june jun
  july jul august aug september sep october oct november nov december dec
  minutes hours days weeks
]], true))
 
-- Identifiers.
lex:add_rule('identifier', token(lexer.IDENTIFIER, (lexer.alpha + '_') *
                                                   lexer.alnum^0))
 
-- Strings.
lex:add_rule('string', token(lexer.STRING, lexer.delimited_range('"', true)))
 
-- 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.
lex:add_rule('number', token(lexer.NUMBER, lexer.float + lexer.integer))
 
-- Operators.
lex:add_rule('operator', token(lexer.OPERATOR, S('+-^*/&<>=:,(){}')))
 
-- Fold points.
lex:add_fold_point(lexer.COMMENT, '(*', '*)')
 
return lex