GSP
Quick Navigator

Search Site

Unix VPS
A - Starter
B - Basic
C - Preferred
D - Commercial
MPS - Dedicated
Previous VPSs
* Sign Up! *

Support
Contact Us
Online Help
Handbooks
Domain Status
Man Pages

FAQ
Virtual Servers
Pricing
Billing
Technical

Network
Facilities
Connectivity
Topology Map

Miscellaneous
Server Agreement
Year 2038
Credits
 

USA Flag

 

 

Man Pages


Manual Reference Pages  -  CARP::ALWAYS (3)

.ds Aq ’

NAME

Carp::Always - Warns and dies noisily with stack backtraces

CONTENTS

SYNOPSIS



  use Carp::Always;



makes every warn() and die() complains loudly in the calling package and elsewhere. More often used on the command line:



  perl -MCarp::Always script.pl



DESCRIPTION

This module is meant as a debugging aid. It can be used to make a script complain loudly with stack backtraces when warn()ing or die()ing.

Here are how stack backtraces produced by this module looks:



  # it works for explicit dies and warns
  $ perl -MCarp::Always -e sub f { die "arghh" }; sub g { f }; g
  arghh at -e line 1
          main::f() called at -e line 1
          main::g() called at -e line 1

  # it works for interpreter-thrown failures
  $ perl -MCarp::Always -w -e sub f { $a = shift; @a = @$a }; \
                           -e sub g { f(undef) }; g
  Use of uninitialized value in array dereference at -e line 1
          main::f(undef) called at -e line 2
          main::g() called at -e line 2



In the implementation, the Carp module does the heavy work, through longmess(). The actual implementation sets the signal hooks $SIG{__WARN__} and $SIG{__DIE__} to emit the stack backtraces.

Oh, by the way, carp and croak when requiring/using the Carp module are also made verbose, behaving like cluck and confess, respectively.

    EXPORT

Nothing at all is exported.

ACKNOWLEDGMENTS

This module was born as a reaction to a release of Acme::JavaTrace by Se\k:'Aperghis-Tramoni. Se\k:'also has a newer module called Devel::SimpleTrace with the same code and fewer flame comments on docs. The pruning of the uselessly long docs of this module were prodded by Michael Schwern.

Schwern and others told me the module name stinked - it was called Carp::Indeed. After thinking long and not getting nowhere, I went with nuffin’s suggestion and now it is called Carp::Always. Carp::Indeed which is now deprecate lives in its own distribution (which won’t go anywhere but will stay there as a redirection to this module).

SEE ALSO

o Carp
o Acme::JavaTrace and Devel::SimpleTrace
o Carp::Always::Color
o Carp::Source::Always
Please report bugs via CPAN RT http://rt.cpan.org/NoAuth/Bugs.html?Dist=Carp-Always.

BUGS

Every (un)deserving module has its own pet bugs.
o This module does not play well with other modules which fusses around with warn, die, $SIG{__WARN__}, $SIG{__DIE__}.
o Test scripts are good. I should write more of these.
o I don’t know if this module name is still a bug as it was at the time of Carp::Indeed.

AUTHOR

Adriano Ferreira, <ferreira@cpan.org>

COPYRIGHT AND LICENSE

Copyright (C) 2005-2013 by Adriano R. Ferreira

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

Search for    or go to Top of page |  Section 3 |  Main Index


perl v5.20.3 CARP::ALWAYS (3) 2013-11-06

Powered by GSP Visit the GSP FreeBSD Man Page Interface.
Output converted with manServer 1.07.