PACK_IS_LITTLE_ENDIAN = "\x01\00".unpack('S')[0] == 0x01 def assert_pack tmpl, packed, unpacked t = tmpl.inspect assert "assert_pack" do assert_equal packed, unpacked.pack(tmpl), "#{unpacked.inspect}.pack(#{t})" assert_equal unpacked, packed.unpack(tmpl), "#{packed.inspect}.unpack(#{t})" end end # pack & unpack 'm' (base64) assert('[""].pack("m")') do assert_pack "m", "", [""] end assert('["\0"].pack("m")') do assert_pack "m", "AA==\n", ["\0"] end assert('["\0\0"].pack("m")') do assert_pack "m", "AAA=\n", ["\0\0"] end assert('["\0\0\0"].pack("m")') do assert_pack "m", "AAAA\n", ["\0\0\0"] end assert('["abc..xyzABC..XYZ"].pack("m")') do assert_pack "m", "YWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXpBQkNERUZHSElKS0xNTk9QUVJT\nVFVWV1hZWg==\n", ["abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"] end assert('"YWJ...".unpack("m") should "abc..xyzABC..XYZ"') do ary = ["abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"] assert_equal ary, "YWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXpBQkNERUZHSElKS0xNTk9QUVJT\nVFVWV1hZWg==\n".unpack("m") assert_equal ary, "YWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXpBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWg==\n".unpack("m") end assert('["A", "B"].pack') do assert_equal "QQ==\n", ["A", "B"].pack("m50") assert_equal ["A"], "QQ==\n".unpack("m50") assert_equal "QQ==Qg==", ["A", "B"].pack("m0 m0") assert_equal ["A", "B"], "QQ==Qg==".unpack("m10 m10") end assert('["abc..xyzABC..XYZ"].pack("m0")') do assert_pack "m0", "YWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXpBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWg==", ["abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"] end # pack & unpack 'H' assert('["3031"].pack("H*")') do assert_pack "H*", "01", ["3031"] end assert('["10"].pack("H*")') do assert_pack "H*", "\020", ["10"] end assert('[0,1,127,128,255].pack("C*")') do assert_pack "C*", "\x00\x01\x7F\x80\xFF", [0, 1, 127, 128, 255] end # pack "a" assert('["abc"].pack("a")') do assert_equal "a", ["abc"].pack("a") assert_equal "abc", ["abc"].pack("a*") assert_equal "abc\0", ["abc"].pack("a4") end # upack "a" assert('["abc"].pack("a")') do assert_equal ["abc\0"], "abc\0".unpack("a4") assert_equal ["abc "], "abc ".unpack("a4") end # pack "A" assert('["abc"].pack("A")') do assert_equal "a", ["abc"].pack("A") assert_equal "abc", ["abc"].pack("A*") assert_equal "abc ", ["abc"].pack("A4") end # upack "A" assert('["abc"].pack("A")') do assert_equal ["abc"], "abc\0".unpack("A4") assert_equal ["abc"], "abc ".unpack("A4") end # regression tests assert('issue #1') do assert_equal "\000\001\000\002", [1, 2].pack("nn") end assert 'pack float' do assert_pack 'e', "\x00\x00@@", [3.0] assert_pack 'g', "@@\x00\x00", [3.0] if PACK_IS_LITTLE_ENDIAN assert_pack 'f', "\x00\x00@@", [3.0] assert_pack 'F', "\x00\x00@@", [3.0] else assert_pack 'f', "@@\x00\x00", [3.0] assert_pack 'F', "@@\x00\x00", [3.0] end end assert 'pack double' do assert_pack 'E', "\x00\x00\x00\x00\x00\x00\b@", [3.0] assert_pack 'G', "@\b\x00\x00\x00\x00\x00\x00", [3.0] if PACK_IS_LITTLE_ENDIAN assert_pack 'd', "\x00\x00\x00\x00\x00\x00\b@", [3.0] assert_pack 'D', "\x00\x00\x00\x00\x00\x00\b@", [3.0] else assert_pack 'd', "@\b\x00\x00\x00\x00\x00\x00", [3.0] assert_pack 'D', "@\b\x00\x00\x00\x00\x00\x00", [3.0] end end assert 'pack/unpack "i"' do int_size = [0].pack('i').size raise "pack('i').size is too small (#{int_size})" if int_size < 2 if PACK_IS_LITTLE_ENDIAN str = "\xC7\xCF" + "\xFF" * (int_size-2) else str = "\xFF" * (int_size-2) + "\xCF\xC7" end assert_pack 'i', str, [-12345] end assert 'pack/unpack "I"' do uint_size = [0].pack('I').size raise "pack('I').size is too small (#{uint_size})" if uint_size < 2 if PACK_IS_LITTLE_ENDIAN str = "\x39\x30" + "\0" * (uint_size-2) else str = "\0" * (uint_size-2) + "\x30\x39" end assert_pack 'I', str, [12345] end assert 'pack/unpack "U"' do assert_equal [], "".unpack("U") assert_equal [], "".unpack("U*") assert_equal [65, 66], "ABC".unpack("U2") assert_equal [12371, 12435, 12395, 12385, 12399, 19990, 30028], "こんにちは世界".unpack("U*") assert_equal "", [].pack("U") assert_equal "", [].pack("U*") assert_equal "AB", [65, 66, 67].pack("U2") assert_equal "こんにちは世界", [12371, 12435, 12395, 12385, 12399, 19990, 30028].pack("U*") assert_equal "\000", [0].pack("U") assert_raise(RangeError) { [-0x40000000].pack("U") } assert_raise(RangeError) { [-1].pack("U") } assert_raise(RangeError) { [0x40000000].pack("U") } end