From 1ee082b7cc0745c3a220deae68a0a3cc2ac5bd4b Mon Sep 17 00:00:00 2001 From: Gurusamy Sarathy Date: Mon, 6 Jul 1998 00:40:24 +0000 Subject: [PATCH] add Symbol::delete_package() p4raw-id: //depot/perl@1330 --- lib/Symbol.pm | 35 +++++++++++++++++++++++++++++++++++ pod/perlembed.pod | 18 +----------------- 2 files changed, 36 insertions(+), 17 deletions(-) diff --git a/lib/Symbol.pm b/lib/Symbol.pm index 6807e74..5ed6b26 100644 --- a/lib/Symbol.pm +++ b/lib/Symbol.pm @@ -27,6 +27,11 @@ Symbol - manipulate Perl symbols and their names 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 creates an anonymous glob and returns a reference @@ -52,6 +57,10 @@ C is just like C except that it returns a glob ref rather than a symbol name, so you can use the result even if C is in effect. +C wipes out a whole package namespace. Note +this routine is not exported by default--you may want to import it +explicitly. + =cut BEGIN { require 5.002; } @@ -59,6 +68,7 @@ BEGIN { require 5.002; } require Exporter; @ISA = qw(Exporter); @EXPORT = qw(gensym ungensym qualify qualify_to_ref); +@EXPORT_OK = qw(delete_package); $VERSION = 1.02; @@ -101,4 +111,29 @@ 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}; + + my $leaf_glob = $stem_symtab->{$leaf}; + my $leaf_symtab = *{$leaf_glob}{HASH}; + + %$leaf_symtab = (); + delete $stem_symtab->{$leaf}; +} + 1; diff --git a/pod/perlembed.pod b/pod/perlembed.pod index 1255345..f7c8e4a 100644 --- a/pod/perlembed.pod +++ b/pod/perlembed.pod @@ -668,6 +668,7 @@ with my() whenever possible. use strict; use vars '%Cache'; + use Symbol qw(delete_package); sub valid_package_name { my($string) = @_; @@ -680,23 +681,6 @@ with my() whenever possible. return "Embed" . $string; } - #borrowed from Safe.pm - sub delete_package { - my $pkg = shift; - my ($stem, $leaf); - - no strict 'refs'; - $pkg = "main::$pkg\::"; # expand to full symbol table name - ($stem, $leaf) = $pkg =~ m/(.*::)(\w+::)$/; - - my $stem_symtab = *{$stem}{HASH}; - my $leaf_glob = $stem_symtab->{$leaf}; - my $leaf_symtab = *{$leaf_glob}{HASH}; - - %$leaf_symtab = (); - delete $stem_symtab->{$leaf}; - } - sub eval_file { my($filename, $delete) = @_; my $package = valid_package_name($filename); -- 2.7.4