Mercurial > hg > soundsoftware-site
comparison vendor/plugins/coderay-0.9.2/lib/coderay/scanners/delphi.rb @ 0:513646585e45
* Import Redmine trunk SVN rev 3859
author | Chris Cannam |
---|---|
date | Fri, 23 Jul 2010 15:52:44 +0100 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:513646585e45 |
---|---|
1 module CodeRay | |
2 module Scanners | |
3 | |
4 class Delphi < Scanner | |
5 | |
6 register_for :delphi | |
7 file_extension 'pas' | |
8 | |
9 RESERVED_WORDS = [ | |
10 'and', 'array', 'as', 'at', 'asm', 'at', 'begin', 'case', 'class', | |
11 'const', 'constructor', 'destructor', 'dispinterface', 'div', 'do', | |
12 'downto', 'else', 'end', 'except', 'exports', 'file', 'finalization', | |
13 'finally', 'for', 'function', 'goto', 'if', 'implementation', 'in', | |
14 'inherited', 'initialization', 'inline', 'interface', 'is', 'label', | |
15 'library', 'mod', 'nil', 'not', 'object', 'of', 'or', 'out', 'packed', | |
16 'procedure', 'program', 'property', 'raise', 'record', 'repeat', | |
17 'resourcestring', 'set', 'shl', 'shr', 'string', 'then', 'threadvar', | |
18 'to', 'try', 'type', 'unit', 'until', 'uses', 'var', 'while', 'with', | |
19 'xor', 'on' | |
20 ] | |
21 | |
22 DIRECTIVES = [ | |
23 'absolute', 'abstract', 'assembler', 'at', 'automated', 'cdecl', | |
24 'contains', 'deprecated', 'dispid', 'dynamic', 'export', | |
25 'external', 'far', 'forward', 'implements', 'local', | |
26 'near', 'nodefault', 'on', 'overload', 'override', | |
27 'package', 'pascal', 'platform', 'private', 'protected', 'public', | |
28 'published', 'read', 'readonly', 'register', 'reintroduce', | |
29 'requires', 'resident', 'safecall', 'stdcall', 'stored', 'varargs', | |
30 'virtual', 'write', 'writeonly' | |
31 ] | |
32 | |
33 IDENT_KIND = CaseIgnoringWordList.new(:ident). | |
34 add(RESERVED_WORDS, :reserved). | |
35 add(DIRECTIVES, :directive) | |
36 | |
37 NAME_FOLLOWS = CaseIgnoringWordList.new(false). | |
38 add(%w(procedure function .)) | |
39 | |
40 private | |
41 def scan_tokens tokens, options | |
42 | |
43 state = :initial | |
44 last_token = '' | |
45 | |
46 until eos? | |
47 | |
48 kind = nil | |
49 match = nil | |
50 | |
51 if state == :initial | |
52 | |
53 if scan(/ \s+ /x) | |
54 tokens << [matched, :space] | |
55 next | |
56 | |
57 elsif scan(%r! \{ \$ [^}]* \}? | \(\* \$ (?: .*? \*\) | .* ) !mx) | |
58 tokens << [matched, :preprocessor] | |
59 next | |
60 | |
61 elsif scan(%r! // [^\n]* | \{ [^}]* \}? | \(\* (?: .*? \*\) | .* ) !mx) | |
62 tokens << [matched, :comment] | |
63 next | |
64 | |
65 elsif match = scan(/ <[>=]? | >=? | :=? | [-+=*\/;,@\^|\(\)\[\]] | \.\. /x) | |
66 kind = :operator | |
67 | |
68 elsif match = scan(/\./) | |
69 kind = :operator | |
70 if last_token == 'end' | |
71 tokens << [match, kind] | |
72 next | |
73 end | |
74 | |
75 elsif match = scan(/ [A-Za-z_][A-Za-z_0-9]* /x) | |
76 kind = NAME_FOLLOWS[last_token] ? :ident : IDENT_KIND[match] | |
77 | |
78 elsif match = scan(/ ' ( [^\n']|'' ) (?:'|$) /x) | |
79 tokens << [:open, :char] | |
80 tokens << ["'", :delimiter] | |
81 tokens << [self[1], :content] | |
82 tokens << ["'", :delimiter] | |
83 tokens << [:close, :char] | |
84 next | |
85 | |
86 elsif match = scan(/ ' /x) | |
87 tokens << [:open, :string] | |
88 state = :string | |
89 kind = :delimiter | |
90 | |
91 elsif scan(/ \# (?: \d+ | \$[0-9A-Fa-f]+ ) /x) | |
92 kind = :char | |
93 | |
94 elsif scan(/ \$ [0-9A-Fa-f]+ /x) | |
95 kind = :hex | |
96 | |
97 elsif scan(/ (?: \d+ ) (?![eE]|\.[^.]) /x) | |
98 kind = :integer | |
99 | |
100 elsif scan(/ \d+ (?: \.\d+ (?: [eE][+-]? \d+ )? | [eE][+-]? \d+ ) /x) | |
101 kind = :float | |
102 | |
103 else | |
104 kind = :error | |
105 getch | |
106 | |
107 end | |
108 | |
109 elsif state == :string | |
110 if scan(/[^\n']+/) | |
111 kind = :content | |
112 elsif scan(/''/) | |
113 kind = :char | |
114 elsif scan(/'/) | |
115 tokens << ["'", :delimiter] | |
116 tokens << [:close, :string] | |
117 state = :initial | |
118 next | |
119 elsif scan(/\n/) | |
120 tokens << [:close, :string] | |
121 kind = :error | |
122 state = :initial | |
123 else | |
124 raise "else case \' reached; %p not handled." % peek(1), tokens | |
125 end | |
126 | |
127 else | |
128 raise 'else-case reached', tokens | |
129 | |
130 end | |
131 | |
132 match ||= matched | |
133 if $CODERAY_DEBUG and not kind | |
134 raise_inspect 'Error token %p in line %d' % | |
135 [[match, kind], line], tokens, state | |
136 end | |
137 raise_inspect 'Empty token', tokens unless match | |
138 | |
139 last_token = match | |
140 tokens << [match, kind] | |
141 | |
142 end | |
143 | |
144 tokens | |
145 end | |
146 | |
147 end | |
148 | |
149 end | |
150 end |