An npm library to sniff the file format of a binary buffer.
import { sniffBytes, FileFormat } from 'sniff-bytes';
const IMAGE: string = `
P6
200 300
255
`.trim();
const BYTES: Uint8Array = new TextEncoder('utf-8').encode(IMAGE);
const FORMAT: FileFormat = sniffBytes(BYTES.buffer);
console.log(FORMAT);
// {
// name: 'Portable PixMap',
// shortName: 'PPM',
// mediaType: 'image/x-portable-pixmap',
// extension: 'ppm'
// }
- To build locally, run
npm run debug
. - To publish a new patch version, run
npm run release-patch
. - To publish a new minor version, run
npm run release-minor
. - To publish a new major version, run
npm run release-major
. - To publish a custom version, run
npm run release -- NNN
whereNNN
is the desired version number.
This repo also serves as a simple example for using Neon to build portable binary npm libraries implemented in Rust.
To build one of your own, follow this general recipe:
- Create a GitHub repo.
- Create a new free npm organization called
@mylib
, replacingmylib
with your library's name. - Create a classic npm automation token and save it as a repo token
NPM_TOKEN
in the GitHub repo secrets. - Copy this repo's structure.
- Change the
package.json
'sneon.targets
entry to replace@sniff-bytes
with@mylib
, again replacingmylib
with your library's name. - Change the
package.json
andREADME.md
of each binary prebuild package in thenpm
directory to replacesniff-bytes
withmylib
, again replacingmylib
with your library's name. - Edit
src/lib.rs
(the Rust implementation of the binary module) andlib/index.cjs
(the JavaScript wrapper) as you like. - Edit
types/index.d.cts
as appropriate to provide types for the (CommonJS) exports oflib/index.cjs
andtypes/index.d.mts
to re-export the (ESM) exports. - Edit the array of exports in
lib/load.cjs
to the complete set of exports ofindex.cjs
.
(Many of these steps may still be automated by future versions of @neon-rs/cli
.)
MIT