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

ruby-changes:2206

From: ko1@a...
Date: 14 Oct 2007 17:32:05 +0900
Subject: [ruby-changes:2206] nobu - Ruby:r13697 (trunk): * encoding.c (rb_obj_encoding): rdoc update. a patch from David

nobu	2007-10-14 17:31:51 +0900 (Sun, 14 Oct 2007)

  New Revision: 13697

  Added files:
    trunk/test/ruby/test_encoding.rb
  Modified files:
    trunk/ChangeLog
    trunk/encoding.c

  Log:
    * encoding.c (rb_obj_encoding): rdoc update.  a patch from David
      Flanagan <david AT davidflanagan.com>.  [ruby-core:12664]
    
    * encoding.c (enc_dump, enc_load): marshaling feature.  a patch from
      David Flanagan.  [ruby-core:12665]
    
    * encoding.c (Init_Encoding): undefine allocator of Encoding.
      [ruby-core:12665], [ruby-core:12666]
    
    * test/ruby/test_encoding.rb: tests for Encoding from David Flanagan
      [ruby-core:12665]


  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=13697&r2=13696
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/test/ruby/test_encoding.rb?r1=13697&r2=13696
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/test/ruby/test_encoding.rb?revision=13697&view=markup
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/encoding.c?r1=13697&r2=13696
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/encoding.c?r1=13697&r2=13696

Index: encoding.c
===================================================================
--- encoding.c	(revision 13696)
+++ encoding.c	(revision 13697)
@@ -2,8 +2,8 @@
 
   encoding.c -
 
-  $Author: matz $
-  $Date: 2007-05-24 17:22:33 +0900 (Thu, 24 May 2007) $
+  $Author$
+  $Date$
   created at: Thu May 24 17:23:27 JST 2007
 
   Copyright (C) 2007 Yukihiro Matsumoto
@@ -372,9 +372,9 @@
 
 /*
  *  call-seq:
- *     obj.encoding   => str
+ *     obj.encoding   => encoding
  *
- *  Retruns the encoding name.
+ *  Returns the Encoding object that represents the encoding of obj.
  */
 
 VALUE
@@ -498,12 +498,31 @@
     return enc_from_encoding(rb_enc_from_index(idx));
 }
 
+/* :nodoc: */
+static VALUE
+enc_dump(int argc, VALUE *argv, VALUE self)
+{
+    rb_scan_args(argc, argv, "01", 0);
+    return enc_name(self);
+}
+
+/* :nodoc: */
+static VALUE
+enc_load(VALUE klass, VALUE str)
+{
+    return enc_find(klass, str);
+}
+
 void
 Init_Encoding(void)
 {
     rb_cEncoding = rb_define_class("Encoding", rb_cObject);
+    rb_undef_alloc_func(rb_cEncoding);
     rb_define_method(rb_cEncoding, "inspect", enc_inspect, 0);
     rb_define_method(rb_cEncoding, "name", enc_name, 0);
     rb_define_singleton_method(rb_cEncoding, "list", enc_list, 0);
     rb_define_singleton_method(rb_cEncoding, "find", enc_find, 1);
+
+    rb_define_method(rb_cEncoding, "_dump", enc_dump, -1);
+    rb_define_singleton_method(rb_cEncoding, "_load", enc_load, 1);
 }

Property changes on: encoding.c
___________________________________________________________________
Name: svn:keywords
   + Author Date Id Revision
Name: svn:eol-style
   + LF

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 13696)
+++ ChangeLog	(revision 13697)
@@ -1,3 +1,17 @@
+Sun Oct 14 17:31:48 2007  Nobuyoshi Nakada  <nobu@r...>
+
+	* encoding.c (rb_obj_encoding): rdoc update.  a patch from David
+	  Flanagan <david AT davidflanagan.com>.  [ruby-core:12664]
+
+	* encoding.c (enc_dump, enc_load): marshaling feature.  a patch from
+	  David Flanagan.  [ruby-core:12665]
+
+	* encoding.c (Init_Encoding): undefine allocator of Encoding.
+	  [ruby-core:12665], [ruby-core:12666]
+
+	* test/ruby/test_encoding.rb: tests for Encoding from David Flanagan
+	  [ruby-core:12665]
+
 Sun Oct 14 11:09:09 2007  Tanaka Akira  <akr@f...>
 
 	* lib/pp.rb (PP::PPMethods#pp_hash): don't sort keys because hash is
Index: test/ruby/test_encoding.rb
===================================================================
--- test/ruby/test_encoding.rb	(revision 0)
+++ test/ruby/test_encoding.rb	(revision 13697)
@@ -0,0 +1,28 @@
+require 'test/unit'
+
+class TestEncoding < Test::Unit::TestCase
+
+  # Test basic encoding methods: list, find, name
+  def test_encoding
+    encodings = Encoding.list
+    assert_equal(encodings.empty?, false)
+
+    encodings.each do |e|
+      assert_equal(e, Encoding.find(e.name))
+      assert_equal(e, Encoding.find(e.name.upcase))
+      assert_equal(e, Encoding.find(e.name.capitalize))
+      assert_equal(e, Encoding.find(e.name.downcase))
+    end
+  end
+
+  # Test that Encoding objects can't be copied
+  # And that they can be compared by object_id
+  def test_singleton
+    encodings = Encoding.list
+    encodings.each do |e|
+      assert_raise(TypeError) { e.dup }
+      assert_raise(TypeError) { e.clone }
+      assert_equal(e.object_id, Marshal.load(Marshal.dump(e)).object_id)
+    end    
+  end
+end

Property changes on: test/ruby/test_encoding.rb
___________________________________________________________________
Name: svn:keywords
   + Author Date Id Revision
Name: svn:eol-style
   + LF


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

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