ruby_parser 3.13.1 → 3.15.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- checksums.yaml.gz.sig +0 -0
- data.tar.gz.sig +0 -0
- data/.autotest +18 -29
- data/History.rdoc +97 -0
- data/Manifest.txt +2 -0
- data/README.rdoc +3 -3
- data/Rakefile +39 -21
- data/bin/ruby_parse +3 -1
- data/bin/ruby_parse_extract_error +8 -3
- data/compare/normalize.rb +43 -3
- data/debugging.md +39 -0
- data/lib/ruby20_parser.rb +3431 -3238
- data/lib/ruby20_parser.y +474 -300
- data/lib/ruby21_parser.rb +3491 -3295
- data/lib/ruby21_parser.y +482 -307
- data/lib/ruby22_parser.rb +3432 -3240
- data/lib/ruby22_parser.y +483 -308
- data/lib/ruby23_parser.rb +3338 -3150
- data/lib/ruby23_parser.y +483 -308
- data/lib/ruby24_parser.rb +3483 -3273
- data/lib/ruby24_parser.y +487 -310
- data/lib/ruby25_parser.rb +3482 -3272
- data/lib/ruby25_parser.y +487 -310
- data/lib/ruby26_parser.rb +3490 -3278
- data/lib/ruby26_parser.y +493 -314
- data/lib/ruby27_parser.rb +7224 -0
- data/lib/ruby27_parser.y +2657 -0
- data/lib/ruby_lexer.rb +483 -459
- data/lib/ruby_lexer.rex +5 -6
- data/lib/ruby_lexer.rex.rb +6 -8
- data/lib/ruby_parser.rb +29 -27
- data/lib/ruby_parser.yy +497 -315
- data/lib/ruby_parser_extras.rb +670 -420
- data/test/test_ruby_lexer.rb +1208 -1121
- data/test/test_ruby_parser.rb +2517 -1955
- data/test/test_ruby_parser_extras.rb +39 -4
- data/tools/munge.rb +10 -5
- data/tools/ripper.rb +13 -2
- metadata +28 -21
- metadata.gz.sig +0 -0
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 0adcb0c06b7ee6d29360bd8dd9641dfcce867cdd7167f59bef5134c3092cb091
|
4
|
+
data.tar.gz: ef51691d5a0e2f09a38a0c6d8bd8d3fccdebf19bd1c1ce41a99f761112a43c4a
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 85e6684d7a8a6207f1040ca97768d4792ba52e2f039eee5fa83047e8e5c83a7a913f98fc5384ac8b3387829078e294e22fb009163ac4eee272557cbed715849e
|
7
|
+
data.tar.gz: 7e996bef3411d3f63dfd8e2af388bddb16dc8a4206bd309611aeda038feb4c66041fb2b7ba5136015d4b0453e34fdebf8c1f8d408d68dccb9031514ebff6f728
|
checksums.yaml.gz.sig
CHANGED
Binary file
|
data.tar.gz.sig
CHANGED
Binary file
|
data/.autotest
CHANGED
@@ -7,20 +7,20 @@ require 'autotest/rcov' if ENV['RCOV']
|
|
7
7
|
Autotest.add_hook :initialize do |at|
|
8
8
|
at.extra_files << "../../sexp_processor/dev/lib/pt_testcase.rb"
|
9
9
|
at.libs << ":../../sexp_processor/dev/lib"
|
10
|
-
at.add_exception "unit"
|
11
|
-
at.add_exception "coverage"
|
12
|
-
at.add_exception "coverage.info"
|
13
10
|
at.add_exception ".diff"
|
11
|
+
at.add_exception ".rdoc"
|
12
|
+
at.add_exception ".yml"
|
13
|
+
at.add_exception ".txt"
|
14
14
|
at.add_exception ".output"
|
15
|
-
at.add_exception "
|
16
|
-
at.add_exception "
|
17
|
-
at.add_exception "
|
18
|
-
at.add_exception "
|
19
|
-
at.add_exception "
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
15
|
+
at.add_exception "bin"
|
16
|
+
at.add_exception "compare"
|
17
|
+
at.add_exception "coverage"
|
18
|
+
at.add_exception "coverage.info"
|
19
|
+
at.add_exception "misc"
|
20
|
+
|
21
|
+
Dir["lib/ruby??_parser.{rb,y}"].each do |f|
|
22
|
+
at.add_exception f
|
23
|
+
end
|
24
24
|
|
25
25
|
Dir["gauntlet*"].each do |f|
|
26
26
|
at.add_exception f
|
@@ -30,12 +30,12 @@ Autotest.add_hook :initialize do |at|
|
|
30
30
|
at.testlib = "minitest/autorun"
|
31
31
|
|
32
32
|
at.add_mapping(/^lib\/.*\.y$/) do |f, _|
|
33
|
-
g = File.basename(f, ".y").gsub("_", "_?").gsub(/
|
33
|
+
g = File.basename(f, ".y").gsub("_", "_?").gsub(/2\d/, '')
|
34
34
|
at.files_matching %r%^test/.*#{g}.rb$%
|
35
35
|
end
|
36
36
|
|
37
37
|
at.add_mapping(/^lib\/.*\.yy$/) do |f, _|
|
38
|
-
g = File.basename(f, ".yy").gsub("_", "_?")
|
38
|
+
g = File.basename(f, ".yy").gsub("_", "_?")
|
39
39
|
at.files_matching %r%^test/.*#{g}.rb$%
|
40
40
|
end
|
41
41
|
|
@@ -52,27 +52,16 @@ Autotest.add_hook :initialize do |at|
|
|
52
52
|
at.files_matching(/test_.*rb$/)
|
53
53
|
end
|
54
54
|
|
55
|
-
%w(TestEnvironment TestStackState).each do |klass|
|
55
|
+
%w(TestEnvironment TestStackState TestValueExpr).each do |klass|
|
56
56
|
at.extra_class_map[klass] = "test/test_ruby_parser_extras.rb"
|
57
57
|
end
|
58
58
|
|
59
|
-
|
60
|
-
|
59
|
+
Dir["lib/ruby??_parser.rb"].each do |s|
|
60
|
+
n = s[/\d+/]
|
61
|
+
at.extra_class_map["TestRubyParserV#{n}"] = "test/test_ruby_parser.rb"
|
61
62
|
end
|
62
63
|
end
|
63
64
|
|
64
65
|
Autotest.add_hook :run_command do |at, _|
|
65
66
|
system "rake parser lexer DEBUG=1"
|
66
67
|
end
|
67
|
-
|
68
|
-
class Autotest
|
69
|
-
def ruby
|
70
|
-
File.expand_path "~/.multiruby/install/1.9.3-p194/bin/ruby"
|
71
|
-
end
|
72
|
-
end if ENV["R19"]
|
73
|
-
|
74
|
-
class Autotest
|
75
|
-
def ruby
|
76
|
-
File.expand_path "~/.multiruby/install/2.0.0-p195/bin/ruby"
|
77
|
-
end
|
78
|
-
end if ENV["R20"]
|
data/History.rdoc
CHANGED
@@ -1,3 +1,100 @@
|
|
1
|
+
=== 3.15.1 / 2021-01-10
|
2
|
+
|
3
|
+
* 1 bug fix:
|
4
|
+
|
5
|
+
* Bumped ruby version to include < 4 (trunk).
|
6
|
+
|
7
|
+
=== 3.15.0 / 2020-08-31
|
8
|
+
|
9
|
+
* 1 major enhancement:
|
10
|
+
|
11
|
+
* Added tentative 2.7 support.
|
12
|
+
|
13
|
+
* 1 minor enhancement:
|
14
|
+
|
15
|
+
* Improved ruby_parse_extract_error's handling of moving slow files out.
|
16
|
+
|
17
|
+
* 22 bug fixes:
|
18
|
+
|
19
|
+
* Bumped ruby version to include 3.0 (trunk).
|
20
|
+
* Fix an error related to empty ensure bodies. (presidentbeef)
|
21
|
+
* Fix handling of bad magic encoding comment.
|
22
|
+
* Fixed SystemStackError when parsing a huoooge hash, caused by a splat arg.
|
23
|
+
* Fixed a number of errors parsing do blocks in strange edge cases.
|
24
|
+
* Fixed a string backslash lexing bug when the string is an invalid encoding. (nijikon, gmcgibbon)
|
25
|
+
* Fixed bug assigning line number to some arg nodes.
|
26
|
+
* Fixed bug concatinating string literals with differing encodings.
|
27
|
+
* Fixed bug lexing heredoc w/ nasty mix of \r\n and \n.
|
28
|
+
* Fixed bug lexing multiple codepoints in \u{0000 1111 2222} forms.
|
29
|
+
* Fixed bug setting line numbers in empty xstrings in some contexts.
|
30
|
+
* Fixed edge case on call w/ begin + do block as an arg.
|
31
|
+
* Fixed handling of UTF BOM.
|
32
|
+
* Fixed handling of lexer state across string interpolation braces.
|
33
|
+
* Fixed infinite loop when lexing backslash+cr+newline (aka dos-files)
|
34
|
+
* Fixed lambda + do block edge case.
|
35
|
+
* Fixed lexing of some ?\M... and ?\C... edge cases.
|
36
|
+
* Fixed more do/brace block edge case failures.
|
37
|
+
* Fixed parsing bug where splat was used in the middle of a list.
|
38
|
+
* Fixed parsing of interpolation in heredoc-like strings. (presidentbeef)
|
39
|
+
* Fixed parsing some esoteric edge cases in op_asgn.
|
40
|
+
* Fixed unicode processing in ident chars so now they better mix.
|
41
|
+
|
42
|
+
=== 3.14.2 / 2020-02-06
|
43
|
+
|
44
|
+
* 1 minor enhancement:
|
45
|
+
|
46
|
+
* Cleaned up call_args and removed arg_blk_pass from ruby_parser_extras.rb! Yay!
|
47
|
+
|
48
|
+
=== 3.14.1 / 2019-10-29
|
49
|
+
|
50
|
+
* 1 minor enhancement:
|
51
|
+
|
52
|
+
* Declared that ruby_parser supports ruby 2.2 and up.
|
53
|
+
|
54
|
+
* 3 bug fixes:
|
55
|
+
|
56
|
+
* Fixed a problem with %W with a null-byte terminator. (wtf?) (spohlenz)
|
57
|
+
* Fixed line numbering for command (eg methods without parentheses) arguments. (mvz)
|
58
|
+
* Fixed lineno on new dxstrs. (presidentbeef)
|
59
|
+
|
60
|
+
=== 3.14.0 / 2019-09-24
|
61
|
+
|
62
|
+
* 8 minor enhancements:
|
63
|
+
|
64
|
+
* Added Sexp#line_min & new line number debugging feature.
|
65
|
+
* Allow bin/ruby_parse to use RP_TIMEOUT to tweak default timeout for large files & slow debugging modes.
|
66
|
+
* Did you know that custom inspect can't be > 65 chars? 65! Me neither. Fixed.
|
67
|
+
* For now, value_expr == remove_begin.
|
68
|
+
* Improved error messages for unterminated regexps.
|
69
|
+
* Moved all STR_* consts into State::Values and made them State instances.
|
70
|
+
* Overhauled RubyLexer::State + Values to allow for completely separate groups of States.
|
71
|
+
* RubyParserExtras#remove_begin removes nested begins and patches line numbers.
|
72
|
+
|
73
|
+
* 22 bug fixes:
|
74
|
+
|
75
|
+
* Changed EOF signaling to return [false, false] per doco.
|
76
|
+
* Changed RubyParserStuff#remove_begin to keep inner line number, if any. (mvz)
|
77
|
+
* Differentiated between lambda call and stabby proc. Added :lambda sexp. (whitequark)
|
78
|
+
* Extended State#== to check equal? first as an optimization.
|
79
|
+
* Fixed a bug in tab indent width.
|
80
|
+
* Fixed a line numbering bug for assignables.
|
81
|
+
* Fixed a line numbering bug for defns w/ nil bodies.
|
82
|
+
* Fixed another missing line number, driven out by ruby_to_ruby bootstrap.
|
83
|
+
* Fixed dedenting squiggle heredocs if interpolation is in the mix. (mvz)
|
84
|
+
* Fixed differentiation of `{ |a| ... }` vs `{ |a,| ... }`. Fixes #236 (whitequark).
|
85
|
+
* Fixed lex_state for symbols.
|
86
|
+
* Fixed lex_state for tSTRING_END and tREGEXP_END.
|
87
|
+
* Fixed line numbers for BEGIN block. (mvz)
|
88
|
+
* Fixed op_asgn1 w/ command_call having array instead of arglist. (mvz)
|
89
|
+
* Fixed parsing of () in a command-call (eg p).
|
90
|
+
* Fixed remaining missing line numbers by forcing extra checks during test and blowing up. They may still be wrong (esp after heredocs, ugh), but they're there! Special thank you to mvz for pushing on this and providing tests and PRs.
|
91
|
+
* Fixed some lex_state versioning issues with closing braces/bracket on ruby<25.
|
92
|
+
* Keep carriage return escapes in heredocs. (mvz)
|
93
|
+
* Massive overhaul of line number code.
|
94
|
+
* More line number fixes and extra tests from mvz. Thank you!
|
95
|
+
* Parsing BEGIN block when not at top level should raise an error. (mvz)
|
96
|
+
* Removed irb task from Rakefile as it has been pushed up to Hoe and doubles up here.
|
97
|
+
|
1
98
|
=== 3.13.1 / 2019-03-25
|
2
99
|
|
3
100
|
* 1 major enhancement:
|
data/Manifest.txt
CHANGED
data/README.rdoc
CHANGED
@@ -7,9 +7,9 @@ rdoc :: http://docs.seattlerb.org/ruby_parser
|
|
7
7
|
== DESCRIPTION:
|
8
8
|
|
9
9
|
ruby_parser (RP) is a ruby parser written in pure ruby (utilizing
|
10
|
-
racc--which does by default use a C extension).
|
11
|
-
|
12
|
-
|
10
|
+
racc--which does by default use a C extension). It outputs
|
11
|
+
s-expressions which can be manipulated and converted back to ruby via
|
12
|
+
the ruby2ruby gem.
|
13
13
|
|
14
14
|
As an example:
|
15
15
|
|
data/Rakefile
CHANGED
@@ -8,11 +8,12 @@ Hoe.plugin :racc
|
|
8
8
|
Hoe.plugin :isolate
|
9
9
|
Hoe.plugin :rdoc
|
10
10
|
|
11
|
+
Hoe.add_include_dirs "lib"
|
11
12
|
Hoe.add_include_dirs "../../sexp_processor/dev/lib"
|
12
13
|
Hoe.add_include_dirs "../../minitest/dev/lib"
|
13
14
|
Hoe.add_include_dirs "../../oedipus_lex/dev/lib"
|
14
15
|
|
15
|
-
V2 = %w[20 21 22 23 24 25 26]
|
16
|
+
V2 = %w[20 21 22 23 24 25 26 27]
|
16
17
|
V2.replace [V2.last] if ENV["FAST"] # HACK
|
17
18
|
|
18
19
|
Hoe.spec "ruby_parser" do
|
@@ -24,6 +25,8 @@ Hoe.spec "ruby_parser" do
|
|
24
25
|
dependency "rake", "< 11", :developer
|
25
26
|
dependency "oedipus_lex", "~> 2.5", :developer
|
26
27
|
|
28
|
+
require_ruby_version [">= 2.1", "< 4"]
|
29
|
+
|
27
30
|
if plugin? :perforce then # generated files
|
28
31
|
V2.each do |n|
|
29
32
|
self.perforce_ignore << "lib/ruby#{n}_parser.rb"
|
@@ -54,6 +57,8 @@ end
|
|
54
57
|
|
55
58
|
file "lib/ruby_lexer.rex.rb" => "lib/ruby_lexer.rex"
|
56
59
|
|
60
|
+
task :generate => [:lexer, :parser]
|
61
|
+
|
57
62
|
task :clean do
|
58
63
|
rm_rf(Dir["**/*~"] +
|
59
64
|
Dir["diff.diff"] + # not all diffs. bit me too many times
|
@@ -73,10 +78,6 @@ task :huh? do
|
|
73
78
|
puts "ruby #{Hoe::RUBY_FLAGS} bin/ruby_parse -q -g ..."
|
74
79
|
end
|
75
80
|
|
76
|
-
task :irb => [:isolate] do
|
77
|
-
sh "GEM_HOME=#{Gem.path.first} irb -rubygems -Ilib -rruby_parser;"
|
78
|
-
end
|
79
|
-
|
80
81
|
def (task(:phony)).timestamp
|
81
82
|
Time.at 0
|
82
83
|
end
|
@@ -107,7 +108,7 @@ def ruby_parse version
|
|
107
108
|
ruby_dir = "ruby-#{version}"
|
108
109
|
diff = "diff#{v}.diff"
|
109
110
|
rp_out = "lib/ruby#{v}_parser.output"
|
110
|
-
|
111
|
+
_rp_y = "lib/ruby#{v}_parser.y"
|
111
112
|
rp_y_rb = "lib/ruby#{v}_parser.rb"
|
112
113
|
|
113
114
|
c_diff = "compare/#{diff}"
|
@@ -125,13 +126,22 @@ def ruby_parse version
|
|
125
126
|
|
126
127
|
file c_parse_y => c_tarball do
|
127
128
|
in_compare do
|
128
|
-
|
129
|
+
extract_glob = case version
|
130
|
+
when /2\.7/
|
131
|
+
"{id.h,parse.y,tool/{id2token.rb,lib/vpath.rb}}"
|
132
|
+
else
|
133
|
+
"{id.h,parse.y,tool/{id2token.rb,vpath.rb}}"
|
134
|
+
end
|
135
|
+
system "tar yxf #{tarball} #{ruby_dir}/#{extract_glob}"
|
136
|
+
|
129
137
|
Dir.chdir ruby_dir do
|
130
138
|
if File.exist? "tool/id2token.rb" then
|
131
139
|
sh "ruby tool/id2token.rb --path-separator=.:./ id.h parse.y | expand > ../#{parse_y}"
|
132
140
|
else
|
133
141
|
sh "expand parse.y > ../#{parse_y}"
|
134
142
|
end
|
143
|
+
|
144
|
+
ruby "-pi", "-e", 'gsub(/^%define\s+api\.pure/, "%pure-parser")', "../#{parse_y}"
|
135
145
|
end
|
136
146
|
sh "rm -rf #{ruby_dir}"
|
137
147
|
end
|
@@ -184,16 +194,17 @@ ruby_parse "2.0.0-p648"
|
|
184
194
|
ruby_parse "2.1.9"
|
185
195
|
ruby_parse "2.2.9"
|
186
196
|
ruby_parse "2.3.8"
|
187
|
-
ruby_parse "2.4.
|
188
|
-
ruby_parse "2.5.
|
189
|
-
ruby_parse "2.6.
|
197
|
+
ruby_parse "2.4.9"
|
198
|
+
ruby_parse "2.5.8"
|
199
|
+
ruby_parse "2.6.6"
|
200
|
+
ruby_parse "2.7.1"
|
190
201
|
|
191
202
|
task :debug => :isolate do
|
192
203
|
ENV["V"] ||= V2.last
|
193
204
|
Rake.application[:parser].invoke # this way we can have DEBUG set
|
194
205
|
Rake.application[:lexer].invoke # this way we can have DEBUG set
|
195
206
|
|
196
|
-
|
207
|
+
$:.unshift "lib"
|
197
208
|
require "ruby_parser"
|
198
209
|
require "pp"
|
199
210
|
|
@@ -204,19 +215,21 @@ task :debug => :isolate do
|
|
204
215
|
time = (ENV["RP_TIMEOUT"] || 10).to_i
|
205
216
|
|
206
217
|
n = ENV["BUG"]
|
207
|
-
file = (n && "bug#{n}.rb") || ENV["F"] || ENV["FILE"]
|
218
|
+
file = (n && "bug#{n}.rb") || ENV["F"] || ENV["FILE"] || "bug.rb"
|
219
|
+
ruby = ENV["R"] || ENV["RUBY"]
|
220
|
+
|
221
|
+
if ruby then
|
222
|
+
file = "env"
|
223
|
+
else
|
224
|
+
ruby = File.read file
|
225
|
+
end
|
208
226
|
|
209
|
-
ruby = if file then
|
210
|
-
File.read(file)
|
211
|
-
else
|
212
|
-
file = "env"
|
213
|
-
ENV["R"] || ENV["RUBY"]
|
214
|
-
end
|
215
227
|
|
216
228
|
begin
|
217
229
|
pp parser.process(ruby, file, time)
|
218
|
-
rescue Racc::ParseError => e
|
230
|
+
rescue ArgumentError, Racc::ParseError => e
|
219
231
|
p e
|
232
|
+
puts e.backtrace.join "\n "
|
220
233
|
ss = parser.lexer.ss
|
221
234
|
src = ss.string
|
222
235
|
lines = src[0..ss.pos].split(/\n/)
|
@@ -225,7 +238,7 @@ task :debug => :isolate do
|
|
225
238
|
end
|
226
239
|
|
227
240
|
task :debug3 do
|
228
|
-
file = ENV["F"]
|
241
|
+
file = ENV["F"] || "bug.rb"
|
229
242
|
verbose = ENV["V"] ? "-v" : ""
|
230
243
|
munge = "./tools/munge.rb #{verbose}"
|
231
244
|
|
@@ -233,12 +246,17 @@ task :debug3 do
|
|
233
246
|
|
234
247
|
ENV.delete "V"
|
235
248
|
|
249
|
+
sh "ruby -v"
|
236
250
|
sh "ruby -y #{file} 2>&1 | #{munge} > tmp/ruby"
|
237
251
|
sh "./tools/ripper.rb -d #{file} | #{munge} > tmp/rip"
|
238
|
-
sh "rake debug F=#{file} DEBUG=1
|
252
|
+
sh "rake debug F=#{file} DEBUG=1 2>&1 | #{munge} > tmp/rp"
|
239
253
|
sh "diff -U 999 -d tmp/{rip,rp}"
|
240
254
|
end
|
241
255
|
|
256
|
+
task :cmp do
|
257
|
+
sh %(emacsclient --eval '(ediff-files "tmp/ruby" "tmp/rp")')
|
258
|
+
end
|
259
|
+
|
242
260
|
task :cmp3 do
|
243
261
|
sh %(emacsclient --eval '(ediff-files3 "tmp/ruby" "tmp/rip" "tmp/rp")')
|
244
262
|
end
|
data/bin/ruby_parse
CHANGED
@@ -26,6 +26,8 @@ class File
|
|
26
26
|
end
|
27
27
|
|
28
28
|
begin
|
29
|
+
time = (ENV["RP_TIMEOUT"] || 10).to_i
|
30
|
+
|
29
31
|
ARGV.each do |file|
|
30
32
|
rp = RubyParser.new
|
31
33
|
loc = `wc -l #{file}`.strip.to_i
|
@@ -45,7 +47,7 @@ begin
|
|
45
47
|
begin
|
46
48
|
begin
|
47
49
|
rp.reset
|
48
|
-
r = rp.
|
50
|
+
r = rp.process(File.binread(file), file, time)
|
49
51
|
pp r unless $q
|
50
52
|
good += 1
|
51
53
|
rescue SyntaxError => e
|
@@ -104,9 +104,14 @@ rescue Timeout::Error
|
|
104
104
|
warn "TIMEOUT parsing #{file}. Skipping."
|
105
105
|
|
106
106
|
if $m then
|
107
|
-
|
108
|
-
|
109
|
-
|
107
|
+
base_dir, *rest = file.split("/")
|
108
|
+
base_dir.sub!(/\.slow\.?.*/, "")
|
109
|
+
base_dir += ".slow.#{time}"
|
110
|
+
|
111
|
+
new_file = File.join(base_dir, *rest)
|
112
|
+
|
113
|
+
FileUtils.mkdir_p File.dirname(new_file)
|
114
|
+
FileUtils.move file, new_file, verbose:true
|
110
115
|
elsif $t then
|
111
116
|
File.unlink file
|
112
117
|
end
|
data/compare/normalize.rb
CHANGED
@@ -8,6 +8,10 @@ order = []
|
|
8
8
|
|
9
9
|
def munge s
|
10
10
|
renames = [
|
11
|
+
# unquote... wtf?
|
12
|
+
/`(.+?)'/, proc { $1 },
|
13
|
+
/"'(.+?)'"/, proc { "\"#{$1}\"" },
|
14
|
+
|
11
15
|
"'='", "tEQL",
|
12
16
|
"'!'", "tBANG",
|
13
17
|
"'%'", "tPERCENT",
|
@@ -100,6 +104,43 @@ def munge s
|
|
100
104
|
|
101
105
|
"kVARIABLE", "keyword_variable", # ugh: this is a rule name
|
102
106
|
|
107
|
+
# 2.7 changes:
|
108
|
+
|
109
|
+
'"global variable"', "tGVAR",
|
110
|
+
'"operator-assignment"', "tOP_ASGN",
|
111
|
+
'"back reference"', "tBACK_REF",
|
112
|
+
'"numbered reference"', "tNTH_REF",
|
113
|
+
'"local variable or method"', "tIDENTIFIER",
|
114
|
+
'"constant"', "tCONSTANT",
|
115
|
+
|
116
|
+
'"(.."', "tBDOT2",
|
117
|
+
'"(..."', "tBDOT3",
|
118
|
+
'"char literal"', "tCHAR",
|
119
|
+
'"literal content"', "tSTRING_CONTENT",
|
120
|
+
'"string literal"', "tSTRING_BEG",
|
121
|
+
'"symbol literal"', "tSYMBEG",
|
122
|
+
'"backtick literal"', "tXSTRING_BEG",
|
123
|
+
'"regexp literal"', "tREGEXP_BEG",
|
124
|
+
'"word list"', "tWORDS_BEG",
|
125
|
+
'"verbatim word list"', "tQWORDS_BEG",
|
126
|
+
'"symbol list"', "tSYMBOLS_BEG",
|
127
|
+
'"verbatim symbol list"', "tQSYMBOLS_BEG",
|
128
|
+
|
129
|
+
'"float literal"', "tFLOAT",
|
130
|
+
'"imaginary literal"', "tIMAGINARY",
|
131
|
+
'"integer literal"', "tINTEGER",
|
132
|
+
'"rational literal"', "tRATIONAL",
|
133
|
+
|
134
|
+
'"instance variable"', "tIVAR",
|
135
|
+
'"class variable"', "tCVAR",
|
136
|
+
'"terminator"', "tSTRING_END", # TODO: switch this?
|
137
|
+
'"method"', "tFID",
|
138
|
+
'"}"', "tSTRING_DEND",
|
139
|
+
|
140
|
+
'"do for block"', "kDO_BLOCK",
|
141
|
+
'"do for condition"', "kDO_COND",
|
142
|
+
'"do for lambda"', "kDO_LAMBDA",
|
143
|
+
|
103
144
|
# UGH
|
104
145
|
"k_LINE__", "k__LINE__",
|
105
146
|
"k_FILE__", "k__FILE__",
|
@@ -107,13 +148,12 @@ def munge s
|
|
107
148
|
|
108
149
|
'"defined?"', "kDEFINED",
|
109
150
|
|
110
|
-
|
111
151
|
'"do (for condition)"', "kDO_COND",
|
112
152
|
'"do (for lambda)"', "kDO_LAMBDA",
|
113
153
|
'"do (for block)"', "kDO_BLOCK",
|
114
154
|
|
115
|
-
/\"(\w+) \(modifier\)
|
116
|
-
/\"(\w+)\"/,
|
155
|
+
/\"(\w+) \(?modifier\)?\"/, proc { |x| "k#{$1.upcase}_MOD" },
|
156
|
+
/\"(\w+)\"/, proc { |x| "k#{$1.upcase}" },
|
117
157
|
|
118
158
|
/@(\d+)(\s+|$)/, "",
|
119
159
|
]
|