Skip to content
This repository has been archived by the owner on Jun 1, 2021. It is now read-only.
/ catcher-in-the-try Public archive

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

License

Notifications You must be signed in to change notification settings

shz/catcher-in-the-try

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

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.

About

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

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published