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

bundown

v0.1.2

Published

Bundown is a fast all-in-one Markdown runtime.

Downloads

9

Readme

Bundown

Bundown is a fast all-in-one Markdown runtime and bundler, built on Bun.

It runs Markdown files, executing their Shell, JavaScript, and TypeScript code blocks.

bundown license bundown package version bundown source code size bundown speed

Installation

You can install bundown (bd) globally using Bun:

bun i -g bundown

Now you should be able to:

  • bundown run to run a Markdown file from a path or URL
  • bundown sync to pack/unpack code between files and Markdown
  • bundown -h to view help
  • bundown upgrade to update Bundown

Links

Changelog

See what's planned in the roadmap.

^0.1.2

  • Improvements
    • bundown --print uses improved box drawing for run & sync code printing.

^0.1.0

  • Features
    • bundown run <file> now aliases bundown <file>.
    • bundown sync synchronizes Markdown codeblocks with actual code files using file tags in the codeblock metadata:
      • --file <file> (-f) in a codeblock meta header sets the corresponding file.
      • bundown <file> does not run code blocks with a --file flag.
      • bundown sync <file> <dir> (over)writes files in <dir> with corresponding codeblocks from <file>.
      • bundown sync <url> <dir> downloads and over(writes) the files in <dir> with codeblocks from <url>.
      • bundown sync --print (-p) pretty-prints the synced files.
    • bundown https://example.com/file.md runs a Markdown file from a URL.
    • bundown --tag <tag> <file> (-t) runs only code blocks with the specified tag.
      • --tag <tag> (-t) in a codeblock meta header tags the codeblock with <tag>.
      • bundown <file> does not run code blocks with a --tag flag.
    • bundown auto-detects operating system and only runs corresponding codeblocks.
      • --os <os> in a codeblock meta header tags the codeblock with <os>.
      • linux and macos/darwin are supported <os> tags.
    • bundown <dir> auto-detects the best potential default file like readme.md and runs it.
  • Improvements
    • bundown now has a block-level args parser for advanced features.
    • bundown now uses abstract syntax trees to parse and manipulate Markdown.
    • bundown --print uses syntax highlighting for code blocks and rich text.
  • Languages
    • bundown can print and sync: c, cuda, c++, c#, css, diff, go, graphql, .gitignore, html, arduino, java, javascript, json, jsx, kotlin, less, lua, makefile, markdown, objective-c, perl, php, python, r, ruby, rust, scss, shell, sql, svg, swift, toml, tsx, typescript, xml, vb.net, wasm, yaml, and many aliases for the aforementioned.

^0.0.10

  • Improvements
    • bundown upgrade fixed.

^0.0.9

  • Improvements
    • bundown checks that the user has bun@^1.0.24 installed and reports a helpful error message if not.

^0.0.8

  • Improvements
    • bundown upgrade upgrades bundown to the latest version.

^0.0.7

  • Improvements
    • package.json now lists runtime dependencies.

^0.0.6

  • Features
    • bundown --version (-v) prints the version of bundown installed.
    • bundown --print <file> (-p) pretty-prints the Markdown and syntax highlighted code blocks.
    • bundown --help (-h) prints a help message.
  • Improvements
    • bundown now uses ANSI colors for more helpful usage messages & pretty-printing.

^0.0.5

  • Features
    • bundown recognizes languages regardless of case, allowing uppercase language names in code blocks.
  • Improvements
    • bundown now uses a single parser loop to run faster in less lines of code.

^0.0.4

  • Features
    • bundown can run multiple instances at once.
    • bundown returns the same exit code as the code it ran.

^0.0.3

  • Improvements
    • bundown has developer tooling including biome code formatting via bundown and a .gitignore file.

^0.0.2

  • Improvements
    • bundown doesn't skip a code block if a supported language is specified in full but has extra whitespace/content on the language line.

^0.0.1

  • Features
    • bundown <file> runs TypeScript, JavaScript, and Shell code blocks in Markdown files.
    • bundown can be installed globally using npm, bun, pnpm, or yarn and run from anywhere.

Contributing

If you have any bugs, feature requests, etc. please open a discussion, issue or pull request as appropriate.

Before you open a PR, use this script to format the code with biome. We use an opinionated style guide, aimed at maximizing the intuitive readability of code and minimizing noisy syntax - follow it.

We also have a roadmap of planned features and bugs we'd like to fix if you'd like to pick one up:

Roadmap

See what's already been done in the changelog. Please suggest changes.

  • Features
    • bundown sync <url> <file> downloads and over(writes) the Markdown file from <url> into <file>.
    • bundown sync <dir> <file> (over)writes codeblocks in <file> with corresponding files from <dir>.
      • --no-new-blocks does not create new codeblocks in <file> for files in <dir> without corresponding codeblocks.
    • bundown sync bundown.md . is used to sync the bundown codebase from a single file.
    • bundown sync --delete deletes files/blocks in the destination that don't exist in the source.
    • bundown --interactive <file> (-i) pretty-prints each code block before running with a Y/N prompt to run it.
    • bundown detects potentially unsafe code and prompts the user to run interactively if so.
    • bundown uses source mapping to deliver helpful and traceable error messages when code blocks or individual lines of code fail.
    • bundown ai uses the core runtime, pretty-printing, and safe execution to deliver a great private, local, open-source alternative interface to LLM chat/search/code apps.
    • ... | bundown can be used to pipe Markdown into bundown instead of using a file path.
    • bundown tasks allows you to view and manage task lists.
    • bundown.config.md allows a user to set a custom color theme for Bundown.
  • Improvements
    • bundown should safely escape the content of Shell code when compiling to TS.
    • bundown --print visually formats Markdown segments (code, links, etc.) beyond just syntax highlighting.
    • bundown --print supports GFM style autolinks.
    • bundown --print supports GFM style task lists.
    • bundown --print supports GFM style tables.
    • bundown --print supports GFM style footnotes.
    • bundown --print converts emoji codes like :fire: to actual emojis.
    • bundown --print pretty-prints math e.g. replacing common TeX characters e.g. \pi to π.
  • Languages
    • bundown shares variables and functions between code blocks, regardless of language.
    • bundown can print and sync: sass, zig, assembly, haskell, lisp, clojure, julia, brainfuck, latex, and more?
    • bundown can run: python, c#, c++, c, zig, rust, php, go, ruby, lua, assembly, wasm, lisp, clojure, julia, brainfuck, and more?

Scripts

If you have Bundown installed, you can run any of the following scripts with bundown -t <script>

Format

We use biome to format our code.

To format all files in the project, make sure you have biome installed and run:

bun x biome format --write .