mirror of
https://github.com/rustwasm/wasm-bindgen.git
synced 2024-12-27 12:06:14 +03:00
d5b81595ec
First added in #161 this never ended up panning out, so let's remove the experimental suport which isn't actually used by anything today and hold off on any other changes until an RFC happens.
211 lines
4.5 KiB
Rust
211 lines
4.5 KiB
Rust
use wasm_bindgen_test::*;
|
|
use wasm_bindgen::prelude::*;
|
|
|
|
#[wasm_bindgen(module = "tests/wasm/slice.js")]
|
|
extern {
|
|
fn js_export();
|
|
|
|
fn js_import();
|
|
|
|
fn js_pass_array();
|
|
|
|
fn js_export_mut();
|
|
|
|
fn js_return_vec();
|
|
}
|
|
|
|
macro_rules! export_macro {
|
|
($(($i:ident, $n:ident))*) => ($(
|
|
#[wasm_bindgen]
|
|
pub fn $n(a: &[$i]) -> Vec<$i> {
|
|
assert_eq!(a.len(), 2);
|
|
assert_eq!(a[0], 1 as $i);
|
|
assert_eq!(a[1], 2 as $i);
|
|
a.to_vec()
|
|
}
|
|
)*)
|
|
}
|
|
|
|
export_macro! {
|
|
(i8, export_i8)
|
|
(u8, export_u8)
|
|
(i16, export_i16)
|
|
(u16, export_u16)
|
|
(i32, export_i32)
|
|
(u32, export_u32)
|
|
(f32, export_f32)
|
|
(f64, export_f64)
|
|
}
|
|
|
|
#[wasm_bindgen_test]
|
|
fn export() {
|
|
js_export();
|
|
}
|
|
|
|
macro_rules! import_macro {
|
|
($(($rust:ident, $js:ident, $i:ident))*) => ($(
|
|
#[wasm_bindgen(module = "tests/wasm/slice.js")]
|
|
extern {
|
|
fn $js(a: &[$i]) -> Vec<$i>;
|
|
}
|
|
|
|
#[wasm_bindgen]
|
|
pub fn $rust(a: &[$i]) -> Vec<$i> {
|
|
assert_eq!(a.len(), 2);
|
|
assert_eq!(a[0], 1 as $i);
|
|
assert_eq!(a[1], 2 as $i);
|
|
$js(a)
|
|
}
|
|
)*)
|
|
}
|
|
|
|
import_macro! {
|
|
(import_rust_i8, import_js_i8, i8)
|
|
(import_rust_u8, import_js_u8, u8)
|
|
(import_rust_i16, import_js_i16, i16)
|
|
(import_rust_u16, import_js_u16, u16)
|
|
(import_rust_i32, import_js_i32, i32)
|
|
(import_rust_u32, import_js_u32, u32)
|
|
(import_rust_f32, import_js_f32, f32)
|
|
(import_rust_f64, import_js_f64, f64)
|
|
}
|
|
|
|
#[wasm_bindgen_test]
|
|
fn import() {
|
|
js_import();
|
|
}
|
|
|
|
macro_rules! pass_array_marco {
|
|
($(($rust:ident, $i:ident))*) => ($(
|
|
#[wasm_bindgen]
|
|
pub fn $rust(a: &[$i]) {
|
|
assert_eq!(a.len(), 2);
|
|
assert_eq!(a[0], 1 as $i);
|
|
assert_eq!(a[1], 2 as $i);
|
|
}
|
|
)*)
|
|
}
|
|
|
|
pass_array_marco! {
|
|
(pass_array_rust_i8, i8)
|
|
(pass_array_rust_u8, u8)
|
|
(pass_array_rust_i16, i16)
|
|
(pass_array_rust_u16, u16)
|
|
(pass_array_rust_i32, i32)
|
|
(pass_array_rust_u32, u32)
|
|
(pass_array_rust_f32, f32)
|
|
(pass_array_rust_f64, f64)
|
|
}
|
|
|
|
#[wasm_bindgen_test]
|
|
fn pass_array() {
|
|
js_pass_array();
|
|
}
|
|
|
|
macro_rules! import_mut_macro {
|
|
($(($rust:ident, $js:ident, $i:ident))*) => (
|
|
$(
|
|
#[wasm_bindgen(module = "tests/wasm/slice.js")]
|
|
extern {
|
|
fn $js(a: &mut [$i]);
|
|
}
|
|
|
|
fn $rust() {
|
|
let mut buf = [
|
|
1 as $i,
|
|
2 as $i,
|
|
3 as $i,
|
|
];
|
|
$js(&mut buf);
|
|
assert_eq!(buf[0], 4 as $i);
|
|
assert_eq!(buf[1], 5 as $i);
|
|
assert_eq!(buf[2], 3 as $i);
|
|
}
|
|
)*
|
|
|
|
#[wasm_bindgen_test]
|
|
fn import_mut() {
|
|
$($rust();)*
|
|
}
|
|
)
|
|
}
|
|
|
|
import_mut_macro! {
|
|
(import_mut_rust_i8, import_mut_js_i8, i8)
|
|
(import_mut_rust_u8, import_mut_js_u8, u8)
|
|
(import_mut_rust_i16, import_mut_js_i16, i16)
|
|
(import_mut_rust_u16, import_mut_js_u16, u16)
|
|
(import_mut_rust_i32, import_mut_js_i32, i32)
|
|
(import_mut_rust_u32, import_mut_js_u32, u32)
|
|
(import_mut_rust_f32, import_mut_js_f32, f32)
|
|
(import_mut_rust_f64, import_mut_js_f64, f64)
|
|
}
|
|
|
|
macro_rules! export_mut_macro {
|
|
($(($i:ident, $n:ident))*) => ($(
|
|
#[wasm_bindgen]
|
|
pub fn $n(a: &mut [$i]) {
|
|
assert_eq!(a.len(), 3);
|
|
assert_eq!(a[0], 1 as $i);
|
|
assert_eq!(a[1], 2 as $i);
|
|
assert_eq!(a[2], 3 as $i);
|
|
a[0] = 4 as $i;
|
|
a[1] = 5 as $i;
|
|
}
|
|
)*)
|
|
}
|
|
|
|
export_mut_macro! {
|
|
(i8, export_mut_i8)
|
|
(u8, export_mut_u8)
|
|
(i16, export_mut_i16)
|
|
(u16, export_mut_u16)
|
|
(i32, export_mut_i32)
|
|
(u32, export_mut_u32)
|
|
(f32, export_mut_f32)
|
|
(f64, export_mut_f64)
|
|
}
|
|
|
|
#[wasm_bindgen_test]
|
|
fn export_mut() {
|
|
js_export_mut();
|
|
}
|
|
|
|
#[wasm_bindgen]
|
|
pub fn return_vec_broken_vec() -> Vec<u32> {
|
|
vec![1, 2, 3, 4, 5, 6, 7, 8, 9]
|
|
}
|
|
|
|
#[wasm_bindgen]
|
|
pub fn return_vec_web_main() -> ReturnVecApplication {
|
|
ReturnVecApplication::new()
|
|
}
|
|
|
|
#[wasm_bindgen]
|
|
pub struct ReturnVecApplication {
|
|
thing: Vec<u32>,
|
|
}
|
|
|
|
#[wasm_bindgen]
|
|
impl ReturnVecApplication {
|
|
pub fn new() -> ReturnVecApplication {
|
|
let mut thing = vec![];
|
|
thing.push(0);
|
|
thing.push(0);
|
|
thing.push(0);
|
|
thing.push(0);
|
|
thing.push(0);
|
|
|
|
ReturnVecApplication { thing }
|
|
}
|
|
|
|
pub fn tick(&mut self) {
|
|
self.thing = self.thing.clone();
|
|
}
|
|
}
|
|
|
|
#[wasm_bindgen_test]
|
|
fn return_vec() {
|
|
js_return_vec();
|
|
}
|