63 releases (37 stable)

9.1.2 Nov 26, 2024
9.0.0 Aug 2, 2024
8.0.1 Apr 2, 2024
8.0.0 Mar 22, 2024
0.3.2 Jul 15, 2016

#25 in Web programming

Download history 184984/week @ 2024-09-26 207002/week @ 2024-10-03 196633/week @ 2024-10-10 207458/week @ 2024-10-17 235849/week @ 2024-10-24 200958/week @ 2024-10-31 219084/week @ 2024-11-07 236429/week @ 2024-11-14 190234/week @ 2024-11-21 131711/week @ 2024-11-28 207074/week @ 2024-12-05 232741/week @ 2024-12-12 94662/week @ 2024-12-19 70695/week @ 2024-12-26 202469/week @ 2025-01-02 233299/week @ 2025-01-09

641,324 downloads per month
Used in 358 crates (29 directly)

BSD-3-Clause

155KB
3.5K SLoC

sourcemap

This library implements basic processing of JavaScript sourcemaps.

Installation

The crate is called sourcemap and you can depend on it via cargo:

[dependencies]
sourcemap = "*"

If you want to use the git version:

[dependencies.sourcemap]
git = "https://github.com/getsentry/rust-sourcemap.git"

Basic Operation

This crate can load JavaScript sourcemaps from JSON files. It uses serde for parsing of the JSON data. Due to the nature of sourcemaps the entirety of the file must be loaded into memory which can be quite memory intensive.

Usage:

use sourcemap::SourceMap;
let input: &[_] = b"{
    \"version\":3,
    \"sources\":[\"coolstuff.js\"],
    \"names\":[\"x\",\"alert\"],
    \"mappings\":\"AAAA,GAAIA,GAAI,EACR,IAAIA,GAAK,EAAG,CACVC,MAAM\"
}";
let sm = SourceMap::from_reader(input).unwrap();
let token = sm.lookup_token(0, 0).unwrap(); // line-number and column
println!("token: {}", token);

Features

Functionality of the crate can be turned on and off by feature flags. This is the current list of feature flags:

  • ram_bundle: turns on RAM bundle support

License: BSD-3-Clause

Dependencies

~4–5MB
~100K SLoC