aboutsummaryrefslogtreecommitdiffstats
path: root/tool/ruby_vm/loaders
diff options
context:
space:
mode:
authorshyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2018-01-12 08:38:11 +0000
committershyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2018-01-12 08:38:11 +0000
commit8a72c77c7920d129818b7b83bb4fa669cd7e3f7d (patch)
treee88e17811fdb1059cc3a63199c297582780c8497 /tool/ruby_vm/loaders
parent069e9ff52cbb01fe2c5821a9b6a8077ab59c26c7 (diff)
downloadruby-8a72c77c7920d129818b7b83bb4fa669cd7e3f7d.tar.gz
tool/ruby_vm support for pre-2.1 BASERUBY
as requested by devs, support for BASERUBY prior to 2.1 git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@61786 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'tool/ruby_vm/loaders')
-rw-r--r--tool/ruby_vm/loaders/insns_def.rb8
-rw-r--r--tool/ruby_vm/loaders/opt_insn_unif_def.rb6
-rw-r--r--tool/ruby_vm/loaders/opt_operand_def.rb13
-rw-r--r--tool/ruby_vm/loaders/vm_opts_h.rb4
4 files changed, 15 insertions, 16 deletions
diff --git a/tool/ruby_vm/loaders/insns_def.rb b/tool/ruby_vm/loaders/insns_def.rb
index 58748c3ca6..987e29640a 100644
--- a/tool/ruby_vm/loaders/insns_def.rb
+++ b/tool/ruby_vm/loaders/insns_def.rb
@@ -41,7 +41,7 @@ grammar = %r'
'x
until scanner.eos? do
- next if scanner.scan(/#{grammar}\g<ws>+/o)
+ next if scanner.scan(/\G#{grammar}\g<ws>+/o)
split = -> (v) {
case v when /\Avoid\z/ then
[]
@@ -50,14 +50,14 @@ until scanner.eos? do
end
}
- l1 = scanner.scan!(/#{grammar}\g<insn>/o)
+ l1 = scanner.scan!(/\G#{grammar}\g<insn>/o)
name = scanner["insn:name"]
ope = split.(scanner["insn:opes"])
pop = split.(scanner["insn:pops"])
ret = split.(scanner["insn:rets"])
attrs = []
- while l2 = scanner.scan(/#{grammar}\g<pragma>/o) do
+ while l2 = scanner.scan(/\G#{grammar}\g<pragma>/o) do
attrs << {
location: [path, l2],
name: scanner["pragma:name"],
@@ -66,7 +66,7 @@ until scanner.eos? do
}
end
- l3 = scanner.scan!(/#{grammar}\g<block>/o)
+ l3 = scanner.scan!(/\G#{grammar}\g<block>/o)
json << {
name: name,
location: [path, l1],
diff --git a/tool/ruby_vm/loaders/opt_insn_unif_def.rb b/tool/ruby_vm/loaders/opt_insn_unif_def.rb
index a5af409e71..0f5de69930 100644
--- a/tool/ruby_vm/loaders/opt_insn_unif_def.rb
+++ b/tool/ruby_vm/loaders/opt_insn_unif_def.rb
@@ -16,10 +16,10 @@ json = []
scanner = RubyVM::Scanner.new '../../../defs/opt_insn_unif.def'
path = scanner.__FILE__
until scanner.eos? do
- next if scanner.scan(/ ^ (?: \#.* )? \n /x)
- break if scanner.scan(/ ^ __END__ $ /x)
+ next if scanner.scan(/\G ^ (?: \#.* )? \n /x)
+ break if scanner.scan(/\G ^ __END__ $ /x)
- pos = scanner.scan!(/(?<series> (?: [\ \t]* \w+ )+ ) \n /mx)
+ pos = scanner.scan!(/\G (?<series> (?: [\ \t]* \w+ )+ ) \n /mx)
json << {
location: [path, pos],
signature: scanner["series"].strip.split
diff --git a/tool/ruby_vm/loaders/opt_operand_def.rb b/tool/ruby_vm/loaders/opt_operand_def.rb
index 5c94b4bced..3022f9915d 100644
--- a/tool/ruby_vm/loaders/opt_operand_def.rb
+++ b/tool/ruby_vm/loaders/opt_operand_def.rb
@@ -29,18 +29,17 @@ grammar = %r/
/mx
until scanner.eos? do
- break if scanner.scan(/ ^ __END__ $ /x)
- next if scanner.scan(/#{grammar} \g<ws>+ /ox)
+ break if scanner.scan(/\G ^ __END__ $ /x)
+ next if scanner.scan(/\G#{grammar} \g<ws>+ /ox)
- line = scanner.scan!(/#{grammar} \g<decl> /mox)
+ line = scanner.scan!(/\G#{grammar} \g<decl> /mox)
insn = scanner["insn"]
args = scanner["args"]
ary = []
until args.strip.empty? do
- tmp = StringScanner.new args
- tmp.scan(/#{grammar} \g<args> /mox)
- ary << tmp["arg"]
- args = tmp["remain"]
+ md = /\G#{grammar} \g<args> /mox.match(args)
+ ary << md["arg"]
+ args = md["remain"]
break unless args
end
json << {
diff --git a/tool/ruby_vm/loaders/vm_opts_h.rb b/tool/ruby_vm/loaders/vm_opts_h.rb
index f898fb36a4..d28db4eaa2 100644
--- a/tool/ruby_vm/loaders/vm_opts_h.rb
+++ b/tool/ruby_vm/loaders/vm_opts_h.rb
@@ -18,14 +18,14 @@ grammar = %r/
(?<ws> \u0020 ){0}
(?<key> \w+ ){0}
(?<value> 0|1 ){0}
- (?<define> \#define \g<ws>+ OPT_\g<key> \g<ws>+ \g<value> \g<ws>*\n )
+ (?<define> \G \#define \g<ws>+ OPT_\g<key> \g<ws>+ \g<value> \g<ws>*\n )
/mx
until scanner.eos? do
if scanner.scan grammar then
json[scanner['key']] = ! scanner['value'].to_i.zero? # not nonzero?
else
- scanner.scan(/.*\n/)
+ scanner.scan(/\G.*\n/)
end
end