summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authoryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-12 14:53:16 +0000
committeryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-12 14:53:16 +0000
commit520f724895ac15f410e9b4c0bf86eef33f91b26c (patch)
treefdb898962871717b948f67d7e58bfc42bbc507bd
parent87f30b70a623dc2c8b31d03c32299d6a46e3946e (diff)
merges r20564 from trunk into ruby_1_9_1.
* pack.c (pack_pack): 'u0' is not special differently from 'm0'. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_1@20669 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog4
-rw-r--r--pack.c2
-rw-r--r--test/ruby/test_pack.rb4
3 files changed, 9 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 2bfe34b857..c713d3a78a 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+Sat Dec 6 17:51:35 2008 Yuki Sonoda (Yugui) <yugui@yugui.jp>
+
+ * pack.c (pack_pack): 'u0' is not special differently from 'm0'.
+
Tue Dec 9 11:50:46 2008 Yuki Sonoda (Yugui) <yugui@yugui.jp>
* pack.c (pack_pck): fixed [ruby-dev:37295].
diff --git a/pack.c b/pack.c
index 119a83b1ae..ae0218afce 100644
--- a/pack.c
+++ b/pack.c
@@ -903,7 +903,7 @@ pack_pack(VALUE ary, VALUE fmt)
ptr = RSTRING_PTR(from);
plen = RSTRING_LEN(from);
- if (len == 0) {
+ if (len == 0 && type == 'm') {
encodes(res, ptr, plen, type, 0);
ptr += plen;
break;
diff --git a/test/ruby/test_pack.rb b/test/ruby/test_pack.rb
index 2666bb0e90..33694b9f38 100644
--- a/test/ruby/test_pack.rb
+++ b/test/ruby/test_pack.rb
@@ -349,6 +349,10 @@ class TestPack < Test::Unit::TestCase
assert_equal("M86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A\n!80``\n", ["a"*46].pack("u"))
assert_equal("&86)C9&5F\n#9VAI\n", ["abcdefghi"].pack("u6"))
+ assert_equal("M86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A\n!80``\n", ["a"*46].pack("u0"))
+ assert_equal("M86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A\n!80``\n", ["a"*46].pack("u1"))
+ assert_equal("M86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A86%A\n!80``\n", ["a"*46].pack("u2"))
+
assert_equal([""], "".unpack("u"))
assert_equal(["a"], "!80``\n".unpack("u"))
assert_equal(["abc"], "#86)C\n".unpack("u"))