golden hour
/usr/share/perl/5.30.0
⬆️ Go Up
Upload
File/Folder
Size
Actions
AnyDBM_File.pm
2.56 KB
Del
OK
App
-
Del
OK
Archive
-
Del
OK
Attribute
-
Del
OK
AutoLoader.pm
15.43 KB
Del
OK
AutoSplit.pm
19.18 KB
Del
OK
B
-
Del
OK
Benchmark.pm
30.3 KB
Del
OK
CORE.pod
3.11 KB
Del
OK
CPAN
-
Del
OK
CPAN.pm
138.75 KB
Del
OK
Carp
-
Del
OK
Carp.pm
35.12 KB
Del
OK
Class
-
Del
OK
Compress
-
Del
OK
Config
-
Del
OK
DB.pm
18.48 KB
Del
OK
DBM_Filter
-
Del
OK
DBM_Filter.pm
14.05 KB
Del
OK
Devel
-
Del
OK
Digest
-
Del
OK
Digest.pm
10.45 KB
Del
OK
DirHandle.pm
2.04 KB
Del
OK
Dumpvalue.pm
17.14 KB
Del
OK
Encode
-
Del
OK
English.pm
4.65 KB
Del
OK
Env.pm
5.39 KB
Del
OK
Exporter
-
Del
OK
Exporter.pm
18.36 KB
Del
OK
ExtUtils
-
Del
OK
Fatal.pm
56.91 KB
Del
OK
File
-
Del
OK
FileCache.pm
5.42 KB
Del
OK
FileHandle.pm
6.63 KB
Del
OK
Filter
-
Del
OK
FindBin.pm
4.45 KB
Del
OK
Getopt
-
Del
OK
HTTP
-
Del
OK
I18N
-
Del
OK
IO
-
Del
OK
IPC
-
Del
OK
Internals.pod
2.51 KB
Del
OK
JSON
-
Del
OK
Locale
-
Del
OK
Math
-
Del
OK
Memoize
-
Del
OK
Memoize.pm
35.34 KB
Del
OK
Module
-
Del
OK
NEXT.pm
18.54 KB
Del
OK
Net
-
Del
OK
Params
-
Del
OK
Parse
-
Del
OK
Perl
-
Del
OK
PerlIO
-
Del
OK
PerlIO.pm
10.21 KB
Del
OK
Pod
-
Del
OK
Safe.pm
24.49 KB
Del
OK
Search
-
Del
OK
SelectSaver.pm
1.05 KB
Del
OK
SelfLoader.pm
17.27 KB
Del
OK
Symbol.pm
4.69 KB
Del
OK
TAP
-
Del
OK
Term
-
Del
OK
Test
-
Del
OK
Test.pm
29.34 KB
Del
OK
Test2
-
Del
OK
Test2.pm
6.24 KB
Del
OK
Text
-
Del
OK
Thread
-
Del
OK
Thread.pm
8.09 KB
Del
OK
Tie
-
Del
OK
Time
-
Del
OK
UNIVERSAL.pm
6.44 KB
Del
OK
Unicode
-
Del
OK
User
-
Del
OK
XSLoader.pm
10.99 KB
Del
OK
_charnames.pm
32.39 KB
Del
OK
autodie
-
Del
OK
autodie.pm
12.58 KB
Del
OK
autouse.pm
4.14 KB
Del
OK
base.pm
10.7 KB
Del
OK
bigint.pm
22.85 KB
Del
OK
bignum.pm
20.64 KB
Del
OK
bigrat.pm
15.78 KB
Del
OK
blib.pm
2.01 KB
Del
OK
bytes.pm
3.65 KB
Del
OK
bytes_heavy.pl
758 B
Del
OK
charnames.pm
20.38 KB
Del
OK
constant.pm
14.38 KB
Del
OK
deprecate.pm
5.07 KB
Del
OK
diagnostics.pm
18.59 KB
Del
OK
dumpvar.pl
15.19 KB
Del
OK
encoding
-
Del
OK
experimental.pm
6.9 KB
Del
OK
feature.pm
17.28 KB
Del
OK
fields.pm
9.25 KB
Del
OK
filetest.pm
3.91 KB
Del
OK
if.pm
3.53 KB
Del
OK
integer.pm
3.18 KB
Del
OK
less.pm
3.13 KB
Del
OK
locale.pm
4.74 KB
Del
OK
meta_notation.pm
2.07 KB
Del
OK
ok.pm
967 B
Del
OK
open.pm
7.83 KB
Del
OK
overload
-
Del
OK
overload.pm
52.04 KB
Del
OK
overloading.pm
1.77 KB
Del
OK
parent.pm
2.51 KB
Del
OK
perl5db.pl
309.69 KB
Del
OK
perlfaq.pm
77 B
Del
OK
pod
-
Del
OK
sigtrap.pm
8.53 KB
Del
OK
sort.pm
3.82 KB
Del
OK
strict.pm
4.63 KB
Del
OK
subs.pm
901 B
Del
OK
unicore
-
Del
OK
utf8.pm
10.18 KB
Del
OK
utf8_heavy.pl
26.66 KB
Del
OK
vars.pm
2.4 KB
Del
OK
version
-
Del
OK
version.pm
1.93 KB
Del
OK
version.pod
9.6 KB
Del
OK
vmsish.pm
4.21 KB
Del
OK
warnings
-
Del
OK
warnings.pm
48.82 KB
Del
OK
Edit: Symbol.pm
package Symbol; =head1 NAME Symbol - manipulate Perl symbols and their names =head1 SYNOPSIS use Symbol; $sym = gensym; open($sym, '<', "filename"); $_ = <$sym>; # etc. ungensym $sym; # no effect # replace *FOO{IO} handle but not $FOO, %FOO, etc. *FOO = geniosym; print qualify("x"), "\n"; # "main::x" print qualify("x", "FOO"), "\n"; # "FOO::x" print qualify("BAR::x"), "\n"; # "BAR::x" print qualify("BAR::x", "FOO"), "\n"; # "BAR::x" print qualify("STDOUT", "FOO"), "\n"; # "main::STDOUT" (global) print qualify(\*x), "\n"; # returns \*x print qualify(\*x, "FOO"), "\n"; # returns \*x use strict refs; print { qualify_to_ref $fh } "foo!\n"; $ref = qualify_to_ref $name, $pkg; use Symbol qw(delete_package); delete_package('Foo::Bar'); print "deleted\n" unless exists $Foo::{'Bar::'}; =head1 DESCRIPTION C<Symbol::gensym> creates an anonymous glob and returns a reference to it. Such a glob reference can be used as a file or directory handle. For backward compatibility with older implementations that didn't support anonymous globs, C<Symbol::ungensym> is also provided. But it doesn't do anything. C<Symbol::geniosym> creates an anonymous IO handle. This can be assigned into an existing glob without affecting the non-IO portions of the glob. C<Symbol::qualify> turns unqualified symbol names into qualified variable names (e.g. "myvar" -E<gt> "MyPackage::myvar"). If it is given a second parameter, C<qualify> uses it as the default package; otherwise, it uses the package of its caller. Regardless, global variable names (e.g. "STDOUT", "ENV", "SIG") are always qualified with "main::". Qualification applies only to symbol names (strings). References are left unchanged under the assumption that they are glob references, which are qualified by their nature. C<Symbol::qualify_to_ref> is just like C<Symbol::qualify> except that it returns a glob ref rather than a symbol name, so you can use the result even if C<use strict 'refs'> is in effect. C<Symbol::delete_package> wipes out a whole package namespace. Note this routine is not exported by default--you may want to import it explicitly. =head1 BUGS C<Symbol::delete_package> is a bit too powerful. It undefines every symbol that lives in the specified package. Since perl, for performance reasons, does not perform a symbol table lookup each time a function is called or a global variable is accessed, some code that has already been loaded and that makes use of symbols in package C<Foo> may stop working after you delete C<Foo>, even if you reload the C<Foo> module afterwards. =cut BEGIN { require 5.005; } require Exporter; @ISA = qw(Exporter); @EXPORT = qw(gensym ungensym qualify qualify_to_ref); @EXPORT_OK = qw(delete_package geniosym); $VERSION = '1.08'; my $genpkg = "Symbol::"; my $genseq = 0; my %global = map {$_ => 1} qw(ARGV ARGVOUT ENV INC SIG STDERR STDIN STDOUT); # # Note that we never _copy_ the glob; we just make a ref to it. # If we did copy it, then SVf_FAKE would be set on the copy, and # glob-specific behaviors (e.g. C<*$ref = \&func>) wouldn't work. # sub gensym () { my $name = "GEN" . $genseq++; my $ref = \*{$genpkg . $name}; delete $$genpkg{$name}; $ref; } sub geniosym () { my $sym = gensym(); # force the IO slot to be filled select(select $sym); *$sym{IO}; } sub ungensym ($) {} sub qualify ($;$) { my ($name) = @_; if (!ref($name) && index($name, '::') == -1 && index($name, "'") == -1) { my $pkg; # Global names: special character, "^xyz", or other. if ($name =~ /^(([^a-z])|(\^[a-z_]+))\z/i || $global{$name}) { # RGS 2001-11-05 : translate leading ^X to control-char $name =~ s/^\^([a-z_])/'qq(\c'.$1.')'/eei; $pkg = "main"; } else { $pkg = (@_ > 1) ? $_[1] : caller; } $name = $pkg . "::" . $name; } $name; } sub qualify_to_ref ($;$) { return \*{ qualify $_[0], @_ > 1 ? $_[1] : caller }; } # # of Safe.pm lineage # sub delete_package ($) { my $pkg = shift; # expand to full symbol table name if needed unless ($pkg =~ /^main::.*::$/) { $pkg = "main$pkg" if $pkg =~ /^::/; $pkg = "main::$pkg" unless $pkg =~ /^main::/; $pkg .= '::' unless $pkg =~ /::$/; } my($stem, $leaf) = $pkg =~ m/(.*::)(\w+::)$/; my $stem_symtab = *{$stem}{HASH}; return unless defined $stem_symtab and exists $stem_symtab->{$leaf}; # free all the symbols in the package my $leaf_symtab = *{$stem_symtab->{$leaf}}{HASH}; foreach my $name (keys %$leaf_symtab) { undef *{$pkg . $name}; } # delete the symbol table %$leaf_symtab = (); delete $stem_symtab->{$leaf}; } 1;
Save