xref: /onnv-gate/usr/src/cmd/perl/5.8.4/distrib/t/op/gv.t (revision 0:68f95e015346)
1#!./perl
2
3#
4# various typeglob tests
5#
6
7BEGIN {
8    chdir 't' if -d 't';
9    @INC = '../lib';
10}
11
12use warnings;
13
14print "1..48\n";
15
16# type coersion on assignment
17$foo = 'foo';
18$bar = *main::foo;
19$bar = $foo;
20print ref(\$bar) eq 'SCALAR' ? "ok 1\n" : "not ok 1\n";
21$foo = *main::bar;
22
23# type coersion (not) on misc ops
24
25if ($foo) {
26  print ref(\$foo) eq 'GLOB' ? "ok 2\n" : "not ok 2\n";
27}
28
29unless ($foo =~ /abcd/) {
30  print ref(\$foo) eq 'GLOB' ? "ok 3\n" : "not ok 3\n";
31}
32
33if ($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//;
41print ref(\$a) eq 'GLOB' ? "ok 5\n" : "not ok 5\n";
42$a =~ s/^\*//;
43print $a eq 'main::foo' ? "ok 6\n" : "not ok 6\n";
44print ref(\$b) eq 'GLOB' ? "ok 7\n" : "not ok 7\n";
45
46# typeglobs as lvalues
47substr($foo, 0, 1) = "XXX";
48print ref(\$foo) eq 'SCALAR' ? "ok 8\n" : "not ok 8\n";
49print $foo eq 'XXXmain::bar' ? "ok 9\n" : "not ok 9\n";
50
51# returning glob values
52sub foo {
53  local($bar) = *main::foo;
54  $foo = *main::bar;
55  return ($foo, $bar);
56}
57
58($fuu, $baa) = foo();
59if (defined $fuu) {
60  print ref(\$fuu) eq 'GLOB' ? "ok 10\n" : "not ok 10\n";
61}
62
63if (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; }
73print exists $Foo::{'Bar::'} ? "ok 12\n" : "not ok 12\n";
74print $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);
80undef *foo;
81print +($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");
98sub x { "ok 20\n" }
99print ${*x{SCALAR}}, @{*x{ARRAY}}, %{*x{HASH}}, &{*x{CODE}};
100format x =
101ok 21
102.
103print ref *x{FORMAT} eq "FORMAT" ? "ok 21\n" : "not ok 21\n";
104*x = *STDOUT;
105print *{*x{GLOB}} eq "*main::STDOUT" ? "ok 22\n" : "not ok 22\n";
106print {*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
184print $j    == 1 ? "ok 41\n"  : "not ok 41\n";
185print $j{a} == 1 ? "ok 42\n"  : "not ok 42\n";
186print $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__END__
221ok 44
222ok 48
223