[前][次][番号順一覧][スレッド一覧]

ruby-changes:8591

From: matz <ko1@a...>
Date: Fri, 7 Nov 2008 07:36:25 +0900 (JST)
Subject: [ruby-changes:8591] Ruby:r20126 (trunk): * lib/yaml/rubytypes.rb: support Rational and Complex as 1.8

matz	2008-11-07 07:36:07 +0900 (Fri, 07 Nov 2008)

  New Revision: 20126

  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=20126

  Log:
    * lib/yaml/rubytypes.rb: support Rational and Complex as 1.8
      does.  a patch from Hiroshi Moriyama in [ruby-dev:36899].

  Modified files:
    trunk/ChangeLog
    trunk/lib/yaml/rubytypes.rb
    trunk/test/yaml/test_yaml.rb

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 20125)
+++ ChangeLog	(revision 20126)
@@ -1,3 +1,8 @@
+Fri Nov  7 07:32:55 2008  Yukihiro Matsumoto  <matz@r...>
+
+	* lib/yaml/rubytypes.rb: support Rational and Complex as 1.8
+	  does.  a patch from Hiroshi Moriyama in [ruby-dev:36899].
+
 Fri Nov  7 07:12:06 2008  Nobuyoshi Nakada  <nobu@r...>
 
 	* thread_pthread.c (thread_timer): uses pthread_cond_timedwait always
Index: lib/yaml/rubytypes.rb
===================================================================
--- lib/yaml/rubytypes.rb	(revision 20125)
+++ lib/yaml/rubytypes.rb	(revision 20126)
@@ -379,6 +379,44 @@
 	end
 end
 
+class Rational
+	yaml_as "tag:ruby.yaml.org,2002:object:Rational"
+	def Rational.yaml_new( klass, tag, val )
+		if val.is_a? String
+			Rational( val )
+		else
+			Rational( val['numerator'], val['denominator'] )
+		end
+	end
+	def to_yaml( opts = {} ) 
+		YAML::quick_emit( self, opts ) do |out|
+			out.map( taguri, nil ) do |map| 
+				map.add( 'denominator', denominator )
+				map.add( 'numerator', numerator )
+			end
+		end
+	end
+end
+
+class Complex
+	yaml_as "tag:ruby.yaml.org,2002:object:Complex"
+	def Complex.yaml_new( klass, tag, val )
+		if val.is_a? String
+			Complex( val )
+		else
+			Complex( val['real'], val['image'] )
+		end
+	end
+	def to_yaml( opts = {} )
+		YAML::quick_emit( self, opts ) do |out|
+			out.map( taguri, nil ) do |map|
+				map.add( 'image', imaginary )
+				map.add( 'real', real )
+			end
+		end
+	end
+end
+
 class TrueClass
     yaml_as "tag:yaml.org,2002:bool#yes"
 	def to_yaml( opts = {} )
Index: test/yaml/test_yaml.rb
===================================================================
--- test/yaml/test_yaml.rb	(revision 20125)
+++ test/yaml/test_yaml.rb	(revision 20126)
@@ -1107,6 +1107,30 @@
 
 	end
 
+	def test_ruby_rational
+		assert_to_yaml( Rational(1, 2), <<EOY )
+--- !ruby/object:Rational 
+numerator: 1
+denominator: 2
+EOY
+
+		# Read YAML dumped by the ruby 1.8.3.
+		assert_to_yaml( Rational(1, 2), "!ruby/object:Rational 1/2\n" )
+		assert_raise( ArgumentError ) { YAML.load("!ruby/object:Rational INVALID/RATIONAL\n") }
+	end
+
+	def test_ruby_complex
+		assert_to_yaml( Complex(3, 4), <<EOY )
+--- !ruby/object:Complex 
+image: 4
+real: 3
+EOY
+
+		# Read YAML dumped by the ruby 1.8.3.
+		assert_to_yaml( Complex(3, 4), "!ruby/object:Complex 3+4i\n" )
+		assert_raise( ArgumentError ) { YAML.load("!ruby/object:Complex INVALID+COMPLEXi\n") }
+	end
+
 	def test_emitting_indicators
 		assert_to_yaml( "Hi, from Object 1. You passed: please, pretty please", <<EOY
 --- "Hi, from Object 1. You passed: please, pretty please"

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

[前][次][番号順一覧][スレッド一覧]