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

famitone2-tools-emscripten

v1.0.4

Published

Famitone2 tools compiled with emscripten and hooked into javascript for use in the browser or node

Downloads

15

Readme

Famitone2 tools via emscripten

This is a quick hack of shiru's neslib tools to work within emscripten. This will allow them to be loaded in javascript/web applications, and used as appropriate.

The original tools were released into the Public Domain, so they are used with permission. I am releasing this under MIT, though if for some reason that's restrictive for you, you are welcome to contact me to use another license.

How's it work?

Basically, the original files are patched slightly to run on linux (mostly removing an unused import and swapping out a method), then compiled with emscripten and made available as a library.

emscripten does come with a bit of overhead - the tools each cost about 200kb - which is pretty big when considering web tooling. The library makes an effort to only load the large files when necessary, so the browser won't be bogged down until the user needs this.

Library Methods

nsf2data (sound effect conversion)

Usage: nsf2data(nsfData, options)

nsfData: A uint8Array of data that a nsf file contains. If you're using node, you can get it like this:

const nsfData = Uint8Array.from(fs.readFileSync('/path/to/sfx.nsf'))

Options: An object with parameters to configure the nsf generation

| option | Potential Values | Description | |----------------|------------------|------------------------------------------------| | assembler | asm6 or ca65 | Which assembler to build for (Default: ca65) | | ntscOnly | true or false| Whether to generate only ntsc (Default: false) | | palOnly | true or false| Whether to generate only pal (Default: false) | | moduleSettings | Any object | Settings to pass through to emscripten's module|

Returns: An object in the following format:

{
    data: "; Assembly file output...", // This is the full text file output, in string form
    size: 500, // How many bytes the exported data takes up
    effects: 5 // How many sound effects were converted
}

Example:

const testNsf = Uint8Array.from(fs.readFileSync('/path/to/file.nsf'))
const result = await nsf2data(testNsf, {assembler: 'ca65', ntscOnly: true})
console.log(result)

text2data (music conversion)

Usage: text2data(textData, options)

textData: A string of music data usually found in music.txt. If you're using node, you can get it like this:

const textData = fs.readFileSync('/path/to/music.txt').toString()

Options: An object with parameters to configure the nsf generation

| option | Potential Values | Description | |-----------------|-------------------|------------------------------------------------------------------| | assembler | asm6 or ca65 | Which assembler to build for (Default: ca65) | | separateFiles | true or false | Whether to break each song into a separate file (Default: false) | | channels | Number 1-5 | The number of channels to include (Default: 5) | | musicName | Any string | The name to use for the exported data. Will be postfixed with _data (Default: music) | | moduleSettings | Any object | Settings to pass through to emscripten's module |

Returns: An object in the following format:

 {
    data: "; Assembly file output...", // This is the full text file output, in string form
    dataSize: 2000, // How many bytes the exported data takes up
    dpcmSize: 50, // How many bytes dcpm takes up 
    songs: 5 // How many songs were converted
}

If separateFiles is set to true, data will take a different format:

{
    data: [
        "; Assembly file output 1...", // This is the full text file output, in string form
        "; Assembly file output 2...",
    ],
    size: 2000, // How many bytes the exported data takes up
    songs: 5 // How many songs were converted
}

nesasmc (Convert nesasm to ca65 and asm6)

This is a little helper that came with the tool, which I believe was used on famitone2 itself. This is included in case you find it useful.

It has no specific options, just pass it an assembly file. Less checking is done on this than on // others. It also has no output, so we don't provide much. But, if you need it, it's here.

Usage: nesasmc(textData)

textData: A valid nesasm program, in a string.

Options: An object with parameters to configure asm conversion | option | Potential Values | Description | |-----------------|-------------------|-------------------------------------------------| | moduleSettings | Any object | Settings to pass through to emscripten's module |

Returns: An object in the following format:

{
    ca65: "; ca65 code" // Source code in ca65 format
    asm6: "; asm6 code" // Source code in asm6 format
}

License

This code is released under the MIT license. See details in the license file.