This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
update -Dx to cope with lexical version of OP_AELEMFAST
[perl5.git] / t / op / gv.t
1 #!./perl
2
3 #
4 # various typeglob tests
5 #
6
7 BEGIN {
8     chdir 't' if -d 't';
9     @INC = '../lib';
10 }   
11
12 use warnings;
13
14 print "1..53\n";
15
16 # type coersion on assignment
17 $foo = 'foo';
18 $bar = *main::foo;
19 $bar = $foo;
20 print ref(\$bar) eq 'SCALAR' ? "ok 1\n" : "not ok 1\n";
21 $foo = *main::bar;
22
23 # type coersion (not) on misc ops
24
25 if ($foo) {
26   print ref(\$foo) eq 'GLOB' ? "ok 2\n" : "not ok 2\n";
27 }
28
29 unless ($foo =~ /abcd/) {
30   print ref(\$foo) eq 'GLOB' ? "ok 3\n" : "not ok 3\n";
31 }
32
33 if ($foo eq '*main::bar') {
34   print ref(\$foo) eq 'GLOB' ? "ok 4\n" : "not ok 4\n";
35 }
36
37 # type coersion on substitutions that match
38 $a = *main::foo;
39 $b = $a;
40 $a =~ s/^X//;
41 print ref(\$a) eq 'GLOB' ? "ok 5\n" : "not ok 5\n";
42 $a =~ s/^\*//;
43 print $a eq 'main::foo' ? "ok 6\n" : "not ok 6\n";
44 print ref(\$b) eq 'GLOB' ? "ok 7\n" : "not ok 7\n";
45
46 # typeglobs as lvalues
47 substr($foo, 0, 1) = "XXX";
48 print ref(\$foo) eq 'SCALAR' ? "ok 8\n" : "not ok 8\n";
49 print $foo eq 'XXXmain::bar' ? "ok 9\n" : "not ok 9\n";
50
51 # returning glob values
52 sub foo {
53   local($bar) = *main::foo;
54   $foo = *main::bar;
55   return ($foo, $bar);
56 }
57
58 ($fuu, $baa) = foo();
59 if (defined $fuu) {
60   print ref(\$fuu) eq 'GLOB' ? "ok 10\n" : "not ok 10\n";
61 }
62
63 if (defined $baa) {
64   print ref(\$baa) eq 'GLOB' ? "ok 11\n" : "not ok 11\n";
65 }
66
67 # nested package globs
68 # NOTE:  It's probably OK if these semantics change, because the
69 #        fact that %X::Y:: is stored in %X:: isn't documented.
70 #        (I hope.)
71
72 { package Foo::Bar; no warnings 'once'; $test=1; }
73 print exists $Foo::{'Bar::'} ? "ok 12\n" : "not ok 12\n";
74 print $Foo::{'Bar::'} eq '*Foo::Bar::' ? "ok 13\n" : "not ok 13\n";
75
76 # test undef operator clearing out entire glob
77 $foo = 'stuff';
78 @foo = qw(more stuff);
79 %foo = qw(even more random stuff);
80 undef *foo;
81 print +($foo || @foo || %foo) ? "not ok" : "ok", " 14\n";
82
83 # test warnings from assignment of undef to glob
84 {
85     my $msg;
86     local $SIG{__WARN__} = sub { $msg = $_[0] };
87     use warnings;
88     *foo = 'bar';
89     print $msg ? "not ok" : "ok", " 15\n";
90     *foo = undef;
91     print $msg ? "ok" : "not ok", " 16\n";
92 }
93
94 # test *glob{THING} syntax
95 $x = "ok 17\n";
96 @x = ("ok 18\n");
97 %x = ("ok 19" => "\n");
98 sub x { "ok 20\n" }
99 print ${*x{SCALAR}}, @{*x{ARRAY}}, %{*x{HASH}}, &{*x{CODE}};
100 format x =
101 ok 21
102 .
103 print ref *x{FORMAT} eq "FORMAT" ? "ok 21\n" : "not ok 21\n";
104 *x = *STDOUT;
105 print *{*x{GLOB}} eq "*main::STDOUT" ? "ok 22\n" : "not ok 22\n";
106 print {*x{IO}} "ok 23\n";
107
108 {
109         my $warn;
110         local $SIG{__WARN__} = sub {
111                 $warn .= $_[0];
112         };
113         my $val = *x{FILEHANDLE};
114         print {*x{IO}} ($warn =~ /is deprecated/ ? "ok 24\n" : "not ok 24\n");
115         
116 }
117
118 # test if defined() doesn't create any new symbols
119
120 {
121     my $test = 24;
122
123     my $a = "SYM000";
124     print "not " if defined *{$a};
125     ++$test; print "ok $test\n";
126
127     print "not " if defined @{$a} or defined *{$a};
128     ++$test; print "ok $test\n";
129
130     print "not " if defined %{$a} or defined *{$a};
131     ++$test; print "ok $test\n";
132
133     print "not " if defined ${$a} or defined *{$a};
134     ++$test; print "ok $test\n";
135
136     print "not " if defined &{$a} or defined *{$a};
137     ++$test; print "ok $test\n";
138
139     *{$a} = sub { print "ok $test\n" };
140     print "not " unless defined &{$a} and defined *{$a};
141     ++$test; &{$a};
142 }
143
144 # although it *should* if you're talking about magicals
145
146 {
147     my $test = 30;
148
149     my $a = "]";
150     print "not " unless defined ${$a};
151     ++$test; print "ok $test\n";
152     print "not " unless defined *{$a};
153     ++$test; print "ok $test\n";
154
155     $a = "1";
156     "o" =~ /(o)/;
157     print "not " unless ${$a};
158     ++$test; print "ok $test\n";
159     print "not " unless defined *{$a};
160     ++$test; print "ok $test\n";
161     $a = "2";
162     print "not " if ${$a};
163     ++$test; print "ok $test\n";
164     print "not " unless defined *{$a};
165     ++$test; print "ok $test\n";
166     $a = "1x";
167     print "not " if defined ${$a};
168     ++$test; print "ok $test\n";
169     print "not " if defined *{$a};
170     ++$test; print "ok $test\n";
171     $a = "11";
172     "o" =~ /(((((((((((o)))))))))))/;
173     print "not " unless ${$a};
174     ++$test; print "ok $test\n";
175     print "not " unless defined *{$a};
176     ++$test; print "ok $test\n";
177 }
178
179
180 # [ID 20010526.001] localized glob loses value when assigned to
181
182 $j=1; %j=(a=>1); @j=(1); local *j=*j; *j = sub{};
183
184 print $j    == 1 ? "ok 41\n"  : "not ok 41\n";
185 print $j{a} == 1 ? "ok 42\n"  : "not ok 42\n";
186 print $j[0] == 1 ? "ok 43\n" : "not ok 43\n";
187
188 # does pp_readline() handle glob-ness correctly?
189
190 {
191     my $g = *foo;
192     $g = <DATA>;
193     print $g;
194 }
195
196 {
197     my $w = '';
198     $SIG{__WARN__} = sub { $w = $_[0] };
199     sub abc1 ();
200     local *abc1 = sub { };
201     print $w eq '' ? "ok 45\n" : "not ok 45\n# $w";
202     sub abc2 ();
203     local *abc2;
204     *abc2 = sub { };
205     print $w eq '' ? "ok 46\n" : "not ok 46\n# $w";
206     sub abc3 ();
207     *abc3 = sub { };
208     print $w =~ /Prototype mismatch/ ? "ok 47\n" : "not ok 47\n# $w";
209 }
210
211 {
212     # [17375] rcatline to formerly-defined undef was broken. Fixed in
213     # do_readline by checking SvOK. AMS, 20020918
214     my $x = "not ";
215     $x  = undef;
216     $x .= <DATA>;
217     print $x;
218 }
219
220 {
221     # test the assignment of a GLOB to an LVALUE
222     my $e = '';
223     local $SIG{__DIE__} = sub { $e = $_[0] };
224     my $v;
225     sub f { $_[0] = 0; $_[0] = "a"; $_[0] = *DATA }
226     f($v);
227     print $v eq '*main::DATA' ? "ok 49\n" : "not ok 49\n# $e";
228     my $x = <$v>;
229     print $x || "not ok 50\n";
230 }
231
232 {   
233     # GLOB assignment to tied element
234     local $SIG{__DIE__} = sub { $e = $_[0] };
235     sub T::TIEARRAY { bless [] => "T" }
236     sub T::STORE    { $_[0]->[ $_[1] ] = $_[2] }
237     sub T::FETCH    { $_[0]->[ $_[1] ] }
238     tie my @ary => "T";
239     $ary[0] = *DATA;
240     print $ary[0] eq '*main::DATA' ? "ok 51\n" : "not ok 51\n# $e";
241     my $x = readline $ary[0];
242     print $x || "not ok 52\n";
243 }
244
245 # stringified typeglob should escape leading control char
246 print *^A eq "*main::^A" ? "ok 53\n" : "not ok 53\n";
247
248 __END__
249 ok 44
250 ok 48
251 ok 50
252 ok 52