diff options
author | shyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2018-01-12 08:38:11 +0000 |
---|---|---|
committer | shyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2018-01-12 08:38:11 +0000 |
commit | 8a72c77c7920d129818b7b83bb4fa669cd7e3f7d (patch) | |
tree | e88e17811fdb1059cc3a63199c297582780c8497 /tool/ruby_vm/loaders | |
parent | 069e9ff52cbb01fe2c5821a9b6a8077ab59c26c7 (diff) | |
download | ruby-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.rb | 8 | ||||
-rw-r--r-- | tool/ruby_vm/loaders/opt_insn_unif_def.rb | 6 | ||||
-rw-r--r-- | tool/ruby_vm/loaders/opt_operand_def.rb | 13 | ||||
-rw-r--r-- | tool/ruby_vm/loaders/vm_opts_h.rb | 4 |
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 |