diff options
author | Gisle Aas <gisle@aas.no> | 2000-08-30 02:33:09 +0200 |
---|---|---|
committer | Jarkko Hietaniemi <jhi@iki.fi> | 2000-08-29 23:44:14 +0000 |
commit | 022dc0897c96201d3aa1961e7ad1a6fd3238bda4 (patch) | |
tree | 91e74afbb7535c5f4dfb9898a7aa780ee1d63a9f /ext/Opcode | |
parent | 8b6e653be5897e6dbe4487609bc262b6bca2afcf (diff) | |
download | perl-022dc0897c96201d3aa1961e7ad1a6fd3238bda4.tar.gz |
Retry what #6882 attempted.
Subject: Re: [ID 20000829.004] Sharing leak root name into safe compartment
Message-ID: <m3pumry9y2.fsf@eik.g.aas.no>
p4raw-id: //depot/perl@6902
Diffstat (limited to 'ext/Opcode')
-rw-r--r-- | ext/Opcode/Safe.pm | 36 |
1 files changed, 18 insertions, 18 deletions
diff --git a/ext/Opcode/Safe.pm b/ext/Opcode/Safe.pm index 7e1d6a34a7..9b618f2f8f 100644 --- a/ext/Opcode/Safe.pm +++ b/ext/Opcode/Safe.pm @@ -152,7 +152,6 @@ sub share_from { my $pkg = shift; my $vars = shift; my $no_record = shift || 0; - my $root = $obj->root(); croak("vars not an array ref") unless ref $vars eq 'ARRAY'; no strict 'refs'; # Check that 'from' package actually exists @@ -167,13 +166,16 @@ sub share_from { my ($var, $type); $type = $1 if ($var = $arg) =~ s/^(\W)//; # warn "share_from $pkg $type $var"; - *{$root."::$var"} = (!$type) ? \&{$pkg."::$var"} + my $obj_to_share = (!$type) ? \&{$pkg."::$var"} : ($type eq '&') ? \&{$pkg."::$var"} : ($type eq '$') ? \${$pkg."::$var"} : ($type eq '@') ? \@{$pkg."::$var"} : ($type eq '%') ? \%{$pkg."::$var"} : ($type eq '*') ? *{$pkg."::$var"} : croak(qq(Can't share "$type$var" of unknown type)); + package main; + Opcode::_safe_call_sv($obj->{Root}, $obj->{Mask}, + sub { *$var = $obj_to_share }); } $obj->share_record($pkg, $vars) unless $no_record or !$vars; } @@ -208,27 +210,25 @@ sub varglob { sub reval { my ($obj, $expr, $strict) = @_; - my $root = $obj->{Root}; - # Create anon sub ref in root of compartment. - # Uses a closure (on $expr) to pass in the code to be executed. - # (eval on one line to keep line numbers as expected by caller) - my $evalcode = sprintf('package %s; sub { eval $expr; }', $root); - my $evalsub; - - if ($strict) { use strict; $evalsub = eval $evalcode; } - else { no strict; $evalsub = eval $evalcode; } - - return Opcode::_safe_call_sv($root, $obj->{Mask}, $evalsub); + package main; + if ($strict) { + use strict; + return Opcode::_safe_call_sv($obj->{Root}, $obj->{Mask}, + sub { eval $expr }); + } + else { + no strict; + return Opcode::_safe_call_sv($obj->{Root}, $obj->{Mask}, + sub { eval $expr }); + } } sub rdo { my ($obj, $file) = @_; - my $root = $obj->{Root}; - - my $evalsub = eval - sprintf('package %s; sub { do $file }', $root); - return Opcode::_safe_call_sv($root, $obj->{Mask}, $evalsub); + package main; + return Opcode::_safe_call_sv($obj->{Root}, $obj->{Mask}, + sub { do $file }); } |