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

hammerpack

v0.0.25

Published

Hammerpack is an opinionated development, test, build, and deployment system for javascript projects.

Downloads

52

Readme

Hammerpack

Hammerpack is an opinionated development, test, build, and deployment system for javascript projects.

Warning: Hammerpack is in the alpha stage.

Opinions Matter

Hammerpack is strongly opinionated about the following:

1. Monolithic repositories are better than smaller multiple repositories for each project

If done right, monolithic repositories vastly improve productivity when setting up development environments, building projects, sharing code, sharing third-party dependencies, code discovery, refactoring, testing, and more.

For example, having one package.json in the root of the repository that covers dependencies across all projects has the following advantages:

  • Update a dependency version across all projects at once, ensuring we don't miss any projects especially in case like patching security vulnerabilities.
  • Allows easier development and debugging patterns, such as knowing what version of a library is being used across all the deployed services.
  • Is easier for legal clearance on dependencies in corporate environments.

2. A monolithic repository can consist of several projects targeting different platforms

You no longer need to have your browser, backend, react-native code in separate repositories. By placing them all organized in the same repo, you get the advantage of easier code sharing and better understanding of the entire codebase.

Another advantage you will get is faster development and publishing cycles. For example, with Hammerpack you will now be to use the same commands for developing, testing, building, deploying, and running any type of project. This means faster onboarding of new developers, and using the same scripts in your CI/CD pipelines.

When it comes to developing, building, packaging, and deploying the different types of projects, Hammerpack will ensure there is no leakage of one platform's specific technologies into another platform. This is because Hammerpack will generate optimized builds for the targeted platforms.

3. You should only build and deploy changes

Traditionally, the downside of monolithic repositories is that builds would compile all projects, regardless of whether or not any of the projects have changed. This meant that:

  • Build times would be ridiculous for large projects, even when you make a small change.
  • All projects would need to have their tests rerun, even if none of their shared code or third-party libraries changed.
  • All projects would need to be redeployed, even if none of their shared code or third-party libraries changed.

Hammerpack can detect if there have been any changes to any of the following as compared to previous stages:

  • The project's own code
  • Shared code the project uses
  • Third-party libraries
  • Build dependencies (e.g. base Docker images)
  • Hammerpack library updates

Hammerpack uses the above data to generate a unique hash, which it then uses to track and determine if it should rebuild, retest and redeploy on a per-project basis. This greatly improves CI/CD times.

(This feature is yet to be released)

4. High-coupling is bad

The immediate knee-jerk reaction to monolithic repositories that share code is the concern of high-coupling between code components. Hammerpack is also of the opinion that high-coupling is bad, and that projects need to define clear code boundaries to prevent high-coupling.

This is why Hammerpack takes measures to allow building enforceable code layering constraints. For example, you can tell Hammerpack that your src-web and src-ios folders can use code from src-shared and nothing else. Then, any attempts by a developer to use code from src-web inside the src-ios folder will result in errors.

(This feature is yet to be released)

5. Minimal configuration is good

You should not spend time on configuring tools for development, testing, building, deploying, running. Instead, you should focus on your project.

You should be able to just point Hammerpack to a minimal configuration and it should just work.

Installation

npm install -g hammerpack

License

MIT