From 8471e88d8435d8c4517d52d246ed810336595b4e Mon Sep 17 00:00:00 2001 From: stefanoviv Date: Tue, 23 Jan 2024 19:57:54 +0100 Subject: [PATCH 1/3] Add js/rust bindings for inline source map generation --- src/bindings.rs | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/bindings.rs b/src/bindings.rs index a546d91..faa0a44 100644 --- a/src/bindings.rs +++ b/src/bindings.rs @@ -86,13 +86,13 @@ impl Preprocessor { Self {} } - pub fn process(&self, src: String, filename: Option) -> Result { + pub fn process(&self, src: String, filename: Option, inline_source_map: bool) -> Result { let preprocessor = CorePreprocessor::new(); let result = preprocessor.process( &src, Options { filename: filename.map(|f| f.into()), - inline_source_map: false, + inline_source_map, }, ); @@ -112,7 +112,7 @@ impl Preprocessor { inline_source_map: false, }, ) - .map_err(|_err| self.process(src, filename).unwrap_err())?; + .map_err(|_err| self.process(src, filename, false).unwrap_err())?; let serialized = serde_json::to_string(&result) .map_err(|err| js_error(format!("Unexpected serialization error; please open an issue with the following debug info: {err:#?}").into()))?; Ok(json_parse(serialized.into())) From 786e5855a33eee1fe674868bf759e057267410cf Mon Sep 17 00:00:00 2001 From: stefanoviv Date: Wed, 24 Jan 2024 00:43:12 +0100 Subject: [PATCH 2/3] Convert second argument to options object for both functions --- Cargo.lock | 1 + Cargo.toml | 1 + package-lock.json | 4 ++-- package.json | 4 ++-- pkg/node.cjs | 24 ++++++++++++++++++++++++ pkg/standalone.js | 24 ++++++++++++++++++++++-- src/bindings.rs | 34 ++++++++++++++++++++++++++-------- test/parse.test.js | 2 +- test/process.test.js | 18 ++++++++++++++++-- 9 files changed, 95 insertions(+), 17 deletions(-) create mode 100644 pkg/node.cjs diff --git a/Cargo.lock b/Cargo.lock index ff2534d..a8abab4 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -283,6 +283,7 @@ dependencies = [ "js-sys", "lazy_static", "serde", + "serde-wasm-bindgen", "serde_json", "swc", "swc_atoms", diff --git a/Cargo.toml b/Cargo.toml index 4b6249b..55f57e1 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -35,6 +35,7 @@ lazy_static = "1.4.0" base64 = "0.21.4" serde = { version = "1.0", features = ["derive"] } serde_json = "1.0" +serde-wasm-bindgen = "0.4" wasm-bindgen = "0.2.63" js-sys = "0.3.64" diff --git a/package-lock.json b/package-lock.json index 0bf3765..ee67ef5 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "content-tag", - "version": "1.2.1", + "version": "1.2.2", "lockfileVersion": 3, "requires": true, "packages": { "": { "name": "content-tag", - "version": "1.2.1", + "version": "1.2.2", "license": "MIT", "devDependencies": { "@arethetypeswrong/cli": "^0.13.2", diff --git a/package.json b/package.json index e94792a..a199647 100644 --- a/package.json +++ b/package.json @@ -13,11 +13,11 @@ "import": { "types": "./index.d.ts", "browser": "./pkg/standalone.js", - "default": "./pkg/node/content_tag.cjs" + "default": "./pkg/node.cjs" }, "require": { "types": "./index.d.ts", - "default": "./pkg/node/content_tag.cjs" + "default": "./pkg/node.cjs" } } }, diff --git a/pkg/node.cjs b/pkg/node.cjs new file mode 100644 index 0000000..86b1043 --- /dev/null +++ b/pkg/node.cjs @@ -0,0 +1,24 @@ +const { Preprocessor: WasmPreprocessor } = require("./node/content_tag.cjs"); + +const defaultOptions = { + inline_source_map: false, + filename: null +}; + +class Preprocessor { + #preprocessor; + + constructor() { + this.#preprocessor = new WasmPreprocessor(); + } + + process(str, options = {}) { + return this.#preprocessor.process(str, { ...defaultOptions, ...options }); + } + + parse(str, options = {}) { + return this.#preprocessor.parse(str, { ...defaultOptions, ...options }); + } +} + +module.exports.Preprocessor = Preprocessor; diff --git a/pkg/standalone.js b/pkg/standalone.js index 0df00d7..29449b4 100644 --- a/pkg/standalone.js +++ b/pkg/standalone.js @@ -1,5 +1,25 @@ -import init from "./standalone/content_tag.js"; +import init from "./node/content_tag.js"; +import { Preprocessor as WasmPreprocessor } from "./standalone/content_tag.js"; await init(); -export { Preprocessor } from "./standalone/content_tag.js"; +const defaultOptions = { + inline_source_map: false, + filename: null +}; + +export class Preprocessor { + #preprocessor; + + constructor() { + this.#preprocessor = new WasmPreprocessor(); + } + + process(str, options = {}) { + return this.#preprocessor.process(str, { ...defaultOptions, ...options }); + } + + parse(str, options = {}) { + return this.#preprocessor.parse(str, { ...defaultOptions, ...options }); + } +} diff --git a/src/bindings.rs b/src/bindings.rs index faa0a44..8f82fd2 100644 --- a/src/bindings.rs +++ b/src/bindings.rs @@ -1,5 +1,9 @@ use crate::{Options, Preprocessor as CorePreprocessor}; -use std::{fmt, str}; +use std::{ + fmt, + str, + path::PathBuf, +}; use swc_common::{ errors::Handler, sync::{Lock, Lrc}, @@ -7,6 +11,8 @@ use swc_common::{ }; use swc_error_reporters::{GraphicalReportHandler, GraphicalTheme, PrettyEmitter}; use wasm_bindgen::prelude::*; +use serde::{Serialize, Deserialize}; +use serde_wasm_bindgen::from_value; #[wasm_bindgen] extern "C" { @@ -26,6 +32,12 @@ pub struct Preprocessor { // core: Box, } +#[derive(Serialize, Deserialize)] +pub struct ProcessOptions { + filename: Option, + inline_source_map: bool, +} + #[derive(Clone, Default)] struct Writer(Lrc>); @@ -86,13 +98,16 @@ impl Preprocessor { Self {} } - pub fn process(&self, src: String, filename: Option, inline_source_map: bool) -> Result { + pub fn process(&self, src: String, options: JsValue) -> Result { + let options: ProcessOptions = from_value(options) + .map_err(|e| js_error(format!("Options parsing error: {:?}", e).into()))?; + let preprocessor = CorePreprocessor::new(); let result = preprocessor.process( &src, Options { - filename: filename.map(|f| f.into()), - inline_source_map, + filename: options.filename.map(|f| PathBuf::from(f)), + inline_source_map: options.inline_source_map, }, ); @@ -102,17 +117,20 @@ impl Preprocessor { } } - pub fn parse(&self, src: String, filename: Option) -> Result { + pub fn parse(&self, src: String, options: JsValue) -> Result { + let parse_options: ProcessOptions = from_value(options.clone()) + .map_err(|e| js_error(format!("Options parsing error: {:?}", e).into()))?; + let preprocessor = CorePreprocessor::new(); let result = preprocessor .parse( &src, Options { - filename: filename.as_ref().map(|f| f.into()), - inline_source_map: false, + filename: parse_options.filename.map(|f| PathBuf::from(f)), + inline_source_map: parse_options.inline_source_map, }, ) - .map_err(|_err| self.process(src, filename, false).unwrap_err())?; + .map_err(|_err| self.process(src, options).unwrap_err())?; let serialized = serde_json::to_string(&result) .map_err(|err| js_error(format!("Unexpected serialization error; please open an issue with the following debug info: {err:#?}").into()))?; Ok(json_parse(serialized.into())) diff --git a/test/parse.test.js b/test/parse.test.js index 0e0c716..ac4b25a 100644 --- a/test/parse.test.js +++ b/test/parse.test.js @@ -173,7 +173,7 @@ describe(`parse`, function () { p.process( `const thing = "face";