~ isn't valid in VMS filenames
[p5sagit/p5-mst-13.2.git] / t / op / pack.t
CommitLineData
a687059c 1#!./perl
2
a1a0e61e 3BEGIN {
4 chdir 't' if -d 't';
93430cb4 5 unshift @INC, '../lib' if -d '../lib';
a1a0e61e 6 require Config; import Config;
7}
8
d99ad34e 9print "1..142\n";
a687059c 10
bbdab043 11$format = "c2 x5 C C x s d i l a6";
450a55e4 12# Need the expression in here to force ary[5] to be numeric. This avoids
13# test2 failing because ary2 goes str->numeric->str and ary doesn't.
14@ary = (1,-100,127,128,32767,987.654321098 / 100.0,12345,123456,"abcdef");
a687059c 15$foo = pack($format,@ary);
16@ary2 = unpack($format,$foo);
17
18print ($#ary == $#ary2 ? "ok 1\n" : "not ok 1\n");
19
20$out1=join(':',@ary);
21$out2=join(':',@ary2);
22print ($out1 eq $out2 ? "ok 2\n" : "not ok 2\n");
23
24print ($foo =~ /def/ ? "ok 3\n" : "not ok 3\n");
79072805 25
26# How about counting bits?
27
28print +($x = unpack("%32B*", "\001\002\004\010\020\040\100\200\377")) == 16
29 ? "ok 4\n" : "not ok 4 $x\n";
30
31print +($x = unpack("%32b69", "\001\002\004\010\020\040\100\200\017")) == 12
32 ? "ok 5\n" : "not ok 5 $x\n";
33
34print +($x = unpack("%32B69", "\001\002\004\010\020\040\100\200\017")) == 9
35 ? "ok 6\n" : "not ok 6 $x\n";
36
9d116dd7 37my $sum = 129; # ASCII
a1a0e61e 38$sum = 103 if ($Config{ebcdic} eq 'define');
9d116dd7 39
40print +($x = unpack("%32B*", "Now is the time for all good blurfl")) == $sum
79072805 41 ? "ok 7\n" : "not ok 7 $x\n";
42
b8440792 43open(BIN, "./perl") || open(BIN, "./perl.exe")
44 || die "Can't open ../perl or ../perl.exe: $!\n";
79072805 45sysread BIN, $foo, 8192;
46close BIN;
47
48$sum = unpack("%32b*", $foo);
49$longway = unpack("b*", $foo);
50print $sum == $longway =~ tr/1/1/ ? "ok 8\n" : "not ok 8\n";
73a1c01a 51
52print +($x = unpack("I",pack("I", 0xFFFFFFFF))) == 0xFFFFFFFF
53 ? "ok 9\n" : "not ok 9 $x\n";
def98dd4 54
55# check 'w'
56my $test=10;
55497cff 57my @x = (5,130,256,560,32000,3097152,268435455,1073741844,
58 '4503599627365785','23728385234614992549757750638446');
def98dd4 59my $x = pack('w*', @x);
55497cff 60my $y = pack 'H*', '0581028200843081fa0081bd8440ffffff7f848080801487ffffffffffdb19caefe8e1eeeea0c2e1e3e8ede1ee6e';
def98dd4 61
62print $x eq $y ? "ok $test\n" : "not ok $test\n"; $test++;
63
64@y = unpack('w*', $y);
55497cff 65my $a;
66while ($a = pop @x) {
67 my $b = pop @y;
68 print $a eq $b ? "ok $test\n" : "not ok $test\n$a\n$b\n"; $test++;
69}
def98dd4 70
71@y = unpack('w2', $x);
72
73print scalar(@y) == 2 ? "ok $test\n" : "not ok $test\n"; $test++;
74print $y[1] == 130 ? "ok $test\n" : "not ok $test\n"; $test++;
75
55497cff 76# test exeptions
def98dd4 77eval { $x = unpack 'w', pack 'C*', 0xff, 0xff};
78print $@ ne '' ? "ok $test\n" : "not ok $test\n"; $test++;
79
80eval { $x = unpack 'w', pack 'C*', 0xff, 0xff, 0xff, 0xff};
81print $@ ne '' ? "ok $test\n" : "not ok $test\n"; $test++;
82
83eval { $x = unpack 'w', pack 'C*', 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
84print $@ ne '' ? "ok $test\n" : "not ok $test\n"; $test++;
85
84902520 86#
87# test the "p" template
88
89# literals
90print((unpack("p",pack("p","foo")) eq "foo" ? "ok " : "not ok "),$test++,"\n");
91
92# scalars
93print((unpack("p",pack("p",$test)) == $test ? "ok " : "not ok "),$test++,"\n");
94
95# temps
96sub foo { my $a = "a"; return $a . $a++ . $a++ }
97{
98 local $^W = 1;
99 my $last = $test;
100 local $SIG{__WARN__} = sub {
101 print "ok ",$test++,"\n" if $_[0] =~ /temporary val/
102 };
103 my $junk = pack("p", &foo);
104 print "not ok ", $test++, "\n" if $last == $test;
105}
106
107# undef should give null pointer
108print((pack("p", undef) =~ /^\0+/ ? "ok " : "not ok "),$test++,"\n");
109
20408e3c 110# Check for optimizer bug (e.g. Digital Unix GEM cc with -O4 on DU V4.0B gives
111# 4294967295 instead of -1)
112# see #ifdef __osf__ in pp.c pp_unpack
113# Test 30:
114print( ((unpack("i",pack("i",-1))) == -1 ? "ok " : "not ok "),$test++,"\n");
115
d4217c7e 116# 31..36: test the pack lengths of s S i I l L
117print "not " unless length(pack("s", 0)) == 2;
118print "ok ", $test++, "\n";
119
120print "not " unless length(pack("S", 0)) == 2;
121print "ok ", $test++, "\n";
122
123print "not " unless length(pack("i", 0)) >= 4;
124print "ok ", $test++, "\n";
125
126print "not " unless length(pack("I", 0)) >= 4;
127print "ok ", $test++, "\n";
128
129print "not " unless length(pack("l", 0)) == 4;
130print "ok ", $test++, "\n";
131
132print "not " unless length(pack("L", 0)) == 4;
133print "ok ", $test++, "\n";
134
135# 37..40: test the pack lengths of n N v V
136
137print "not " unless length(pack("n", 0)) == 2;
138print "ok ", $test++, "\n";
139
140print "not " unless length(pack("N", 0)) == 4;
141print "ok ", $test++, "\n";
142
143print "not " unless length(pack("v", 0)) == 2;
144print "ok ", $test++, "\n";
145
146print "not " unless length(pack("V", 0)) == 4;
147print "ok ", $test++, "\n";
148
149# 41..56: test unpack-pack lengths
150
151my @templates = qw(c C i I s S l L n N v V f d);
152
153# quads not supported everywhere: if not, retest floats/doubles
154# to preserve the test count...
155eval { my $q = pack("q",0) };
156push @templates, $@ !~ /Invalid type in pack/ ? qw(q Q) : qw(f d);
157
158foreach my $t (@templates) {
159 my @t = unpack("$t*", pack("$t*", 12, 34));
160 print "not "
161 unless @t == 2 and (($t[0] == 12 and $t[1] == 34) or ($t =~ /[nv]/i));
162 print "ok ", $test++, "\n";
163}
9d116dd7 164
eddc390b 165# 57..60: uuencode/decode
9d116dd7 166
ef54e1a4 167# Note that first uuencoding known 'text' data and then checking the
168# binary values of the uuencoded version would not be portable between
169# character sets. Uuencoding is meant for encoding binary data, not
170# text data.
171
342930fb 172$in = pack 'C*', 0 .. 255;
ba1ac976 173
174# just to be anal, we do some random tr/`/ /
9d116dd7 175$uu = <<'EOUU';
ba1ac976 176M` $"`P0%!@<("0H+# T.#Q`1$A,4%187&!D:&QP='A\@(2(C)"4F)R@I*BLL
9d116dd7 177M+2XO,#$R,S0U-C<X.3H[/#T^/T!!0D-$149'2$E*2TQ-3D]045)35%565UA9
178M6EM<75Y?8&%B8V1E9F=H:6IK;&UN;W!Q<G-T=79W>'EZ>WQ]?G^`@8*#A(6&
179MAXB)BHN,C8Z/D)&2DY25EI>8F9J;G)V>GZ"AHJ.DI::GJ*FJJZRMKJ^PL;*S
180MM+6VM[BYNKN\O;Z_P,'"P\3%QL?(R<K+S,W.S]#1TM/4U=;7V-G:V]S=WM_@
ba1ac976 181?X>+CY.7FY^CIZNOL[>[O\/'R\_3U]O?X^?K[_/W^_P `
9d116dd7 182EOUU
183
ba1ac976 184$_ = $uu;
185tr/ /`/;
186print "not " unless pack('u', $in) eq $_;
9d116dd7 187print "ok ", $test++, "\n";
188
189print "not " unless unpack('u', $uu) eq $in;
190print "ok ", $test++, "\n";
191
eddc390b 192$in = "\x1f\x8b\x08\x08\x58\xdc\xc4\x35\x02\x03\x4a\x41\x50\x55\x00\xf3\x2a\x2d\x2e\x51\x48\xcc\xcb\x2f\xc9\x48\x2d\x52\x08\x48\x2d\xca\x51\x28\x2d\x4d\xce\x4f\x49\x2d\xe2\x02\x00\x64\x66\x60\x5c\x1a\x00\x00\x00";
193$uu = <<'EOUU';
194M'XL("%C<Q#4"`TI!4%4`\RHM+E%(S,LOR4@M4@A(+<I1*"U-SD])+>("`&1F
195&8%P:````
196EOUU
197
198print "not " unless unpack('u', $uu) eq $in;
199print "ok ", $test++, "\n";
200
201# 60 identical to 59 except that backquotes have been changed to spaces
202
203$uu = <<'EOUU';
204M'XL("%C<Q#4" TI!4%4 \RHM+E%(S,LOR4@M4@A(+<I1*"U-SD])+>(" &1F
205&8%P:
206EOUU
207
208print "not " unless unpack('u', $uu) eq $in;
209print "ok ", $test++, "\n";
210
ef54e1a4 211# 61..72: test the ascii template types (A, a, Z)
5a929a98 212
213print "not " unless pack('A*', "foo\0bar\0 ") eq "foo\0bar\0 ";
214print "ok ", $test++, "\n";
215
216print "not " unless pack('A11', "foo\0bar\0 ") eq "foo\0bar\0 ";
217print "ok ", $test++, "\n";
218
219print "not " unless unpack('A*', "foo\0bar \0") eq "foo\0bar";
220print "ok ", $test++, "\n";
221
222print "not " unless unpack('A8', "foo\0bar \0") eq "foo\0bar";
223print "ok ", $test++, "\n";
224
225print "not " unless pack('a*', "foo\0bar\0 ") eq "foo\0bar\0 ";
226print "ok ", $test++, "\n";
227
228print "not " unless pack('a11', "foo\0bar\0 ") eq "foo\0bar\0 \0\0";
229print "ok ", $test++, "\n";
230
231print "not " unless unpack('a*', "foo\0bar \0") eq "foo\0bar \0";
232print "ok ", $test++, "\n";
233
234print "not " unless unpack('a8', "foo\0bar \0") eq "foo\0bar ";
235print "ok ", $test++, "\n";
236
237print "not " unless pack('Z*', "foo\0bar\0 ") eq "foo\0bar\0 ";
238print "ok ", $test++, "\n";
239
240print "not " unless pack('Z11', "foo\0bar\0 ") eq "foo\0bar\0 \0\0";
241print "ok ", $test++, "\n";
242
243print "not " unless unpack('Z*', "foo\0bar \0") eq "foo";
244print "ok ", $test++, "\n";
245
246print "not " unless unpack('Z8', "foo\0bar \0") eq "foo";
247print "ok ", $test++, "\n";
248
726ea183 249# 73..78: packing native shorts/ints/longs
ef54e1a4 250
f61d411c 251print "not " unless length(pack("s!", 0)) == $Config{shortsize};
ef54e1a4 252print "ok ", $test++, "\n";
253
f61d411c 254print "not " unless length(pack("i!", 0)) == $Config{intsize};
ef54e1a4 255print "ok ", $test++, "\n";
256
f61d411c 257print "not " unless length(pack("l!", 0)) == $Config{longsize};
ef54e1a4 258print "ok ", $test++, "\n";
259
f61d411c 260print "not " unless length(pack("s!", 0)) <= length(pack("i!", 0));
ef54e1a4 261print "ok ", $test++, "\n";
262
f61d411c 263print "not " unless length(pack("i!", 0)) <= length(pack("l!", 0));
ef54e1a4 264print "ok ", $test++, "\n";
265
f61d411c 266print "not " unless length(pack("i!", 0)) == length(pack("i", 0));
ef54e1a4 267print "ok ", $test++, "\n";
268
d99ad34e 269# 79..138: pack <-> unpack bijectionism
726ea183 270
d99ad34e 271# 79.. 83 c
272foreach my $c (-128, -1, 0, 1, 127) {
273 print "not " unless unpack("c", pack("c", $c)) == $c;
274 print "ok ", $test++, "\n";
275}
9de70c85 276
d99ad34e 277# 84.. 88: C
278foreach my $C (0, 1, 127, 128, 255) {
279 print "not " unless unpack("C", pack("C", $C)) == $C;
280 print "ok ", $test++, "\n";
281}
726ea183 282
d99ad34e 283# 89.. 93: s
284foreach my $s (-32768, -1, 0, 1, 32767) {
285 print "not " unless unpack("s", pack("s", $s)) == $s;
286 print "ok ", $test++, "\n";
287}
726ea183 288
d99ad34e 289# 94.. 98: S
290foreach my $S (0, 1, 32767, 32768, 65535) {
291 print "not " unless unpack("S", pack("S", $S)) == $S;
292 print "ok ", $test++, "\n";
293}
726ea183 294
d99ad34e 295# 99..103: i
296foreach my $i (-2147483648, -1, 0, 1, 2147483647) {
297 print "not " unless unpack("i", pack("i", $i)) == $i;
298 print "ok ", $test++, "\n";
299}
726ea183 300
d99ad34e 301# 104..108: I
302foreach my $I (0, 1, 2147483647, 2147483648, 4294967295) {
303 print "not " unless unpack("I", pack("I", $I)) == $I;
304 print "ok ", $test++, "\n";
305}
726ea183 306
d99ad34e 307# 109..113: l
308foreach my $l (-2147483648, -1, 0, 1, 2147483647) {
309 print "not " unless unpack("l", pack("l", $l)) == $l;
310 print "ok ", $test++, "\n";
311}
726ea183 312
d99ad34e 313# 114..118: L
314foreach my $L (0, 1, 2147483647, 2147483648, 4294967295) {
315 print "not " unless unpack("L", pack("L", $L)) == $L;
316 print "ok ", $test++, "\n";
317}
726ea183 318
d99ad34e 319# 119..123: n
320foreach my $n (0, 1, 32767, 32768, 65535) {
321 print "not " unless unpack("n", pack("n", $n)) == $n;
322 print "ok ", $test++, "\n";
323}
726ea183 324
d99ad34e 325# 124..128: v
326foreach my $v (0, 1, 32767, 32768, 65535) {
327 print "not " unless unpack("v", pack("v", $v)) == $v;
328 print "ok ", $test++, "\n";
329}
726ea183 330
d99ad34e 331# 129..133: N
332foreach my $N (0, 1, 2147483647, 2147483648, 4294967295) {
333 print "not " unless unpack("N", pack("N", $N)) == $N;
334 print "ok ", $test++, "\n";
335}
726ea183 336
d99ad34e 337# 134..138: V
338foreach my $V (0, 1, 2147483647, 2147483648, 4294967295) {
339 print "not " unless unpack("V", pack("V", $V)) == $V;
340 print "ok ", $test++, "\n";
341}
726ea183 342
d99ad34e 343# 139..142: pack nvNV byteorders
726ea183 344
d99ad34e 345print "not " unless pack("n", 0xdead) eq "\xde\xad";
726ea183 346print "ok ", $test++, "\n";
347
d99ad34e 348print "not " unless pack("v", 0xdead) eq "\xad\xde";
c67712b2 349print "ok ", $test++, "\n";
726ea183 350
d99ad34e 351print "not " unless pack("N", 0xdeadbeef) eq "\xde\xad\xbe\xef";
726ea183 352print "ok ", $test++, "\n";
353
d99ad34e 354print "not " unless pack("V", 0xdeadbeef) eq "\xef\xbe\xad\xde";
c67712b2 355print "ok ", $test++, "\n";