188 lines
4.8 KiB
Diff
188 lines
4.8 KiB
Diff
From a91baa4c8cb395568f4c55199e47ce4807e42bd2 Mon Sep 17 00:00:00 2001
|
||
From: Jitka Plesnikova <jplesnik@redhat.com>
|
||
Date: Wed, 5 May 2021 13:42:36 +0200
|
||
Subject: [PATCH] Upgrade to 1.52
|
||
|
||
---
|
||
lib/Carp.pm | 12 ++++++------
|
||
lib/Carp/Heavy.pm | 2 +-
|
||
t/Carp.t | 6 ++++--
|
||
t/Carp_overloadless.t | 6 ++++--
|
||
t/broken_can.t | 5 ++++-
|
||
t/broken_univ_can.t | 12 +++++++++---
|
||
t/vivify_stash.t | 6 +++++-
|
||
7 files changed, 33 insertions(+), 16 deletions(-)
|
||
|
||
diff --git a/lib/Carp.pm b/lib/Carp.pm
|
||
index 109b7fe..df563d0 100644
|
||
--- a/lib/Carp.pm
|
||
+++ b/lib/Carp.pm
|
||
@@ -211,7 +211,7 @@ BEGIN {
|
||
}
|
||
|
||
|
||
-our $VERSION = '1.50';
|
||
+our $VERSION = '1.52';
|
||
$VERSION =~ tr/_//d;
|
||
|
||
our $MaxEvalLen = 0;
|
||
@@ -284,7 +284,7 @@ sub shortmess {
|
||
my $cgc = _cgc();
|
||
|
||
# Icky backwards compatibility wrapper. :-(
|
||
- local @CARP_NOT = $cgc ? $cgc->() : caller();
|
||
+ local @CARP_NOT = scalar( $cgc ? $cgc->() : caller() );
|
||
shortmess_heavy(@_);
|
||
}
|
||
|
||
@@ -944,10 +944,10 @@ This variable sets a general argument formatter to display references.
|
||
Plain scalars and objects that implement C<CARP_TRACE> will not go through
|
||
this formatter. Calling C<Carp> from within this function is not supported.
|
||
|
||
-local $Carp::RefArgFormatter = sub {
|
||
- require Data::Dumper;
|
||
- Data::Dumper::Dump($_[0]); # not necessarily safe
|
||
-};
|
||
+ local $Carp::RefArgFormatter = sub {
|
||
+ require Data::Dumper;
|
||
+ Data::Dumper->Dump($_[0]); # not necessarily safe
|
||
+ };
|
||
|
||
=head2 @CARP_NOT
|
||
|
||
diff --git a/lib/Carp/Heavy.pm b/lib/Carp/Heavy.pm
|
||
index a9b803c..fdb3e52 100644
|
||
--- a/lib/Carp/Heavy.pm
|
||
+++ b/lib/Carp/Heavy.pm
|
||
@@ -2,7 +2,7 @@ package Carp::Heavy;
|
||
|
||
use Carp ();
|
||
|
||
-our $VERSION = '1.50';
|
||
+our $VERSION = '1.52';
|
||
$VERSION =~ tr/_//d;
|
||
|
||
# Carp::Heavy was merged into Carp in version 1.12. Any mismatched versions
|
||
diff --git a/t/Carp.t b/t/Carp.t
|
||
index b1e399d..02c047e 100644
|
||
--- a/t/Carp.t
|
||
+++ b/t/Carp.t
|
||
@@ -1,5 +1,6 @@
|
||
+use strict;
|
||
use warnings;
|
||
-no warnings "once";
|
||
+
|
||
use Config;
|
||
|
||
use IPC::Open3 1.0103 qw(open3);
|
||
@@ -353,6 +354,7 @@ for my $bodge_job ( 2, 1, 0 ) { SKIP: {
|
||
print "# required B\n";
|
||
}
|
||
my $accum = '';
|
||
+ no warnings 'once';
|
||
local *CORE::GLOBAL::caller = sub {
|
||
local *__ANON__ = "fakecaller";
|
||
my @c = CORE::caller(@_);
|
||
@@ -480,7 +482,7 @@ SKIP:
|
||
);
|
||
|
||
package Foo::No::Autovivify;
|
||
- $CARP_NOT = 1;
|
||
+ our $CARP_NOT = 1;
|
||
eval { Carp::croak(1) };
|
||
::ok(
|
||
!defined *{$Foo::No::Autovivify::{CARP_NOT}}{ARRAY},
|
||
diff --git a/t/Carp_overloadless.t b/t/Carp_overloadless.t
|
||
index f4bda04..6b73601 100644
|
||
--- a/t/Carp_overloadless.t
|
||
+++ b/t/Carp_overloadless.t
|
||
@@ -1,12 +1,14 @@
|
||
+use strict;
|
||
use warnings;
|
||
-#no warnings 'once';
|
||
+
|
||
use Test::More tests => 1;
|
||
|
||
use Carp;
|
||
|
||
# test that enabling overload without loading overload.pm does not trigger infinite recursion
|
||
|
||
-my $p = "OverloadedInXS";
|
||
+no strict 'refs';
|
||
+my $p = "OverloadedInXS";
|
||
*{$p."::(("} = sub{};
|
||
*{$p.q!::(""!} = sub { Carp::cluck "<My Stringify>" };
|
||
sub { Carp::longmess("longmess:") }->(bless {}, $p);
|
||
diff --git a/t/broken_can.t b/t/broken_can.t
|
||
index c32fa19..9232d68 100644
|
||
--- a/t/broken_can.t
|
||
+++ b/t/broken_can.t
|
||
@@ -1,3 +1,6 @@
|
||
+use strict;
|
||
+use warnings;
|
||
+
|
||
use Test::More tests => 1;
|
||
|
||
# [perl #132910]
|
||
@@ -10,6 +13,6 @@ package main;
|
||
use Carp;
|
||
|
||
eval {
|
||
- sub { confess-sins }->(bless[], Foo);
|
||
+ sub { confess-sins }->(bless[], 'Foo');
|
||
};
|
||
like $@, qr/^-sins at /;
|
||
diff --git a/t/broken_univ_can.t b/t/broken_univ_can.t
|
||
index 0ec19d7..49c7720 100644
|
||
--- a/t/broken_univ_can.t
|
||
+++ b/t/broken_univ_can.t
|
||
@@ -1,15 +1,21 @@
|
||
+use strict;
|
||
+use warnings;
|
||
+
|
||
# [perl #132910]
|
||
# This mock-up breaks Test::More. Don’t use Test::More.
|
||
|
||
-sub UNIVERSAL::can { die; }
|
||
+{
|
||
+ no warnings 'redefine';
|
||
+ sub UNIVERSAL::can { die; }
|
||
+}
|
||
|
||
# Carp depends on this to detect the override:
|
||
-BEGIN { $UNIVERSAL::can::VERSION = 0xbaff1ed_bee; }
|
||
+BEGIN { no warnings 'portable'; $UNIVERSAL::can::VERSION = 0xbaff1ed_bee; }
|
||
|
||
use Carp;
|
||
|
||
eval {
|
||
- sub { confess-sins }->(bless[], Foo);
|
||
+ sub { confess-sins }->(bless[], 'Foo');
|
||
};
|
||
print "1..1\n";
|
||
if ($@ !~ qr/^-sins at /) {
|
||
diff --git a/t/vivify_stash.t b/t/vivify_stash.t
|
||
index 744d0d2..00181f3 100644
|
||
--- a/t/vivify_stash.t
|
||
+++ b/t/vivify_stash.t
|
||
@@ -1,3 +1,6 @@
|
||
+use strict;
|
||
+use warnings;
|
||
+
|
||
BEGIN { print "1..5\n"; }
|
||
|
||
our $has_utf8; BEGIN { $has_utf8 = exists($::{"utf8::"}); }
|
||
@@ -18,7 +21,8 @@ eval { sub { Carp::longmess() }->(\1) };
|
||
print $@ eq '' ? "ok 4 # longmess check1\n" : "not ok 4 # longmess check1\n# $@";
|
||
|
||
# overload:: glob without hash
|
||
-undef *{"overload::"};
|
||
+# Clear overload quoted so it happens to the runtime stash.
|
||
+{ no strict 'refs'; undef *{"overload::"} }
|
||
eval { sub { Carp::longmess() }->(\1) };
|
||
print $@ eq '' ? "ok 5 # longmess check2\n" : "not ok 5 # longmess check2\n# $@";
|
||
|
||
--
|
||
2.30.2
|
||
|