wasm-bindgen/tests/wasm/slice.rs
Alex Crichton d5b81595ec Remove support for the version attribute
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.
2018-08-06 13:30:28 -05:00

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();
}