mirror of
https://github.com/rustwasm/wasm-bindgen.git
synced 2024-11-24 06:33:33 +03:00
Merge pull request #400 from alexcrichton/derive-import
Forward attributes on `type` declaration to definition
This commit is contained in:
commit
142d7377e2
@ -84,6 +84,7 @@ pub struct ImportStatic {
|
||||
pub struct ImportType {
|
||||
pub vis: syn::Visibility,
|
||||
pub name: Ident,
|
||||
pub attrs: Vec<syn::Attribute>,
|
||||
}
|
||||
|
||||
#[cfg_attr(feature = "extra-traits", derive(Debug, PartialEq, Eq))]
|
||||
@ -469,6 +470,7 @@ impl Program {
|
||||
ImportKind::Type(ImportType {
|
||||
vis: f.vis,
|
||||
name: f.ident,
|
||||
attrs: f.attrs,
|
||||
})
|
||||
}
|
||||
|
||||
|
@ -505,8 +505,10 @@ impl ToTokens for ast::ImportType {
|
||||
fn to_tokens(&self, tokens: &mut TokenStream) {
|
||||
let vis = &self.vis;
|
||||
let name = &self.name;
|
||||
let attrs = &self.attrs;
|
||||
(quote! {
|
||||
#[allow(bad_style)]
|
||||
#(#attrs)*
|
||||
#vis struct #name {
|
||||
obj: ::wasm_bindgen::JsValue,
|
||||
}
|
||||
|
@ -171,6 +171,7 @@ impl WebidlParse<()> for webidl::ast::NonPartialInterface {
|
||||
pub_token: Default::default(),
|
||||
}),
|
||||
name: rust_ident(&self.name),
|
||||
attrs: Vec::new(),
|
||||
}),
|
||||
});
|
||||
|
||||
@ -379,7 +380,7 @@ impl<'a> WebidlParse<&'a str> for webidl::ast::StaticOperation {
|
||||
if util::is_chrome_only(&self.extended_attributes) {
|
||||
return Ok(())
|
||||
}
|
||||
|
||||
|
||||
create_basic_method(
|
||||
&self.arguments,
|
||||
self.name.as_ref(),
|
||||
|
@ -112,6 +112,7 @@ fn construct() {
|
||||
|
||||
#[wasm_bindgen(module = "./another")]
|
||||
extern {
|
||||
#[derive(Clone)]
|
||||
type Foo;
|
||||
#[wasm_bindgen(js_namespace = Foo)]
|
||||
fn create() -> Foo;
|
||||
@ -127,6 +128,7 @@ fn construct() {
|
||||
pub fn run() {
|
||||
let f = Foo::create();
|
||||
assert_eq!(f.get_internal_string(), "this");
|
||||
assert_eq!(f.clone().get_internal_string(), "this");
|
||||
f.append_to_internal_string(" foo");
|
||||
f.assert_internal_string("this foo");
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user