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 🙏

© 2024 – Pkg Stats / Ryan Hefner

browserify-breakdown

v1.0.4

Published

break down and analyze browserify/browser-pack bundles

Downloads

11

Readme

browserify-breakdown

break down and analyze browserify/browser-pack bundles

npm Build Status Dependency Status devDependency Status

Usage

CLI

browserify main.js > bundle.js
browserify-breakdown < bundle.js

Prints a breakdown of the browser-pack bundle with individual module size and total module size. If the bundle is being created using browserify, the flag --full-paths / option fullPaths may be specified to include module paths in the output instead of integer IDs.

API

var breakdown = require('browserify-breakdown')

breakdown(bundleSrc)

Returns a breakdown of the browser-pack bundle. The returned result is the result of walking through the dependency graph of the bundle with circular dependencies broken.

Each node in the returned result has the following properties:

  • id: The module id.
  • size: The module size, in UTF-8 bytes
  • totalSize: The totalled size of the module and its dependencies, excluding circular and repeated dependencies.
  • deps: An array of the module's dependencies.

The top-level node is a dummy node representing the whole bundle with id=0 and size=0.

breakdown.core(bundleSrc)

The core breakdown function. Useful if you want more information about the nodes in the graph.

Returns an object with the properties:

  • info: Raw information about a module in module-deps format.
  • graph: An adjacency matrix of the initial dependency graph, a directed graph. Entry modules are dependencies of the dummy node entry:. Nodes are simply module IDs.
  • result: Same as the output of the breakdown function. The dummy node entry: is stripped.
  • isolatedNodes: An array with all the isolated modules. Normally, all modules should be a descendant of an entry module or an entry module itself, so this should be empty if that's the case.

Rationale

I created this module as a lower-level alternative to disc, which for some reason always breaks whenever I try to use it. I cannot find any other analyzer for browserify, too. So I intend this to be something a bit better than disc.

  • Plain CLI output via archy (the same thing used by npm ls)
  • What-you-passed-it-is-what-you-get. If you passed browserify --full-paths input, that's fine. If your module IDs are integers, that's fine too... you'll see the integers being used as module IDs. 😜
  • Low-level. Can be easily included into a bigger project that can e.g. provide the same visualization disc does, and possibly more.
  • Hopefully better maintained, or at least maintained as well as the lower-level browserify modules (module-deps, browser-pack, browser-unpack).