зеркало из https://github.com/github/ruby.git
* ext/psych/lib/psych/visitors/to_ruby.rb: strings with YAML anchors
are properly referenced. Patched by Joe Rafaniello via Github: https://github.com/tenderlove/psych/pull/69 * ext/psych/lib/psych/visitors/yaml_tree.rb: ditto * test/psych/test_alias_and_anchor.rb: test for change git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@36414 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
Родитель
43395d53c9
Коммит
7d1f53e782
|
@ -1,3 +1,11 @@
|
|||
Tue Jul 17 03:56:34 2012 Aaron Patterson <aaron@tenderlovemaking.com>
|
||||
|
||||
* ext/psych/lib/psych/visitors/to_ruby.rb: strings with YAML anchors
|
||||
are properly referenced. Patched by Joe Rafaniello via Github:
|
||||
https://github.com/tenderlove/psych/pull/69
|
||||
* ext/psych/lib/psych/visitors/yaml_tree.rb: ditto
|
||||
* test/psych/test_alias_and_anchor.rb: test for change
|
||||
|
||||
Mon Jul 16 23:20:24 2012 Tanaka Akira <akr@fsij.org>
|
||||
|
||||
* bignum.c (rb_integer_float_cmp): use FIXNUM_MIN and FIXNUM_MAX,
|
||||
|
|
|
@ -148,6 +148,7 @@ module Psych
|
|||
|
||||
if klass
|
||||
string = klass.allocate.replace string
|
||||
register(o, string)
|
||||
end
|
||||
|
||||
init_with(string, members.map { |k,v| [k.to_s.sub(/^@/, ''),v] }, o)
|
||||
|
|
|
@ -254,7 +254,7 @@ module Psych
|
|||
maptag = '!ruby/string'
|
||||
maptag << ":#{o.class}" unless o.class == ::String
|
||||
|
||||
@emitter.start_mapping nil, maptag, false, Nodes::Mapping::BLOCK
|
||||
register o, @emitter.start_mapping(nil, maptag, false, Nodes::Mapping::BLOCK)
|
||||
@emitter.scalar 'str', nil, nil, true, false, Nodes::Scalar::ANY
|
||||
@emitter.scalar str, nil, tag, plain, quote, style
|
||||
|
||||
|
|
|
@ -1,5 +1,13 @@
|
|||
require 'psych/helper'
|
||||
|
||||
class ObjectWithInstanceVariables
|
||||
attr_accessor :var1, :var2
|
||||
end
|
||||
|
||||
class SubStringWithInstanceVariables < String
|
||||
attr_accessor :var1
|
||||
end
|
||||
|
||||
module Psych
|
||||
class TestAliasAndAnchor < TestCase
|
||||
def test_mri_compatibility
|
||||
|
@ -14,6 +22,40 @@ EOYAML
|
|||
result.each {|el| assert_same(result[0], el) }
|
||||
end
|
||||
|
||||
def test_mri_compatibility_object_with_ivars
|
||||
yaml = <<EOYAML
|
||||
---
|
||||
- &id001 !ruby/object:ObjectWithInstanceVariables
|
||||
var1: test1
|
||||
var2: test2
|
||||
- *id001
|
||||
- *id001
|
||||
EOYAML
|
||||
|
||||
result = Psych.load yaml
|
||||
result.each do |el|
|
||||
assert_same(result[0], el)
|
||||
assert_equal('test1', el.var1)
|
||||
assert_equal('test2', el.var2)
|
||||
end
|
||||
end
|
||||
|
||||
def test_mri_compatibility_substring_with_ivars
|
||||
yaml = <<EOYAML
|
||||
---
|
||||
- &id001 !str:SubStringWithInstanceVariables
|
||||
str: test
|
||||
"@var1": test
|
||||
- *id001
|
||||
- *id001
|
||||
EOYAML
|
||||
result = Psych.load yaml
|
||||
result.each do |el|
|
||||
assert_same(result[0], el)
|
||||
assert_equal('test', el.var1)
|
||||
end
|
||||
end
|
||||
|
||||
def test_anchor_alias_round_trip
|
||||
o = Object.new
|
||||
original = [o,o,o]
|
||||
|
@ -22,5 +64,33 @@ EOYAML
|
|||
result = Psych.load yaml
|
||||
result.each {|el| assert_same(result[0], el) }
|
||||
end
|
||||
|
||||
def test_anchor_alias_round_trip_object_with_ivars
|
||||
o = ObjectWithInstanceVariables.new
|
||||
o.var1 = 'test1'
|
||||
o.var2 = 'test2'
|
||||
original = [o,o,o]
|
||||
|
||||
yaml = Psych.dump original
|
||||
result = Psych.load yaml
|
||||
result.each do |el|
|
||||
assert_same(result[0], el)
|
||||
assert_equal('test1', el.var1)
|
||||
assert_equal('test2', el.var2)
|
||||
end
|
||||
end
|
||||
|
||||
def test_anchor_alias_round_trip_substring_with_ivars
|
||||
o = SubStringWithInstanceVariables.new
|
||||
o.var1 = 'test'
|
||||
original = [o,o,o]
|
||||
|
||||
yaml = Psych.dump original
|
||||
result = Psych.load yaml
|
||||
result.each do |el|
|
||||
assert_same(result[0], el)
|
||||
assert_equal('test', el.var1)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Загрузка…
Ссылка в новой задаче