npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

catcher-in-the-try

v1.1.2

Published

Catch Javascript errors in the browser. All of them. With real stack traces!

Downloads

14

Readme

Catcher in the try

Ever used window.onerror? It sucks. You don't get stack traces, or anything resembling a real Error object. Catcher in the try solves this problem by maniulating JS source code to properly track the full exception object all the way up to your custom error handler.

Example:

window.addEventListener('citt', function(e) {
  console.log('Look maw, full error objects!');
  console.log(e.detail.stack);
}, false);

(And before you ask, yes, it works with jQuery too).

Usage

There's both a client side piece, and a backend piece that need to be wired up for everything to work correctly.

Client Side

Listen for the citt event on the window, as in the above example. There are no libraries to include; CITT will inject its required code automatically when you call the wrap functions.

Backend

There are a couple different ways to hook things up:

var citt = require('catcher-in-the-try');

// This will asynchronously read in a file and apply CITT to it.  If
// there were no errors, you get back the modified source code.
citt.wrapFile('foo.js', function(err, src) {  });

// This synchronously applies CITT to a piece of source code
var src = citt.wrapSrc('var a = 1;');

// This synchronously applies CITT to a piece of AST conforming to
// the Mozilla Parser API spec.
citt.wrap(require('acorn').parse('var a = 1;'));

If CITT is part of a larger asset pipeline that already uses the Mozilla Parser API, you probably want to user the latter for (citt.wrap). It plays nicely with esprima, esmangle, etc. and also preserves location information in the tree.

If you want things a bit more standalone, use the citt.wrapSrc or citt.wrapFile functions. Note that these do not deal with source mapping, so if you're using this as part of a pipeline you want to put CITT before any minification step (which is a good idea anyway, as it will save you more space).

Browser Support

Works in modern browsers, should work in all older IEs as well, though I haven't really tested them thoroughly.

Installation

npm install catcher-in-the-try

How it works

Every single function is wrapped in a try-catch block that simply sets window._citt to the Error object that it caught, and then rethrows.

An error handler is attached to the window that simply looks for this _citt variable, and passes it on to the custom error handler.

Pretty easy! If you want to see this better for yourself, run this from node:

var citt = require('catcher-in-the-try');
var src = citt.wrapSrc('setTimeout(function() { throw new Error() }, 100)');
console.log(src);

License

Public domain, see license.txt for details.

Developed and open sourced at Vizify, from Portland with love.