CINXE.COM
Carp::Always - Warns and dies noisily with stack backtraces - metacpan.org
<!DOCTYPE html> <html lang="en-US"> <head> <title>Carp::Always - Warns and dies noisily with stack backtraces - metacpan.org</title> <link rel="preload" as="fetch" href="/account/login_status" crossorigin="anonymous" /> <link href="/assets/style-XFEQ536G.css" rel="stylesheet" type="text/css"> <script src="/assets/main-WXBSEDQJ.js" type="module"></script> <link rel="alternate" type="application/rss+xml" title="Recent CPAN Uploads of Carp-Always - MetaCPAN" href="/dist/Carp-Always/releases.rss" /> <link rel="canonical" href="https://metacpan.org/pod/Carp::Always" /> <meta name="description" content="Warns and dies noisily with stack backtraces" /> <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=5"> <link rel="shortcut icon" href="/static/icons/favicon.ico"> <link rel="apple-touch-icon" sizes="152x152" href="/static/icons/apple-touch-icon.png"> <link rel="search" href="/static/opensearch.xml" type="application/opensearchdescription+xml" title="MetaCPAN"> <script async src="https://perl-ads.perlhacks.com/perl-ads.js"></script> <script async src="https://www.googletagmanager.com/gtag/js?id=G-E82Q2V8LVD"></script> <meta property="og:site_name" content="MetaCPAN" /> <meta name="twitter:site" content="@metacpan" /> <meta property="og:type" content="article" /> <meta name="twitter:card" content="summary" /> <meta property="og:url" content="https://metacpan.org/pod/Carp::Always" /> <meta property="og:title" content="Carp::Always" /> <meta property="og:description" content="Warns and dies noisily with stack backtraces" /> <meta property="og:image" content="https://metacpan.org/static/images/dots.png" /> </head> <body> <nav class="navbar navbar-default" role="navigation"> <div class="header-logo-large hidden-xs"> <a href="/" tabindex="0"> <svg class="logo" aria-label="MetaCPAN"> <use class="logo" href="/static/images/metacpan-logo.svg#logo" /> </svg> </a> </div> <div class="header-logo-icon visible-xs"> <a href="/"> <svg class="logo" aria-label="MetaCPAN"> <use class="logo" href="/static/images/metacpan-logo.svg#dots" /> </svg> </a> </div> <ul class="nav navbar-nav menu-items hidden-xs hidden-sm"> <li><a href="/about">About</a></li> <li><a href="/about/sponsors">Sponsor</a></li> <li><a href="https://grep.metacpan.org/">grep::cpan</a></li> <li><a href="/recent">Recent</a></li> <li><a href="/about/faq">FAQ</a></li> <li><a href="/tools">Tools</a></li> <li><a href="https://fastapi.metacpan.org/">API</a></li> </ul> <ul class="nav navbar-nav navbar-right"> <button type="button" class="searchbar-btn visible-xs visible-sm"> <i class="fa fa-search button-fa-icon"></i> </button> <form action="/search" class="searchbar-form visible-md visible-lg search-form form-horizontal"> <input type="hidden" name="size" id="metacpan_search-size" value="20"> <div class="form-group"> <div class="search-group"> <i class="fa fa-search"></i> <input type="text" name="q" placeholder="Search the CPAN" size="41" autocorrect="off" autocapitalize="off" spellcheck="false" id="metacpan_search-input" class="form-control" value=""> </div> </div> </form> <li class="icon-slidepanel visible-xs visible-sm"> <button data-toggle="slidepanel" data-target=".slidepanel"> <span class="button-fa-icon"> <i class="fa fa-bars slidepanel-open"></i> <i class="fa fa-times slidepanel-close"></i> </span> </button> </li> <li class="dropdown login-dropdown show-logged-in"> <button type="button" class="dropdown-toggle" data-toggle="dropdown"> <i class="fa fa-user button-fa-icon logged-in-icon" aria-hidden="true"></i> <i class="fas fa-chevron-down"></i> </button> <ul class="dropdown-menu"> <li><a href="/account/identities">Identities</a></li> <li><a href="/account/profile">Profile</a></li> <li><a href="/account/favorite/list">Favorites</a></li> <li> <a href="#" type="button" class="logout-button"> Logout </a> </li> </ul> </li> <li class="dropdown login-dropdown show-logged-out"> <button type="button" class="dropdown-toggle" data-toggle="dropdown"> <i class="fa fa-user button-fa-icon avatar-placeholder" aria-hidden="true"></i> <i class="fas fa-chevron-down"></i> </button> <ul class="dropdown-menu"> <li> <a href="/login/github"> <i class="fab fa-github fa-fw"></i> GitHub </a> </li> <li> <a href="/login/twitter"> <i class="fab fa-twitter fa-fw"></i> Twitter </a> </li> <li> <a href="/login/google"> <i class="fab fa-google fa-fw"></i> Google </a> </li> </ul> </li> <li class="dropdown login-dropdown hide-logged-in hide-logged-out"> <button> <i class="fa fa-user button-fa-icon" aria-hidden="true"></i> </button> </li> </ul> </nav> <div class="page-content "> <div id="perl-ad-target" class="top-notify-banner perl-ad-target"> </div> <nav class="sidebar"> <div class="slidepanel"> <ul class="nav-list "> <li class="nav-header no-margin-top"> <div class="ttip" data-toggle="tooltip" data-placement="bottom" title="The date that this version of Carp-Always was released."> <span class="relatize">10 Aug 2018 23:36:09 UTC</span> </div> </li> <li> Distribution: <a href="/dist/Carp-Always">Carp-Always</a> </li> <li> Module version: 0.16 </li> <li> <a data-keyboard-shortcut="g s" href="/dist/Carp-Always/source/lib/Carp/Always.pm">Source</a> (<a href="/dist/Carp-Always/source/lib/Carp/Always.pm?raw=1">raw</a>) </li> <li> <a data-keyboard-shortcut="g b" href="/dist/Carp-Always/source/lib/Carp">Browse</a> (<a href="/dist/Carp-Always/source/lib/Carp?raw=1">raw</a>) </li> <li> <a data-keyboard-shortcut="g c" href="/dist/Carp-Always/changes">Changes</a> </li> <li> <a class="nopopup" href="/dist/Carp-Always/contribute">How to Contribute</a> </li> <li> <a rel="noopener nofollow" data-keyboard-shortcut="g r" href="https://github.com/aferreira/cpan-Carp-Always">Repository</a> </li> <li> <a rel="noopener nofollow" data-keyboard-shortcut="g i" href="https://github.com/aferreira/cpan-Carp-Always/issues">Issues</a> (1) </li> <li> <a rel="noopener nofollow" href="http://matrix.cpantesters.org/?dist=Carp-Always+0.16" title="Matrix">Testers</a> <span title="(pass / fail / na)">(<a rel="noopener nofollow" href="https://www.cpantesters.org/distro/C/Carp-Always.html?oncpan=1&distmat=1&version=0.16&grade=2" style="color: #090">8673</a> / <a rel="noopener nofollow" href="https://www.cpantesters.org/distro/C/Carp-Always.html?oncpan=1&distmat=1&version=0.16&grade=3" style="color: #900">2</a> / <a rel="noopener nofollow" href="https://www.cpantesters.org/distro/C/Carp-Always.html?oncpan=1&distmat=1&version=0.16&grade=4">0</a>)</span> </li> <li> <a rel="noopener nofollow" href="http://cpants.cpanauthors.org/release/FERREIRA/Carp-Always-0.16">Kwalitee</a> </li> <li> <div class="ttip" data-toggle="tooltip" data-placement="bottom" title="The # people with an indexing permission on Carp-Always who have released something to CPAN in the last 2 years (i.e. the # people likely able to release critical fixes in a timely manner)"> Bus factor: 0 </div> </li> <li> <a rel="noopener nofollow" href="http://cpancover.com/latest/Carp-Always-0.16/index.html">61.22% Coverage </a> </li> <li> License: perl_5 </li> <li> Perl: v5.6.0 </li> <li class="nav-header">Activity</li> <li> <div class="activity-graph"> <img src="/dist/Carp-Always/activity.svg?res=month" /> <div class="comment">24 month</div> </div> </li> <li class="nav-header">Tools</li> <li> <a itemprop="downloadUrl" href="https://cpan.metacpan.org/authors/id/F/FE/FERREIRA/Carp-Always-0.16.tar.gz"> Download (<span itemprop="fileSize">13.07KB</span>)</a> </li> <li> <a href="https://explorer.metacpan.org/?url=%2Fmodule%2FFERREIRA%2FCarp-Always-0.16%2Flib%2FCarp%2FAlways.pm"> MetaCPAN Explorer </a> </li> <li> <a href="/dist/Carp-Always/permissions"> Permissions </a> </li> <li> <a href="/dist/Carp-Always/releases.rss"> Subscribe to distribution </a> </li> <li> <button class="btn btn-link" data-toggle="modal" data-target="#metacpan_install-instructions-dialog"> Install Instructions </button> </li> <li> <form action="/search"> <input type="hidden" name="q" value="dist:Carp-Always"> <input type="search" name="q" placeholder="Search distribution" class="form-control tool-bar-form"> <input type="submit" style="display: none"> </form> </li> <li> <form action="https://grep.metacpan.org/search"> <input type="hidden" name="qd" value="Carp-Always"> <input type="hidden" name="source" value="metacpan"> <input type="search" name="q" placeholder="grep distribution" class="form-control tool-bar-form"> <input type="submit" style="display: none"> </form> </li> <li class="version-jump"> <select class="select-navigator form-control tool-bar-form"> <option disabled selected>Jump to version</option> <option disabled value="/release/FERREIRA/Carp-Always-0.16/view/lib/Carp/Always.pm" >0.16 (FERREIRA on 2018-08-10)</option> <option value="/release/FERREIRA/Carp-Always-0.15_02/view/lib/Carp/Always.pm" >0.15_02 DEV (FERREIRA on 2018-08-10)</option> <option value="/release/FERREIRA/Carp-Always-0.15_01/view/lib/Carp/Always.pm" >0.15_01 DEV (FERREIRA on 2018-08-10)</option> <option value="/release/FERREIRA/Carp-Always-0.15/view/lib/Carp/Always.pm" >0.15 (FERREIRA on 2018-08-10)</option> <option value="/release/FERREIRA/Carp-Always-0.14_05/view/lib/Carp/Always.pm" >0.14_05 DEV (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.14_04/view/lib/Carp/Always.pm" >0.14_04 DEV (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.14_03/view/lib/Carp/Always.pm" >0.14_03 DEV (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.14_02/view/lib/Carp/Always.pm" >0.14_02 DEV (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.14_01/view/lib/Carp/Always.pm" >0.14_01 DEV (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.14/view/lib/Carp/Always.pm" >0.14 (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.13_03/view/lib/Carp/Always.pm" >0.13_03 DEV (FERREIRA on 2018-08-08)</option> <option value="/release/FERREIRA/Carp-Always-0.13_02/view/lib/Carp/Always.pm" >0.13_02 DEV (FERREIRA on 2018-08-08)</option> <option value="/release/FERREIRA/Carp-Always-0.13_01/view/lib/Carp/Always.pm" >0.13_01 DEV (FERREIRA on 2018-08-08)</option> <option value="/release/FERREIRA/Carp-Always-0.13/view/lib/Carp/Always.pm" >0.13 (FERREIRA on 2013-11-06)</option> <optgroup label="BackPAN">' <option value="/release/FERREIRA/Carp-Always-0.12/view/lib/Carp/Always.pm" >0.12 (FERREIRA on 2012-08-21)</option> <option value="/release/FERREIRA/Carp-Always-0.11/view/lib/Carp/Always.pm" >0.11 (FERREIRA on 2012-04-18)</option> <option value="/release/FERREIRA/Carp-Always-0.10/view/lib/Carp/Always.pm" >0.10 (FERREIRA on 2011-08-19)</option> <option value="/release/FERREIRA/Carp-Always-0.09/view/lib/Carp/Always.pm" >0.09 (FERREIRA on 2007-07-30)</option> <option value="/release/FERREIRA/Carp-Always-0.08/view/lib/Carp/Always.pm" >0.08 (FERREIRA on 2007-03-21)</option> <option value="/release/FERREIRA/Carp-Always-0.07/view/lib/Carp/Always.pm" >0.07 (FERREIRA on 2006-10-25)</option> <option value="/release/FERREIRA/Carp-Always-0.06/view/lib/Carp/Always.pm" >0.06 (FERREIRA on 2006-07-17)</option> </optgroup> </select> </li> <li class="version-diff"> <select class="select-navigator form-control tool-bar-form"> <option disabled selected>Diff with version</option> <option disabled value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.16/lib/Carp/Always.pm" >0.16 (FERREIRA on 2018-08-10)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.15_02/lib/Carp/Always.pm" >0.15_02 DEV (FERREIRA on 2018-08-10)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.15_01/lib/Carp/Always.pm" >0.15_01 DEV (FERREIRA on 2018-08-10)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.15/lib/Carp/Always.pm" >0.15 (FERREIRA on 2018-08-10)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.14_05/lib/Carp/Always.pm" >0.14_05 DEV (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.14_04/lib/Carp/Always.pm" >0.14_04 DEV (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.14_03/lib/Carp/Always.pm" >0.14_03 DEV (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.14_02/lib/Carp/Always.pm" >0.14_02 DEV (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.14_01/lib/Carp/Always.pm" >0.14_01 DEV (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.14/lib/Carp/Always.pm" >0.14 (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.13_03/lib/Carp/Always.pm" >0.13_03 DEV (FERREIRA on 2018-08-08)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.13_02/lib/Carp/Always.pm" >0.13_02 DEV (FERREIRA on 2018-08-08)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.13_01/lib/Carp/Always.pm" >0.13_01 DEV (FERREIRA on 2018-08-08)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.13/lib/Carp/Always.pm" >0.13 (FERREIRA on 2013-11-06)</option> <optgroup label="BackPAN">' <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.12/lib/Carp/Always.pm" >0.12 (FERREIRA on 2012-08-21)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.11/lib/Carp/Always.pm" >0.11 (FERREIRA on 2012-04-18)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.10/lib/Carp/Always.pm" >0.10 (FERREIRA on 2011-08-19)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.09/lib/Carp/Always.pm" >0.09 (FERREIRA on 2007-07-30)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.08/lib/Carp/Always.pm" >0.08 (FERREIRA on 2007-03-21)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.07/lib/Carp/Always.pm" >0.07 (FERREIRA on 2006-10-25)</option> <option value="/release/FERREIRA/Carp-Always-0.16/diff/FERREIRA/Carp-Always-0.06/lib/Carp/Always.pm" >0.06 (FERREIRA on 2006-07-17)</option> </optgroup> </select> </li> <li> <ul class="dependencies"> <li class="nav-header">Dependencies</li> <li><a href="/pod/Carp" title="Carp" class="ellipsis">Carp</a></li> <li> <hr> </li> <li> <a href="/module/Carp::Always/requires">Reverse dependencies</a> </li> <li> <a href="http://deps.cpantesters.org/?module=Carp%3A%3AAlways">CPAN Testers List</a> </li> <li> <a href="https://cpandeps.grinnz.com/?dist=Carp-Always">Dependency graph</a> </li> </ul> </li> <li class="nav-header">Permalinks</li> <li> <a href="/release/FERREIRA/Carp-Always-0.16/view/lib/Carp/Always.pm">This version</a> </li> <li> <a href="/pod/Carp::Always">Latest version</a> </li> <li> <div class="plussers"> <div class="nav-header">++ed by:</div> <div> <a class="display-all" href="/author/MJEMMESON"><img src="https://www.gravatar.com/avatar/e17c4cf81cbd75b5043884252c378c47?d=identicon&s=20" title="MJEMMESON" alt="MJEMMESON"></a> <a class="display-all" href="/author/DCPETROV"><img src="https://www.gravatar.com/avatar/10e265a667839a004d83dd3ed6b6cfc9?d=identicon&s=20" title="DCPETROV" alt="DCPETROV"></a> <a class="display-all" href="/author/PLU"><img src="https://www.gravatar.com/avatar/b4db07dda59c4fcacce75e943ff4cbb7?d=identicon&s=20" title="PLU" alt="PLU"></a> <a class="display-all" href="/author/MMCLERIC"><img src="https://www.gravatar.com/avatar/d83bc667b8ec21a5b2861b22485024c7?d=identicon&s=20" title="MMCLERIC" alt="MMCLERIC"></a> <a class="display-all" href="/author/DOY"><img src="https://www.gravatar.com/avatar/88766de7a058697d3d0335b8d384fd2a?d=identicon&s=20" title="DOY" alt="DOY"></a> </div> <!-- Display counts of plussers--> <div> <a href="/dist/Carp-Always/plussers">30 PAUSE users</a> </div> <div> 7 non-PAUSE users </div> </div> </li> <li> </li> </ul> </div> </nav> <div class="content-navigation"> <div class="breadcrumbs"> <span> <a data-keyboard-shortcut="g a" rel="author" href="/author/FERREIRA" class="author-name">Adriano Ferreira</a> </span> <span> / </span> <div class="release dist-release status-latest maturity-released"> <span class="dropdown"><b class="caret"></b></span> <select class="select-navigator "> <option selected value="/release/FERREIRA/Carp-Always-0.16/view/lib/Carp/Always.pm" >0.16 (FERREIRA on 2018-08-10)</option> <option value="/release/FERREIRA/Carp-Always-0.15_02/view/lib/Carp/Always.pm" >0.15_02 DEV (FERREIRA on 2018-08-10)</option> <option value="/release/FERREIRA/Carp-Always-0.15_01/view/lib/Carp/Always.pm" >0.15_01 DEV (FERREIRA on 2018-08-10)</option> <option value="/release/FERREIRA/Carp-Always-0.15/view/lib/Carp/Always.pm" >0.15 (FERREIRA on 2018-08-10)</option> <option value="/release/FERREIRA/Carp-Always-0.14_05/view/lib/Carp/Always.pm" >0.14_05 DEV (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.14_04/view/lib/Carp/Always.pm" >0.14_04 DEV (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.14_03/view/lib/Carp/Always.pm" >0.14_03 DEV (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.14_02/view/lib/Carp/Always.pm" >0.14_02 DEV (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.14_01/view/lib/Carp/Always.pm" >0.14_01 DEV (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.14/view/lib/Carp/Always.pm" >0.14 (FERREIRA on 2018-08-09)</option> <option value="/release/FERREIRA/Carp-Always-0.13_03/view/lib/Carp/Always.pm" >0.13_03 DEV (FERREIRA on 2018-08-08)</option> <option value="/release/FERREIRA/Carp-Always-0.13_02/view/lib/Carp/Always.pm" >0.13_02 DEV (FERREIRA on 2018-08-08)</option> <option value="/release/FERREIRA/Carp-Always-0.13_01/view/lib/Carp/Always.pm" >0.13_01 DEV (FERREIRA on 2018-08-08)</option> <option value="/release/FERREIRA/Carp-Always-0.13/view/lib/Carp/Always.pm" >0.13 (FERREIRA on 2013-11-06)</option> <optgroup label="BackPAN">' <option value="/release/FERREIRA/Carp-Always-0.12/view/lib/Carp/Always.pm" >0.12 (FERREIRA on 2012-08-21)</option> <option value="/release/FERREIRA/Carp-Always-0.11/view/lib/Carp/Always.pm" >0.11 (FERREIRA on 2012-04-18)</option> <option value="/release/FERREIRA/Carp-Always-0.10/view/lib/Carp/Always.pm" >0.10 (FERREIRA on 2011-08-19)</option> <option value="/release/FERREIRA/Carp-Always-0.09/view/lib/Carp/Always.pm" >0.09 (FERREIRA on 2007-07-30)</option> <option value="/release/FERREIRA/Carp-Always-0.08/view/lib/Carp/Always.pm" >0.08 (FERREIRA on 2007-03-21)</option> <option value="/release/FERREIRA/Carp-Always-0.07/view/lib/Carp/Always.pm" >0.07 (FERREIRA on 2006-10-25)</option> <option value="/release/FERREIRA/Carp-Always-0.06/view/lib/Carp/Always.pm" >0.06 (FERREIRA on 2006-07-17)</option> </optgroup> </select> <a data-keyboard-shortcut="g d" class="release-name" href="/dist/Carp-Always">Carp-Always-0.16</a> </div> <span class="river-gauge-gauge"> <svg width="24px" height="15px" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> <g> <title> River stage two • 51 direct dependents • 69 total dependents </title> <rect x="0" y="0" width="4" height="15" fill="#7ea3f2" /> <rect x="5" y="0" width="4" height="15" fill="#7ea3f2" /> <rect x="10" y="0" width="4" height="15" fill="#e4e2e2" /> <rect x="15" y="0" width="4" height="15" fill="#e4e2e2" /> <rect x="20" y="0" width="4" height="15" fill="#e4e2e2" /> </g> </svg> </span> <div id="Carp-Always-fav" class="show-logged-in"> <form action="/account/favorite/add" style="display: inline" method="POST"> <input type="hidden" name="remove" value="0"> <input type="hidden" name="release" value="Carp-Always-0.16"> <input type="hidden" name="author" value="FERREIRA"> <input type="hidden" name="distribution" value="Carp-Always"> <button type="submit" class="favorite highlight"><span>37</span> ++</button> </form> </div> <div class="show-logged-out"> <button class="fav-not-logged-in favorite highlight"><span>37</span> ++</button> </div> / <span>Carp::Always</span> </div> </div> <main class="content"> <nav class="toc"> <div class="toc-header"><strong>Contents</strong></div> <ul> <li><a href="#NAME">NAME</a></li> <li><a href="#SYNOPSIS">SYNOPSIS</a></li> <li><a href="#DESCRIPTION">DESCRIPTION</a></li> <li><a href="#METHODS">METHODS</a> <ul> <li><a href="#import">import</a></li> <li><a href="#unimport">unimport</a></li> </ul> </li> <li><a href="#ACKNOWLEDGMENTS">ACKNOWLEDGMENTS</a></li> <li><a href="#SEE-ALSO">SEE ALSO</a></li> <li><a href="#BUGS">BUGS</a></li> <li><a href="#AUTHOR">AUTHOR</a></li> <li><a href="#COPYRIGHT-AND-LICENSE">COPYRIGHT AND LICENSE</a></li> </ul></nav> <div class="pod anchors"> <h1 id="NAME">NAME</h1> <p>Carp::Always - Warns and dies noisily with stack backtraces</p> <h1 id="SYNOPSIS">SYNOPSIS</h1> <pre><code>use Carp::Always;</code></pre> <p>Often used on the command line:</p> <pre><code>perl -MCarp::Always script.pl</code></pre> <h1 id="DESCRIPTION">DESCRIPTION</h1> <p>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.</p> <p>Here are how stack backtraces produced by this module looks:</p> <pre><code># it works for explicit die's and warn's $ 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</code></pre> <p>In the implementation, the <a href="/pod/Carp">Carp</a> module does the heavy work, through <code>longmess()</code>. The actual implementation sets the signal hooks <a href="/pod/perlvar#%25SIG">$SIG{__WARN__}</a> and <a href="/pod/perlvar#%25SIG">$SIG{__DIE__}</a> to emit the stack backtraces.</p> <p>Also, all uses of <code>carp</code> and <code>croak</code> are made verbose, behaving like <code>cluck</code> and <code>confess</code>.</p> <h1 id="METHODS">METHODS</h1> <p><a href="/pod/Carp::Always">Carp::Always</a> implements the following methods.</p> <h2 id="import">import</h2> <pre><code>Carp::Always->import()</code></pre> <p>Enables <a href="/pod/Carp::Always">Carp::Always</a>. Also triggered by statements like</p> <pre><code>use Carp::Always; use Carp::Always 0.14;</code></pre> <p>but not by</p> <pre><code>use Carp::Always (); # does not invoke import()</code></pre> <h2 id="unimport">unimport</h2> <pre><code>Carp::Always->unimport();</code></pre> <p>Disables <a href="/pod/Carp::Always">Carp::Always</a>. Also triggered with</p> <pre><code>no Carp::Always;</code></pre> <h1 id="ACKNOWLEDGMENTS">ACKNOWLEDGMENTS</h1> <p>This module was born as a reaction to a release of <a href="/pod/Acme::JavaTrace">Acme::JavaTrace</a> by Sébastien Aperghis-Tramoni. Sébastien also has a newer module called <a href="/pod/Devel::SimpleTrace">Devel::SimpleTrace</a> with the same code and fewer flame comments on docs. The pruning of the uselessly long docs of this module was prodded by Michael Schwern.</p> <p>Schwern and others told me "the module name stinked" - it was called <code>Carp::Indeed</code>. After thinking long and getting nowhere, I went with nuffin's suggestion and now it is called <code>Carp::Always</code>.</p> <h1 id="SEE-ALSO"><a id="SEE"></a>SEE ALSO</h1> <p><a href="/pod/Carp">Carp</a></p> <p><a href="/pod/Acme::JavaTrace">Acme::JavaTrace</a> and <a href="/pod/Devel::SimpleTrace">Devel::SimpleTrace</a></p> <p><a href="/pod/Carp::Always::Color">Carp::Always::Color</a></p> <p><a href="/pod/Carp::Source::Always">Carp::Source::Always</a></p> <p><a href="/pod/Devel::Confess">Devel::Confess</a></p> <p><a href="/pod/Carp::Always::SyntaxHighlightSource">Carp::Always::SyntaxHighlightSource</a> and <a href="/pod/Carp::Always::DieOnly">Carp::Always::DieOnly</a></p> <h1 id="BUGS">BUGS</h1> <ul> <li><p>This module does not play well with other modules which fusses around with <code>warn</code>, <code>die</code>, <code>$SIG{__WARN__}</code>, <code>$SIG{__DIE__}</code>.</p> </li> <li><p>Test scripts are good. I should write more of these.</p> </li> </ul> <p>Please report bugs via GitHub <a href="https://github.com/aferreira/cpan-Carp-Always/issues">https://github.com/aferreira/cpan-Carp-Always/issues</a></p> <p>Backlog in CPAN RT: <a href="https://rt.cpan.org/Public/Dist/Display.html?Name=Carp-Always">https://rt.cpan.org/Public/Dist/Display.html?Name=Carp-Always</a></p> <h1 id="AUTHOR">AUTHOR</h1> <p>Adriano Ferreira, <ferreira@cpan.org></p> <h1 id="COPYRIGHT-AND-LICENSE"><a id="COPYRIGHT"></a>COPYRIGHT AND LICENSE</h1> <p>Copyright (C) 2005-2013, 2018 by Adriano Ferreira</p> <p>This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.</p></div> <div id="metacpan_install-instructions-dialog" class="modal fade"> <div class="modal-dialog"> <div class="modal-content"> <div class="modal-header"> <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button> <h4 class="modal-title">Module Install Instructions</h4> </div> <div class="modal-body"> <p>To install Carp::Always, copy and paste the appropriate command in to your terminal.</p> <p><a href="/dist/App-cpanminus/view/bin/cpanm">cpanm</a></p> <pre><code>cpanm Carp::Always</code></pre> <p><a href="/pod/CPAN">CPAN shell</a></p> <pre><code>perl -MCPAN -e shell install Carp::Always</code></pre> <p>For more information on module installation, please visit <a href="https://www.cpan.org/modules/INSTALL.html">the detailed CPAN module installation guide</a>.</p> </div> <div class="modal-footer"> <a href="#" data-dismiss="modal" class="btn">Close</a> </div> </div> </div> </div> </main> <div class="content-pagination"> </div> </div> <footer class="footer"> <div class="footer-container"> <div class="footer-social"> <div class="footer-link footer-logo"> <a href="/"> <img src="/static/images/metacpan-logo.svg" alt="MetaCPAN" /> </a> </div> <a class="footer-social-link" href="https://github.com/metacpan"> <i class="fab fa-github-square"></i> </a> <a class="footer-social-link" href="https://fosstodon.org/@metacpan"> <i class="fab fa-mastodon"></i> </a> </div> <div class="footer-links"> <div class="footer-link"> <a href="/about">About</a> </div> <div class="footer-link"> <a href="/about/sponsors">Sponsor</a> </div> <div class="footer-link"> <a href="https://grep.metacpan.org">grep::cpan</a> </div> <div class="footer-link"> <a href="/recent">Recent</a> </div> <div class="footer-link"> <a href="/about/faq">FAQ</a> </div> <div class="footer-link"> <a href="/tools">Tools</a> </div> <div class="footer-link"> <a href="https://fastapi.metacpan.org/">API</a> </div> <div class="footer-link"> <a href="https://www.perl.org/">Perl.org</a> </div> </div> <div class="footer-sponsors"> <a class="footer-sponsor-link" target="_blank" href="https://www.bytemark.co.uk/" rel="noopener"> <img class="footer-sponsor-bytemark" src="/static/images/sponsors/bytemark_logo.svg" alt="Bytemark logo"> </a> <a class="footer-sponsor-link" target="_blank" href="https://www.liquidweb.com/" rel="noopener"> <img class="footer-sponsor-liquidweb" src="/static/images/sponsors/liquidweb_logo.png" alt="liquidweb logo"> </a> <a class="footer-sponsor-link" target="_blank" href="https://deriv.com/careers/" rel="noopener"> <img class="footer-sponsor-deriv" src="/static/images/sponsors/deriv.svg" alt="Deriv logo"> </a> <a class="footer-sponsor-link" target="_blank" href="https://geocode.xyz" rel="noopener"> <img class="footer-sponsor-geocode" src="/static/images/sponsors/geocodelogo.svg" alt="Geocode logo"> </a> <a class="footer-sponsor-link" target="_blank" href="https://www.fastly.com/" rel="noopener"> <img class="footer-sponsor-fastly" src="/static/images/sponsors/fastly_logo.svg" alt="Fastly logo"> </a> <a class="footer-sponsor-link" target="_blank" href="https://opencagedata.com" rel="noopener"> <img class="footer-sponsor-opencage" src="/static/images/sponsors/open-cage.svg" alt="OpenCage logo"> </a> <!-- Added 2024-07-22 --> <a class="footer-sponsor-link" target="_blank" href="https://www.elastic.co/" rel="noopener"> <img class="footer-sponsor-elastic" src="/static/images/sponsors/elastic.svg" alt="Elastic logo"> </a> <!-- Added 2024-07-22 --> <a class="footer-sponsor-link" target="_blank" href="https://route4me.com/" rel="noopener"> <img class="footer-sponsor-route4me" src="/static/images/sponsors/route4me.png" alt="Route4Me logo"> </a> </div> </div> </footer> <div class="modal fade" tabindex="-1" role="dialog" id="metacpan_keyboard-shortcuts"> <div class="modal-dialog"> <div class="modal-content"> <div class="modal-header"> <button type="button" class="close" data-dismiss="modal">×</button> <h4 class="modal-title">Keyboard Shortcuts</h4> </div> <div class="modal-body row"> <div class="col-md-6"> <table class="table keyboard-shortcuts"> <thead> <tr> <th></th> <th>Global</th> </tr> </thead> <tbody> <tr> <td class="keys"> <kbd>s</kbd> </td> <td>Focus search bar</td> </tr> <tr> <td class="keys"> <kbd>?</kbd> </td> <td>Bring up this help dialog</td> </tr> </tbody> </table> <table class="table keyboard-shortcuts"> <thead> <tr> <th></th> <th>GitHub</th> </tr> </thead> <tbody> <tr> <td class="keys"> <kbd>g</kbd> <kbd>p</kbd> </td> <td>Go to pull requests</td> </tr> <tr> <td class="keys"> <kbd>g</kbd> <kbd>i</kbd> </td> <td>go to github issues (only if github is preferred repository)</td> </tr> </tbody> </table> </div> <div class="col-md-6"> <table class="table keyboard-shortcuts"> <thead> <tr> <th></th> <th>POD</th> </tr> </thead> <tbody> <tr> <td class="keys"> <kbd>g</kbd> <kbd>a</kbd> </td> <td>Go to author</td> </tr> <tr> <td class="keys"> <kbd>g</kbd> <kbd>c</kbd> </td> <td>Go to changes</td> </tr> <tr> <td class="keys"> <kbd>g</kbd> <kbd>i</kbd> </td> <td>Go to issues</td> </tr> <tr> <td class="keys"> <kbd>g</kbd> <kbd>d</kbd> </td> <td>Go to dist</td> </tr> <tr> <td class="keys"> <kbd>g</kbd> <kbd>r</kbd> </td> <td>Go to repository/SCM</td> </tr> <tr> <td class="keys"> <kbd>g</kbd> <kbd>s</kbd> </td> <td>Go to source</td> </tr> <tr> <td class="keys"> <kbd>g</kbd> <kbd>b</kbd> </td> <td>Go to file browse</td> </tr> </tbody> </table> </div> <div class="col-md-12"> <table class="table keyboard-shortcuts"> <thead> <tr> <th></th> <th>Search terms</th> </tr> </thead> <tbody> <tr> <td><em>module:</em> (e.g. <a href="/search?q=module%3APlugin">module:Plugin</a>)</td> </tr> <tr> <td><em>distribution:</em> (e.g. <a href="/search?q=distribution%3ADancer+auth">distribution:Dancer auth</a>)</td> </tr> <tr> <td><em>author:</em> (e.g. <a href="/search?q=author%3ASONGMU+Redis">author:SONGMU Redis</a>)</td> </tr> <tr> <td><em>version:</em> (e.g. <a href="/search?q=version%3A1.00">version:1.00</a>)</td> </tr> </tbody> </table> </div> </div> <div class="modal-footer"></div> </div> </div> </div> </body> </html>