6

我遇到了与Can't disable stack trace in Carp::croak() for some reason相同的问题。因为堆栈中的每个调用都被认为是“安全的”,所以每次都croak()打印出完整的堆栈跟踪。我想为某些呼叫禁用它。

这是一个例子:

use Carp;

sub this_may_fail {
  # Some code...
  croak "This call failed!";
}

sub regular_code {
  this_may_fail();
}

regular_code();

两个子例程都在同一个包中,因此this_may_fail被自动标记为安全。有没有办法告诉 Carpthis_may_fail应该被认为是不安全的?

4

2 回答 2

3

regular_code被认为是“安全的” this_may_fail。检查是基于命名空间的,因此为了使其不安全,您可以将其放置this_may_fail在不同的命名空间中。


或者写你自己的黄鱼。

perl -e'
   use Carp qw( );
   sub untrusting_croak {
      goto &Carp::croak if $Carp::Verbose;
      my @caller = caller(1);
      die(join("", @_)." at $caller[1] line $caller[2]\n");
   }

   sub f { untrusting_croak("!!!"); }    # Line 9

   f();                                  # Line 11
'
!!! at -e line 11
于 2014-02-18T17:18:54.770 回答
3

不是特别漂亮,但是,而不是这个:

sub regular_code {
   ...;
   my $result = this_may_fail(@args);
}

你可以用这个...

sub regular_code {
   ...;
   my $result = do {
      my $sub = \&this_may_fail;
      package DUMMY; $sub->(@args)
   };
}
于 2014-02-18T17:41:43.077 回答