From a8bdba4c29dba0ca5e6d49e05029462d89f9cf86 Mon Sep 17 00:00:00 2001 From: Arpad Borsos Date: Mon, 3 Feb 2020 14:26:16 +0100 Subject: [PATCH 1/3] feat: Implement workarounds for dealing with hermes bytecode --- src/utils/sourcemaps.rs | 59 ++++++++++++++++++++++++++++------------- 1 file changed, 41 insertions(+), 18 deletions(-) diff --git a/src/utils/sourcemaps.rs b/src/utils/sourcemaps.rs index 44553f8a1c..a383b3de14 100644 --- a/src/utils/sourcemaps.rs +++ b/src/utils/sourcemaps.rs @@ -269,6 +269,12 @@ pub struct UploadContext<'a> { pub wait: bool, } +fn is_hermes_bytecode(slice: &[u8]) -> bool { + // The hermes bycode format magic is defined here: + // https://github.com/facebook/hermes/blob/5243222ef1d92b7393d00599fc5cff01d189a88a/include/hermes/BCGen/HBC/BytecodeFileFormat.h#L24-L25 + &slice[..8] == 0x1F1903C103BC1FC6u64.to_le_bytes() +} + impl SourceMapProcessor { /// Creates a new sourcemap validator. pub fn new() -> SourceMapProcessor { @@ -320,6 +326,14 @@ impl SourceMapProcessor { || is_likely_minified_js(&contents) { SourceFileType::MinifiedSource + } else if is_hermes_bytecode(&contents) { + // This is actually a big hack: + // For the react-native Hermes case, we skip uploading the bytecode bundle, + // and rather flag it as an empty "minified source". That way, it + // will get a SourceMap reference, and the server side processor + // should deal with it accordingly. + contents.truncate(0); + SourceFileType::MinifiedSource } else { SourceFileType::Source }; @@ -359,22 +373,24 @@ impl SourceMapProcessor { } fn validate_sourcemap(&self, source: &Source) -> Result<(), Error> { - match sourcemap::decode_slice(&source.contents)? { - sourcemap::DecodedMap::Regular(sm) => { - for idx in 0..sm.get_source_count() { - let source_url = sm.get_source(idx).unwrap_or("??"); - if sm.get_source_contents(idx).is_some() - || self.sources.get(source_url).is_some() - { - info!("validator found source ({})", source_url); - } else { - source.warn(format!("missing sourcecode ({})", source_url)); - } + let validate_regular = |sm: &sourcemap::SourceMap| { + for idx in 0..sm.get_source_count() { + let source_url = sm.get_source(idx).unwrap_or("??"); + if sm.get_source_contents(idx).is_some() || self.sources.get(source_url).is_some() { + info!("validator found source ({})", source_url); + } else { + source.warn(format!("missing sourcecode ({})", source_url)); } } + }; + + match sourcemap::decode_slice(&source.contents)? { + sourcemap::DecodedMap::Hermes(smh) => validate_regular(&smh), + sourcemap::DecodedMap::Regular(sm) => validate_regular(&sm), sourcemap::DecodedMap::Index(_) => { source.warn("encountered indexed sourcemap. We cannot validate those.".into()); } + _ => panic!("invalid sourcemap type"), } Ok(()) } @@ -512,11 +528,11 @@ impl SourceMapProcessor { }; let sourcemap_index = match sourcemap::decode_slice(sourcemap_content)? { - sourcemap::DecodedMap::Regular(_) => { + sourcemap::DecodedMap::Index(sourcemap_index) => sourcemap_index, + _ => { warn!("Invalid sourcemap type for RAM bundle, skipping"); return Ok(()); } - sourcemap::DecodedMap::Index(sourcemap_index) => sourcemap_index, }; // We don't need the RAM bundle sourcemap itself @@ -611,12 +627,19 @@ impl SourceMapProcessor { strip_prefixes: prefixes, ..Default::default() }; - let sm = match sourcemap::decode_slice(&source.contents)? { - sourcemap::DecodedMap::Regular(sm) => sm.rewrite(&options)?, - sourcemap::DecodedMap::Index(smi) => smi.flatten_and_rewrite(&options)?, - }; let mut new_source: Vec = Vec::new(); - sm.to_writer(&mut new_source)?; + match sourcemap::decode_slice(&source.contents)? { + sourcemap::DecodedMap::Regular(sm) => { + sm.rewrite(&options)?.to_writer(&mut new_source)? + } + sourcemap::DecodedMap::Hermes(smh) => { + smh.rewrite(&options)?.to_writer(&mut new_source)? + } + sourcemap::DecodedMap::Index(smi) => smi + .flatten_and_rewrite(&options)? + .to_writer(&mut new_source)?, + _ => panic!("invalid sourcemap type"), + }; source.contents = new_source; pb.inc(1); } From 52939d0b5745d384b2827f7737f85207fbf83640 Mon Sep 17 00:00:00 2001 From: Arpad Borsos Date: Tue, 4 Feb 2020 15:10:28 +0100 Subject: [PATCH 2/3] review feedback, remove panics and make clippy happy --- src/utils/sourcemaps.rs | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/src/utils/sourcemaps.rs b/src/utils/sourcemaps.rs index a383b3de14..92a4141fb0 100644 --- a/src/utils/sourcemaps.rs +++ b/src/utils/sourcemaps.rs @@ -272,7 +272,7 @@ pub struct UploadContext<'a> { fn is_hermes_bytecode(slice: &[u8]) -> bool { // The hermes bycode format magic is defined here: // https://github.com/facebook/hermes/blob/5243222ef1d92b7393d00599fc5cff01d189a88a/include/hermes/BCGen/HBC/BytecodeFileFormat.h#L24-L25 - &slice[..8] == 0x1F1903C103BC1FC6u64.to_le_bytes() + slice[..8] == 0x1F19_03C1_03BC_1FC6u64.to_le_bytes() } impl SourceMapProcessor { @@ -332,7 +332,7 @@ impl SourceMapProcessor { // and rather flag it as an empty "minified source". That way, it // will get a SourceMap reference, and the server side processor // should deal with it accordingly. - contents.truncate(0); + contents.clear(); SourceFileType::MinifiedSource } else { SourceFileType::Source @@ -390,7 +390,6 @@ impl SourceMapProcessor { sourcemap::DecodedMap::Index(_) => { source.warn("encountered indexed sourcemap. We cannot validate those.".into()); } - _ => panic!("invalid sourcemap type"), } Ok(()) } @@ -638,7 +637,6 @@ impl SourceMapProcessor { sourcemap::DecodedMap::Index(smi) => smi .flatten_and_rewrite(&options)? .to_writer(&mut new_source)?, - _ => panic!("invalid sourcemap type"), }; source.contents = new_source; pb.inc(1); From ee0199ba77e01d94b9873bd19d382bbac895c3d4 Mon Sep 17 00:00:00 2001 From: Arpad Borsos Date: Thu, 6 Feb 2020 09:43:20 +0100 Subject: [PATCH 3/3] review feedback and dependency bumps --- Cargo.lock | 149 +++++++++++++++++++--------------------- Cargo.toml | 4 +- src/utils/sourcemaps.rs | 5 +- 3 files changed, 74 insertions(+), 84 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 057ebb0e8b..9151c7c25c 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -2,7 +2,7 @@ # It is not intended for manual editing. [[package]] name = "adler32" -version = "1.0.3" +version = "1.0.4" source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] @@ -71,7 +71,7 @@ name = "atty" version = "0.2.13" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -95,7 +95,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "backtrace-sys 0.1.31 (registry+https://github.com/rust-lang/crates.io-index)", "cfg-if 0.1.9 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "rustc-demangle 0.1.15 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -105,7 +105,7 @@ version = "0.1.31" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "cc 1.0.38 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -155,7 +155,7 @@ version = "0.3.2" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "cc 1.0.38 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -164,7 +164,7 @@ version = "0.3.2" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "brotli-sys 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -194,7 +194,7 @@ version = "0.3.3" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "bzip2-sys 0.1.7 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -203,7 +203,7 @@ version = "0.1.7" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "cc 1.0.38 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -226,7 +226,7 @@ name = "chrono" version = "0.4.7" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "num-integer 0.1.41 (registry+https://github.com/rust-lang/crates.io-index)", "num-traits 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", "serde 1.0.98 (registry+https://github.com/rust-lang/crates.io-index)", @@ -257,7 +257,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "atty 0.2.13 (registry+https://github.com/rust-lang/crates.io-index)", "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -278,7 +278,7 @@ dependencies = [ "clicolors-control 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)", "encode_unicode 0.3.5 (registry+https://github.com/rust-lang/crates.io-index)", "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "parking_lot 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)", "regex 1.2.0 (registry+https://github.com/rust-lang/crates.io-index)", "termios 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)", @@ -373,7 +373,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "curl-sys 0.4.20 (registry+https://github.com/rust-lang/crates.io-index)", "kernel32-sys 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "openssl-probe 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", "openssl-sys 0.9.48 (registry+https://github.com/rust-lang/crates.io-index)", "schannel 0.1.15 (registry+https://github.com/rust-lang/crates.io-index)", @@ -387,7 +387,7 @@ version = "0.4.20" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "cc 1.0.38 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "libz-sys 1.0.25 (registry+https://github.com/rust-lang/crates.io-index)", "openssl-sys 0.9.48 (registry+https://github.com/rust-lang/crates.io-index)", "pkg-config 0.3.15 (registry+https://github.com/rust-lang/crates.io-index)", @@ -435,7 +435,7 @@ name = "dirs" version = "1.0.5" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "redox_users 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)", "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -573,12 +573,13 @@ source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] name = "flate2" -version = "1.0.9" +version = "1.0.13" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ + "cfg-if 0.1.9 (registry+https://github.com/rust-lang/crates.io-index)", "crc32fast 1.2.0 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", - "miniz_oxide_c_api 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", + "miniz_oxide 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -621,7 +622,7 @@ version = "0.8.0" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "bitflags 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "libgit2-sys 0.7.11 (registry+https://github.com/rust-lang/crates.io-index)", "log 0.4.8 (registry+https://github.com/rust-lang/crates.io-index)", "url 1.7.2 (registry+https://github.com/rust-lang/crates.io-index)", @@ -659,7 +660,7 @@ name = "hostname" version = "0.1.5" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "winutil 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -798,7 +799,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] name = "libc" -version = "0.2.60" +version = "0.2.66" source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] @@ -806,7 +807,7 @@ name = "libflate" version = "0.1.25" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "adler32 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)", + "adler32 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)", "byteorder 1.3.2 (registry+https://github.com/rust-lang/crates.io-index)", "crc32fast 1.2.0 (registry+https://github.com/rust-lang/crates.io-index)", "rle-decode-fast 1.0.1 (registry+https://github.com/rust-lang/crates.io-index)", @@ -819,7 +820,7 @@ version = "0.7.11" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "cc 1.0.38 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "libz-sys 1.0.25 (registry+https://github.com/rust-lang/crates.io-index)", "pkg-config 0.3.15 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -830,7 +831,7 @@ version = "1.0.25" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "cc 1.0.38 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "pkg-config 0.3.15 (registry+https://github.com/rust-lang/crates.io-index)", "vcpkg 0.2.7 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -895,7 +896,7 @@ name = "memchr" version = "2.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -903,7 +904,7 @@ name = "memmap" version = "0.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -926,21 +927,10 @@ dependencies = [ [[package]] name = "miniz_oxide" -version = "0.3.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -dependencies = [ - "adler32 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)", -] - -[[package]] -name = "miniz_oxide_c_api" -version = "0.2.3" +version = "0.3.6" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "cc 1.0.38 (registry+https://github.com/rust-lang/crates.io-index)", - "crc32fast 1.2.0 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", - "miniz_oxide 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)", + "adler32 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -975,7 +965,7 @@ name = "num_cpus" version = "1.10.1" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -1020,7 +1010,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "autocfg 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)", "cc 1.0.38 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "pkg-config 0.3.15 (registry+https://github.com/rust-lang/crates.io-index)", "vcpkg 0.2.7 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -1062,7 +1052,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "cfg-if 0.1.9 (registry+https://github.com/rust-lang/crates.io-index)", "cloudabi 0.0.3 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "rand 0.6.5 (registry+https://github.com/rust-lang/crates.io-index)", "redox_syscall 0.1.56 (registry+https://github.com/rust-lang/crates.io-index)", "rustc_version 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1077,7 +1067,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "cfg-if 0.1.9 (registry+https://github.com/rust-lang/crates.io-index)", "cloudabi 0.0.3 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "redox_syscall 0.1.56 (registry+https://github.com/rust-lang/crates.io-index)", "rustc_version 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", "smallvec 0.6.10 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1265,7 +1255,7 @@ version = "0.6.5" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "autocfg 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "rand_chacha 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)", "rand_core 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)", "rand_hc 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1320,7 +1310,7 @@ name = "rand_jitter" version = "0.1.4" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "rand_core 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)", "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -1332,7 +1322,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "cloudabi 0.0.3 (registry+https://github.com/rust-lang/crates.io-index)", "fuchsia-cprng 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "rand_core 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)", "rdrand 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)", "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1577,7 +1567,7 @@ dependencies = [ "httpdate 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)", "im 12.3.4 (registry+https://github.com/rust-lang/crates.io-index)", "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "log 0.4.8 (registry+https://github.com/rust-lang/crates.io-index)", "rand 0.6.5 (registry+https://github.com/rust-lang/crates.io-index)", "regex 1.2.0 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1609,7 +1599,7 @@ dependencies = [ "encoding 0.2.33 (registry+https://github.com/rust-lang/crates.io-index)", "failure 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)", "failure_derive 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)", - "flate2 1.0.9 (registry+https://github.com/rust-lang/crates.io-index)", + "flate2 1.0.13 (registry+https://github.com/rust-lang/crates.io-index)", "git2 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)", "glob 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)", "hostname 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1619,7 +1609,7 @@ dependencies = [ "itertools 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)", "java-properties 1.2.0 (registry+https://github.com/rust-lang/crates.io-index)", "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "log 0.4.8 (registry+https://github.com/rust-lang/crates.io-index)", "mac-process-info 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)", "might-be-minified 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1640,8 +1630,8 @@ dependencies = [ "serde_json 1.0.40 (registry+https://github.com/rust-lang/crates.io-index)", "sha1 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)", "signal-hook 0.1.10 (registry+https://github.com/rust-lang/crates.io-index)", - "sourcemap 4.1.0 (registry+https://github.com/rust-lang/crates.io-index)", - "symbolic 7.0.0 (git+https://github.com/getsentry/symbolic?rev=f928869b64f43112ec70ecd87aa24441ebc899e6)", + "sourcemap 5.0.0 (registry+https://github.com/rust-lang/crates.io-index)", + "symbolic 7.0.0 (git+https://github.com/getsentry/symbolic?rev=5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef)", "uname 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)", "unix-daemonize 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", "url 1.7.2 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1739,7 +1729,7 @@ name = "signal-hook" version = "0.1.10" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "signal-hook-registry 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -1749,7 +1739,7 @@ version = "1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "arc-swap 0.3.11 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -1776,14 +1766,14 @@ version = "0.3.10" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "cfg-if 0.1.9 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "redox_syscall 0.1.56 (registry+https://github.com/rust-lang/crates.io-index)", "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "sourcemap" -version = "4.1.0" +version = "5.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "base64 0.10.1 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1841,17 +1831,17 @@ source = "registry+https://github.com/rust-lang/crates.io-index" [[package]] name = "symbolic" version = "7.0.0" -source = "git+https://github.com/getsentry/symbolic?rev=f928869b64f43112ec70ecd87aa24441ebc899e6#f928869b64f43112ec70ecd87aa24441ebc899e6" +source = "git+https://github.com/getsentry/symbolic?rev=5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef#5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef" dependencies = [ - "symbolic-common 7.0.0 (git+https://github.com/getsentry/symbolic?rev=f928869b64f43112ec70ecd87aa24441ebc899e6)", - "symbolic-debuginfo 7.0.0 (git+https://github.com/getsentry/symbolic?rev=f928869b64f43112ec70ecd87aa24441ebc899e6)", - "symbolic-proguard 7.0.0 (git+https://github.com/getsentry/symbolic?rev=f928869b64f43112ec70ecd87aa24441ebc899e6)", + "symbolic-common 7.0.0 (git+https://github.com/getsentry/symbolic?rev=5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef)", + "symbolic-debuginfo 7.0.0 (git+https://github.com/getsentry/symbolic?rev=5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef)", + "symbolic-proguard 7.0.0 (git+https://github.com/getsentry/symbolic?rev=5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef)", ] [[package]] name = "symbolic-common" version = "7.0.0" -source = "git+https://github.com/getsentry/symbolic?rev=f928869b64f43112ec70ecd87aa24441ebc899e6#f928869b64f43112ec70ecd87aa24441ebc899e6" +source = "git+https://github.com/getsentry/symbolic?rev=5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef#5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef" dependencies = [ "debugid 0.5.3 (registry+https://github.com/rust-lang/crates.io-index)", "failure 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1864,12 +1854,12 @@ dependencies = [ [[package]] name = "symbolic-debuginfo" version = "7.0.0" -source = "git+https://github.com/getsentry/symbolic?rev=f928869b64f43112ec70ecd87aa24441ebc899e6#f928869b64f43112ec70ecd87aa24441ebc899e6" +source = "git+https://github.com/getsentry/symbolic?rev=5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef#5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef" dependencies = [ "dmsort 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)", "failure 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)", "fallible-iterator 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)", - "flate2 1.0.9 (registry+https://github.com/rust-lang/crates.io-index)", + "flate2 1.0.13 (registry+https://github.com/rust-lang/crates.io-index)", "gimli 0.19.0 (git+https://github.com/jan-auer/gimli?rev=bf8ea0f0079505681c360d3a55d0ac1e9b498df3)", "goblin 0.1.1 (git+https://github.com/jan-auer/goblin?rev=ee8b997792d37cfb35f8656c028543797425137e)", "lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1882,17 +1872,17 @@ dependencies = [ "serde 1.0.98 (registry+https://github.com/rust-lang/crates.io-index)", "serde_json 1.0.40 (registry+https://github.com/rust-lang/crates.io-index)", "smallvec 0.6.10 (registry+https://github.com/rust-lang/crates.io-index)", - "symbolic-common 7.0.0 (git+https://github.com/getsentry/symbolic?rev=f928869b64f43112ec70ecd87aa24441ebc899e6)", + "symbolic-common 7.0.0 (git+https://github.com/getsentry/symbolic?rev=5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef)", "zip 0.5.2 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] name = "symbolic-proguard" version = "7.0.0" -source = "git+https://github.com/getsentry/symbolic?rev=f928869b64f43112ec70ecd87aa24441ebc899e6#f928869b64f43112ec70ecd87aa24441ebc899e6" +source = "git+https://github.com/getsentry/symbolic?rev=5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef#5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef" dependencies = [ "proguard 2.0.0 (registry+https://github.com/rust-lang/crates.io-index)", - "symbolic-common 7.0.0 (git+https://github.com/getsentry/symbolic?rev=f928869b64f43112ec70ecd87aa24441ebc899e6)", + "symbolic-common 7.0.0 (git+https://github.com/getsentry/symbolic?rev=5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef)", ] [[package]] @@ -1947,7 +1937,7 @@ version = "0.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "kernel32-sys 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "winapi 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -1956,7 +1946,7 @@ name = "termios" version = "0.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -1981,7 +1971,7 @@ name = "time" version = "0.1.42" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", "redox_syscall 0.1.56 (registry+https://github.com/rust-lang/crates.io-index)", "winapi 0.3.7 (registry+https://github.com/rust-lang/crates.io-index)", ] @@ -2006,7 +1996,7 @@ name = "uname" version = "0.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -2045,7 +2035,7 @@ name = "unix-daemonize" version = "0.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -2112,7 +2102,7 @@ version = "2.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "failure 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)", - "libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -2191,7 +2181,7 @@ dependencies = [ ] [metadata] -"checksum adler32 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)" = "7e522997b529f05601e05166c07ed17789691f562762c7f3b987263d2dedee5c" +"checksum adler32 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)" = "5d2e7343e7fc9de883d1b0341e0b13970f764c14101234857d2ddafa1cb1cac2" "checksum advapi32-sys 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)" = "e06588080cb19d0acb6739808aafa5f26bfb2ca015b2b6370028b44cf7cb8a9a" "checksum aho-corasick 0.7.4 (registry+https://github.com/rust-lang/crates.io-index)" = "36b7aa1ccb7d7ea3f437cf025a2ab1c47cc6c1bc9fc84918ff449def12f5e282" "checksum anylog 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)" = "2fcf751df77bc8526b739628305302630756b4d9a1820b7cb87d1d7a2902d0a4" @@ -2259,7 +2249,7 @@ dependencies = [ "checksum fake-simd 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)" = "e88a8acf291dafb59c2d96e8f59828f3838bb1a70398823ade51a84de6a6deed" "checksum fallible-iterator 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)" = "eb7217124812dc5672b7476d0c2d20cfe9f7c0f1ba0904b674a9762a0212f72e" "checksum fallible-iterator 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)" = "4443176a9f2c162692bd3d352d745ef9413eec5782a80d8fd6f8a1ac692a07f7" -"checksum flate2 1.0.9 (registry+https://github.com/rust-lang/crates.io-index)" = "550934ad4808d5d39365e5d61727309bf18b3b02c6c56b729cb92e7dd84bc3d8" +"checksum flate2 1.0.13 (registry+https://github.com/rust-lang/crates.io-index)" = "6bd6d6f4752952feb71363cffc9ebac9411b75b87c6ab6058c40c8900cf43c0f" "checksum fnv 1.0.6 (registry+https://github.com/rust-lang/crates.io-index)" = "2fad85553e09a6f881f739c29f0b00b0f01357c743266d478b68951ce23285f3" "checksum fuchsia-cprng 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "a06f77d526c1a601b7c4cdd98f54b5eaabffc14d5f2f0296febdc7f357c6d3ba" "checksum gcc 0.3.55 (registry+https://github.com/rust-lang/crates.io-index)" = "8f5f3913fa0bfe7ee1fd8248b6b9f42a5af4b9d65ec2dd2c3c26132b950ecfc2" @@ -2285,7 +2275,7 @@ dependencies = [ "checksum kernel32-sys 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)" = "7507624b29483431c0ba2d82aece8ca6cdba9382bff4ddd0f7490560c056098d" "checksum lazy_static 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)" = "bc5729f27f159ddd61f4df6228e827e86643d4d3e7c32183cb30a1c08f604a14" "checksum lazycell 1.2.1 (registry+https://github.com/rust-lang/crates.io-index)" = "b294d6fa9ee409a054354afc4352b0b9ef7ca222c69b8812cbea9e7d2bf3783f" -"checksum libc 0.2.60 (registry+https://github.com/rust-lang/crates.io-index)" = "d44e80633f007889c7eff624b709ab43c92d708caad982295768a7b13ca3b5eb" +"checksum libc 0.2.66 (registry+https://github.com/rust-lang/crates.io-index)" = "d515b1f41455adea1313a4a2ac8a8a477634fbae63cc6100e3aebb207ce61558" "checksum libflate 0.1.25 (registry+https://github.com/rust-lang/crates.io-index)" = "90c6f86f4b0caa347206f916f8b687b51d77c6ef8ff18d52dd007491fd580529" "checksum libgit2-sys 0.7.11 (registry+https://github.com/rust-lang/crates.io-index)" = "48441cb35dc255da8ae72825689a95368bf510659ae1ad55dc4aa88cb1789bf1" "checksum libz-sys 1.0.25 (registry+https://github.com/rust-lang/crates.io-index)" = "2eb5e43362e38e2bca2fd5f5134c4d4564a23a5c28e9b95411652021a8675ebe" @@ -2301,8 +2291,7 @@ dependencies = [ "checksum memmap 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)" = "6585fd95e7bb50d6cc31e20d4cf9afb4e2ba16c5846fc76793f11218da9c475b" "checksum memoffset 0.5.1 (registry+https://github.com/rust-lang/crates.io-index)" = "ce6075db033bbbb7ee5a0bbd3a3186bbae616f57fb001c485c7ff77955f8177f" "checksum might-be-minified 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)" = "885fbcf107091675518e63d521d5f7244efb11a6bd2ee8cbe2f056fddbd4b769" -"checksum miniz_oxide 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)" = "c061edee74a88eb35d876ce88b94d77a0448a201de111c244b70d047f5820516" -"checksum miniz_oxide_c_api 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)" = "6c675792957b0d19933816c4e1d56663c341dd9bfa31cb2140ff2267c1d8ecf4" +"checksum miniz_oxide 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)" = "aa679ff6578b1cddee93d7e82e263b94a575e0bfced07284eb0c037c1d2416a5" "checksum new_debug_unreachable 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)" = "f40f005c60db6e03bae699e414c58bf9aa7ea02a2d0b9bfbcf19286cc4c82b30" "checksum nodrop 0.1.13 (registry+https://github.com/rust-lang/crates.io-index)" = "2f9667ddcc6cc8a43afc9b7917599d7216aa09c463919ea32c59ed6cac8bc945" "checksum num-integer 0.1.41 (registry+https://github.com/rust-lang/crates.io-index)" = "b85e541ef8255f6cf42bbfe4ef361305c6c135d10919ecc26126c4e5ae94bc09" @@ -2392,16 +2381,16 @@ dependencies = [ "checksum sized-chunks 0.1.3 (registry+https://github.com/rust-lang/crates.io-index)" = "9d3e7f23bad2d6694e0f46f5e470ec27eb07b8f3e8b309a4b0dc17501928b9f2" "checksum smallvec 0.6.10 (registry+https://github.com/rust-lang/crates.io-index)" = "ab606a9c5e214920bb66c458cd7be8ef094f813f20fe77a54cc7dbfff220d4b7" "checksum socket2 0.3.10 (registry+https://github.com/rust-lang/crates.io-index)" = "df028e0e632c2a1823d920ad74895e7f9128e6438cbc4bc6fd1f180e644767b9" -"checksum sourcemap 4.1.0 (registry+https://github.com/rust-lang/crates.io-index)" = "4e07b31f3f4820a35de1c21d3023cba2767b9736a2459165aaa3819537cebb28" +"checksum sourcemap 5.0.0 (registry+https://github.com/rust-lang/crates.io-index)" = "8fd57aa9e5cea41b4a3c26a61039fad5585e2154ffe057a2656540a21b03a2d2" "checksum stable_deref_trait 1.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "dba1a27d3efae4351c8051072d619e3ade2820635c3958d826bfea39d59b54c8" "checksum string_cache 0.7.3 (registry+https://github.com/rust-lang/crates.io-index)" = "25d70109977172b127fe834e5449e5ab1740b9ba49fa18a2020f509174f25423" "checksum string_cache_codegen 0.4.2 (registry+https://github.com/rust-lang/crates.io-index)" = "1eea1eee654ef80933142157fdad9dd8bc43cf7c74e999e369263496f04ff4da" "checksum string_cache_shared 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)" = "b1884d1bc09741d466d9b14e6d37ac89d6909cbcac41dd9ae982d4d063bbedfc" "checksum strsim 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)" = "8ea5119cdb4c55b55d432abb513a0429384878c15dde60cc77b1c99de1a95a6a" -"checksum symbolic 7.0.0 (git+https://github.com/getsentry/symbolic?rev=f928869b64f43112ec70ecd87aa24441ebc899e6)" = "" -"checksum symbolic-common 7.0.0 (git+https://github.com/getsentry/symbolic?rev=f928869b64f43112ec70ecd87aa24441ebc899e6)" = "" -"checksum symbolic-debuginfo 7.0.0 (git+https://github.com/getsentry/symbolic?rev=f928869b64f43112ec70ecd87aa24441ebc899e6)" = "" -"checksum symbolic-proguard 7.0.0 (git+https://github.com/getsentry/symbolic?rev=f928869b64f43112ec70ecd87aa24441ebc899e6)" = "" +"checksum symbolic 7.0.0 (git+https://github.com/getsentry/symbolic?rev=5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef)" = "" +"checksum symbolic-common 7.0.0 (git+https://github.com/getsentry/symbolic?rev=5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef)" = "" +"checksum symbolic-debuginfo 7.0.0 (git+https://github.com/getsentry/symbolic?rev=5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef)" = "" +"checksum symbolic-proguard 7.0.0 (git+https://github.com/getsentry/symbolic?rev=5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef)" = "" "checksum syn 0.15.42 (registry+https://github.com/rust-lang/crates.io-index)" = "eadc09306ca51a40555dd6fc2b415538e9e18bc9f870e47b1a524a79fe2dcf5e" "checksum syn 1.0.11 (registry+https://github.com/rust-lang/crates.io-index)" = "dff0acdb207ae2fe6d5976617f887eb1e35a2ba52c13c7234c790960cdad9238" "checksum synstructure 0.10.2 (registry+https://github.com/rust-lang/crates.io-index)" = "02353edf96d6e4dc81aea2d8490a7e9db177bf8acb0e951c24940bf866cb313f" diff --git a/Cargo.toml b/Cargo.toml index adb20199d5..e1070c913b 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -48,8 +48,8 @@ serde = { version = "1.0.98", features = ["derive"] } serde_derive = "1.0.98" serde_json = "1.0.40" sha1 = { version = "0.6.0", features = ["serde"] } -sourcemap = { version = "4.1.0", features = ["ram_bundle"] } -symbolic = { git = "https://github.com/getsentry/symbolic", rev = "f928869b64f43112ec70ecd87aa24441ebc899e6", features = ["debuginfo-serde", "proguard"] } +sourcemap = { version = "5.0.0", features = ["ram_bundle"] } +symbolic = { git = "https://github.com/getsentry/symbolic", rev = "5c8de65b2d4eb3095f2aa0380b35aaed3a9e34ef", features = ["debuginfo-serde", "proguard"] } url = "1.7.2" username = "0.2.0" uuid = { version = "0.7.4", features = ["v4", "serde"] } diff --git a/src/utils/sourcemaps.rs b/src/utils/sourcemaps.rs index 92a4141fb0..c7da2163a6 100644 --- a/src/utils/sourcemaps.rs +++ b/src/utils/sourcemaps.rs @@ -270,9 +270,10 @@ pub struct UploadContext<'a> { } fn is_hermes_bytecode(slice: &[u8]) -> bool { - // The hermes bycode format magic is defined here: + // The hermes bytecode format magic is defined here: // https://github.com/facebook/hermes/blob/5243222ef1d92b7393d00599fc5cff01d189a88a/include/hermes/BCGen/HBC/BytecodeFileFormat.h#L24-L25 - slice[..8] == 0x1F19_03C1_03BC_1FC6u64.to_le_bytes() + const HERMES_MAGIC: [u8; 8] = [0xC6, 0x1F, 0xBC, 0x03, 0xC1, 0x03, 0x19, 0x1F]; + slice.starts_with(&HERMES_MAGIC) } impl SourceMapProcessor {