summaryrefslogtreecommitdiff
path: root/lang/perl5.8/files/patch-Safe.pm
diff options
context:
space:
mode:
Diffstat (limited to 'lang/perl5.8/files/patch-Safe.pm')
-rw-r--r--lang/perl5.8/files/patch-Safe.pm83
1 files changed, 0 insertions, 83 deletions
diff --git a/lang/perl5.8/files/patch-Safe.pm b/lang/perl5.8/files/patch-Safe.pm
deleted file mode 100644
index 12873700b9aa..000000000000
--- a/lang/perl5.8/files/patch-Safe.pm
+++ /dev/null
@@ -1,83 +0,0 @@
---- ext/Opcode/Safe.pm.orig Mon Apr 21 16:37:46 2003
-+++ ext/Opcode/Safe.pm Mon Apr 21 16:37:52 2003
-@@ -3,7 +3,7 @@ package Safe;
- use 5.003_11;
- use strict;
-
--our $VERSION = "2.07";
-+$Safe::VERSION = "2.09";
-
- use Carp;
-
-@@ -47,7 +47,7 @@ sub new {
- # the whole glob *_ rather than $_ and @_ separately, otherwise
- # @_ in non default packages within the compartment don't work.
- $obj->share_from('main', $default_share);
-- Opcode::_safe_pkg_prep($obj->{Root});
-+ Opcode::_safe_pkg_prep($obj->{Root}) if($Opcode::VERSION > 1.04);
- return $obj;
- }
-
-@@ -155,7 +155,7 @@ sub share_from {
- my $no_record = shift || 0;
- my $root = $obj->root();
- croak("vars not an array ref") unless ref $vars eq 'ARRAY';
-- no strict 'refs';
-+ no strict 'refs';
- # Check that 'from' package actually exists
- croak("Package \"$pkg\" does not exist")
- unless keys %{"$pkg\::"};
-@@ -190,7 +190,7 @@ sub share_record {
- sub share_redo {
- my $obj = shift;
- my $shares = \%{$obj->{Shares} ||= {}};
-- my($var, $pkg);
-+ my($var, $pkg);
- while(($var, $pkg) = each %$shares) {
- # warn "share_redo $pkg\:: $var";
- $obj->share_from($pkg, [ $var ], 1);
-@@ -214,11 +214,11 @@ sub reval {
- # 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 $evalcode = sprintf('package %s; sub { @_ = (); eval $expr; }', $root);
- my $evalsub;
-
-- if ($strict) { use strict; $evalsub = eval $evalcode; }
-- else { no strict; $evalsub = eval $evalcode; }
-+ if ($strict) { use strict; $evalsub = eval $evalcode; }
-+ else { no strict; $evalsub = eval $evalcode; }
-
- return Opcode::_safe_call_sv($root, $obj->{Mask}, $evalsub);
- }
-@@ -228,7 +228,7 @@ sub rdo {
- my $root = $obj->{Root};
-
- my $evalsub = eval
-- sprintf('package %s; sub { do $file }', $root);
-+ sprintf('package %s; sub { @_ = (); do $file }', $root);
- return Opcode::_safe_call_sv($root, $obj->{Mask}, $evalsub);
- }
-
-@@ -383,8 +383,9 @@ This shares the variable(s) in the argum
- This is almost identical to exporting variables using the L<Exporter>
- module.
-
--Each NAME must be the B<name> of a variable, typically with the leading
--type identifier included. A bareword is treated as a function name.
-+Each NAME must be the B<name> of a non-lexical variable, typically
-+with the leading type identifier included. A bareword is treated as a
-+function name.
-
- Examples of legal names are '$foo' for a scalar, '@foo' for an
- array, '%foo' for a hash, '&foo' or 'foo' for a subroutine and '*foo'
-@@ -426,7 +427,7 @@ C<main::> package to the code inside the
- Any attempt by the code in STRING to use an operator which is not permitted
- by the compartment will cause an error (at run-time of the main program
- but at compile-time for the code in STRING). The error is of the form
--"%s trapped by operation mask operation...".
-+"'%s' trapped by operation mask...".
-
- If an operation is trapped in this way, then the code in STRING will
- not be executed. If such a trapped operation occurs or any other