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

bs-rebel

v0.2.3

Published

A toolkit for collections for bsb-native and bsb aimed at bundle size and performance

Downloads

263

Readme

bs-rebel

Rebel is a toolkit for collection APIs that work with both bsb-native and bsb.

When you're aiming to write libraries with BuckleScript you're often made to choose between using convenient APIs that only work when compiling to JS, like Js.Array or to include more bs-platform/lib code, like Array or Belt.

Think of Rebel as a standard library wrapper. It aims to use JS built-ins as often as possible, but falls back to using the BuckleScript standard library on native.

(Its name comes from "Re" as in "Reason" and "bel" as in "belt")

Getting Started

Install the library from npm:

yarn add bs-rebel
# or for npm
npm install --save bs-rebel

And add bs-rebel to your bsconfig.json

{
  "name": "<your name>",
  "version": "0.1.0",
  "sources": ["src"],
  "bsc-flags": ["-bs-super-errors"],
  "bs-dependencies": [
+    "bs-rebel"
  ]
}

All of Rebel's module are namespaced as Rebel, so for instance to access the MutableQueue module use: Rebel.MutableQueue

Supported APIs

MutableQueue

See Belt.MutableQueue for this module's signature.

In JS, this module uses externals to mirror as many functions from the Belt module as possible. The only functions that don't completely compile away (but are rather small) are reduce, reduceU, and transfer.

It also adds an addMany function that does compile away, but isn't part of the standard Belt.MutableQueue module.

MutableStack

See Belt.MutableStack for this module's signature.

In JS, this module uses externals to mirror as many functions from the Belt module as possible. The only functions that don't completely compile away (but are rather small) are isEmpty and top.

It does not implement dynamicPopIterU and dynamicPopIter.

Array

See Rebel_types.re for this module's signature. Unfortunately there are no auto-generated docs yet.

This module slightly diverges from Array, Js.Array, and Belt.Array. It tries to match the implementation of the JS Array methods as closely as possible. However, there are some in-place modification methods that are not implemented in Belt.Array and are thus not included in Rebel.Array.

Other methods like filter and removeCount are present though.

The JS externals that don't compile away completely are:

  • set (as opposed to setUnsafe which compiles away)
  • reverse (as opposed to reverseInPlace which compiles away)
  • remove (as opposed to removeInPlace which compiles away)
  • removeCount (as opposed to removeCountInPlace which compiles away)
  • shuffle
  • shuffleInPlace
  • make
  • set
  • includes

Some JS-only methods are for completeness' sake still included in Rebel.Array.Js, but they won't be available during native compilation!