1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
|
#!./perl
use strict;
use warnings;
BEGIN {
chdir 't' if -d 't';
@INC = '../lib';
}
use Test::More tests => 31;
BEGIN { $_ = 'foo'; } # because Symbol used to clobber $_
use Symbol;
ok( $_ eq 'foo', 'check $_ clobbering' );
# First test gensym()
my $sym1 = gensym;
ok( ref($sym1) eq 'GLOB', 'gensym() returns a GLOB' );
my $sym2 = gensym;
ok( $sym1 ne $sym2, 'gensym() returns a different GLOB' );
ungensym $sym1;
$sym1 = $sym2 = undef;
# Test geniosym()
use Symbol qw(geniosym);
$sym1 = geniosym;
like( $sym1, qr/=IO\(/, 'got an IO ref' );
our $FOO = 'Eymascalar';
*FOO = $sym1;
is( $sym1, *FOO{IO}, 'assigns into glob OK' );
is( $FOO, 'Eymascalar', 'leaves scalar alone' );
{
local $^W=1; # 5.005 compat.
my $warn;
local $SIG{__WARN__} = sub { $warn .= "@_" };
readline FOO;
like( $warn, qr/unopened filehandle/, 'warns like an unopened filehandle' );
}
# Test qualify()
package foo;
use Symbol qw(qualify qualify_to_ref); # must import into this package too
::ok( qualify("x") eq "foo::x", 'qualify() with a simple identifier' );
::ok( qualify("x", "FOO") eq "FOO::x", 'qualify() with a package' );
::ok( qualify("BAR::x") eq "BAR::x",
'qualify() with a qualified identifier' );
::ok( qualify("STDOUT") eq "main::STDOUT",
'qualify() with a reserved identifier' );
::ok( qualify("ARGV", "FOO") eq "main::ARGV",
'qualify() with a reserved identifier and a package' );
::ok( qualify("_foo") eq "foo::_foo",
'qualify() with an identifier starting with a _' );
::ok( qualify("^FOO") eq "main::\cFOO",
'qualify() with an identifier starting with a ^' );
::is( qualify('\*x'), 'foo::\*x',
'qualify() reference to a typeglob' );
::is( qualify('\*x', 'FOO'), 'FOO::\*x',
'qualify() reference to a typeglob' );
{
use strict 'refs';
my $fhref = qualify_to_ref("main::STDOUT");
::is( ref($fhref), 'GLOB',
'qualify_to_ref() returned ref to typeglob (1 argument)');
my $key = 'baz';
my $ref_to_key = qualify_to_ref( $key, __PACKAGE__ );
::is( ref($ref_to_key), 'GLOB',
'qualify_to_ref() returned ref to typeglob (2 arguments)');
my $ref_to_key_scalar = *{$ref_to_key}{SCALAR};
::is( ref($ref_to_key_scalar), 'SCALAR',
'able to get SCALAR entry in typeglob');
}
# tests for delete_package
package main;
no warnings 'once';
$Transient::variable = 42;
ok( exists $::{'Transient::'}, 'transient stash exists' );
ok( defined $Transient::{variable}, 'transient variable in stash' );
Symbol::delete_package('Transient');
ok( !exists $Transient::{variable}, 'transient variable no longer in stash' );
is( scalar(keys %Transient::), 0, 'transient stash is empty' );
ok( !exists $::{'Transient::'}, 'no transient stash' );
$Foo::variable = 43;
ok( exists $::{'Foo::'}, 'second transient stash exists' );
ok( defined $Foo::{variable}, 'second transient variable in stash' );
Symbol::delete_package('::Foo');
is( scalar(keys %Foo::), 0, 'second transient stash is empty' );
ok( !exists $::{'Foo::'}, 'no second transient stash' );
$Bar::variable = 44;
ok( exists $::{'Bar::'}, 'third transient stash exists' );
ok( defined $Bar::{variable}, 'third transient variable in stash' );
ok( ! defined(Symbol::delete_package('Bar::Bar::')),
'delete_package() returns undef due to undefined leaf');
|