From e0160795aa7511c0245d2e6a144cc45838065e9c Mon Sep 17 00:00:00 2001 From: JohnTheCoolingFan Date: Sat, 7 Oct 2023 14:40:00 +0300 Subject: [PATCH 1/2] fix: use wasm-bindgen for Shape limitations instead of wasm32 target arch Only when doing JS stuff using wasm-bindgen we need to remove the custom function implementation --- src/convert/mod.rs | 18 ++++++++---------- 1 file changed, 8 insertions(+), 10 deletions(-) diff --git a/src/convert/mod.rs b/src/convert/mod.rs index 0b28cbf..01d6043 100644 --- a/src/convert/mod.rs +++ b/src/convert/mod.rs @@ -31,12 +31,10 @@ pub type ModuleFunction = fn(usize, usize, Module) -> String; #[cfg(all(target_arch = "wasm32", feature = "wasm-bindgen"))] use wasm_bindgen::prelude::*; -// TODO: Find a way to use the same enum for wasm and not wasm -// Current bug being that wasm_bindgen & #[cfg(not(target_arch = "wasm32"))] are not compatible(?) /// Different possible Shapes to represent modules in a [`crate::QRCode`] -#[cfg(target_arch = "wasm32")] #[repr(C)] -#[cfg_attr(feature = "wasm-bindgen", wasm_bindgen)] +#[wasm_bindgen] +#[cfg(feature = "wasm-bindgen")] #[derive(Debug, Clone, Copy, PartialEq, Eq, Ord, PartialOrd)] pub enum Shape { /// Square Shape @@ -54,7 +52,7 @@ pub enum Shape { } /// Different possible Shapes to represent modules in a [`crate::QRCode`] -#[cfg(not(target_arch = "wasm32"))] +#[cfg(not(feature = "wasm-bindgen"))] #[derive(Debug, Clone, Copy, PartialEq, Eq, Ord, PartialOrd)] pub enum Shape { /// Square Shape @@ -93,6 +91,7 @@ pub enum Shape { /// Command(ModuleFunction), } + impl From for usize { fn from(shape: Shape) -> Self { match shape { @@ -102,7 +101,7 @@ impl From for usize { Shape::Vertical => 3, Shape::Horizontal => 4, Shape::Diamond => 5, - #[cfg(not(target_arch = "wasm32"))] + #[cfg(not(feature = "wasm-bindgen"))] Shape::Command(_) => 6, } } @@ -133,7 +132,7 @@ impl From for &str { Shape::Vertical => "vertical", Shape::Horizontal => "horizontal", Shape::Diamond => "diamond", - #[cfg(not(target_arch = "wasm32"))] + #[cfg(not(feature = "wasm-bindgen"))] Shape::Command(_) => "command", } } @@ -180,7 +179,7 @@ impl Deref for Shape { fn deref(&self) -> &Self::Target { let index: usize = (*self).into(); match self { - #[cfg(not(target_arch = "wasm32"))] + #[cfg(not(feature = "wasm-bindgen"))] Self::Command(func) => func, _ => &Self::FUNCTIONS[index], } @@ -188,8 +187,7 @@ impl Deref for Shape { } /// Different possible image background shapes -#[cfg_attr(target_arch = "wasm32", repr(C))] -#[cfg_attr(all(target_arch = "wasm32", feature = "wasm-bindgen"), wasm_bindgen)] +#[cfg_attr(feature = "wasm-bindgen", repr(C), wasm_bindgen)] #[derive(Debug, Clone, Copy, PartialEq, Eq, Ord, PartialOrd)] pub enum ImageBackgroundShape { /// Square shape From 67a1d46d4267d9bf062c5577a7d54b9586847931 Mon Sep 17 00:00:00 2001 From: JohnTheCoolingFan Date: Mon, 9 Oct 2023 14:53:09 +0300 Subject: [PATCH 2/2] fix: disable criterion's `rayon` feature on wasm --- Cargo.toml | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/Cargo.toml b/Cargo.toml index a67af8b..9303cef 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -42,9 +42,14 @@ wasm-opt = ["-Oz"] [dev-dependencies] base64 = "0.21.3" -criterion = "0.4" qrcode = "0.12.0" +[target.'cfg(target_arch = "wasm32")'.dev-dependencies] +criterion = { version = "0.4", default-features = false, features = ["cargo_bench_support", "plotters"]} + +[target.'cfg(not(target_arch = "wasm32"))'.dev-dependencies] +criterion = "0.4" + [[bench]] name = "qr" harness = false