From 3b7308db17aabb6d554c805620b56e5ebe67e9a9 Mon Sep 17 00:00:00 2001 From: Tomasz Kurcz Date: Tue, 25 Jul 2023 22:15:01 +0200 Subject: [PATCH 1/2] use global paths in macro expansions --- .../src/core_impl/abi/abi_embed.rs | 4 +- .../src/core_impl/abi/abi_generator.rs | 216 ++++----- .../core_impl/code_generator/attr_sig_info.rs | 55 +-- .../src/core_impl/code_generator/ext.rs | 96 ++-- .../code_generator/impl_item_method_info.rs | 36 +- .../code_generator/item_impl_info.rs | 430 +++++++++--------- .../code_generator/item_trait_info.rs | 88 ++-- .../core_impl/code_generator/serializer.rs | 6 +- near-sdk-macros/src/core_impl/event/mod.rs | 8 +- .../core_impl/metadata/metadata_generator.rs | 22 +- .../core_impl/metadata/metadata_visitor.rs | 68 +-- near-sdk-macros/src/lib.rs | 28 +- 12 files changed, 530 insertions(+), 527 deletions(-) diff --git a/near-sdk-macros/src/core_impl/abi/abi_embed.rs b/near-sdk-macros/src/core_impl/abi/abi_embed.rs index 0c04ab662..b94f4a68f 100644 --- a/near-sdk-macros/src/core_impl/abi/abi_embed.rs +++ b/near-sdk-macros/src/core_impl/abi/abi_embed.rs @@ -5,10 +5,10 @@ pub fn embed() -> TokenStream2 { let abi_path = env!("CARGO_NEAR_ABI_PATH"); quote! { const _: () = { - const __CONTRACT_ABI: &'static [u8] = include_bytes!(#abi_path); + const __CONTRACT_ABI: &'static [u8] = ::std::include_bytes!(#abi_path); #[no_mangle] pub extern "C" fn __contract_abi() { - near_sdk::env::value_return(__CONTRACT_ABI); + ::near_sdk::env::value_return(__CONTRACT_ABI); } }; } diff --git a/near-sdk-macros/src/core_impl/abi/abi_generator.rs b/near-sdk-macros/src/core_impl/abi/abi_generator.rs index 32eca8698..cbe659a63 100644 --- a/near-sdk-macros/src/core_impl/abi/abi_generator.rs +++ b/near-sdk-macros/src/core_impl/abi/abi_generator.rs @@ -20,10 +20,12 @@ pub fn generate(i: &ItemImplInfo) -> TokenStream2 { const _: () = { #[no_mangle] pub extern "C" fn #near_abi_symbol() -> (*const u8, usize) { - let mut gen = near_sdk::__private::schemars::gen::SchemaGenerator::default(); + use ::std::string::String; + + let mut gen = ::near_sdk::__private::schemars::gen::SchemaGenerator::default(); let functions = vec![#(#functions),*]; - let mut data = std::mem::ManuallyDrop::new( - near_sdk::serde_json::to_vec(&near_sdk::__private::ChunkedAbiEntry::new( + let mut data = ::std::mem::ManuallyDrop::new( + ::near_sdk::serde_json::to_vec(&::near_sdk::__private::ChunkedAbiEntry::new( functions, gen.into_root_schema_for::(), )) @@ -79,28 +81,28 @@ impl ImplItemMethodInfo { let function_name_str = attr_signature_info.ident.to_string(); let function_doc = match parse_rustdoc(&attr_signature_info.non_bindgen_attrs) { - Some(doc) => quote! { Some(#doc.to_string()) }, - None => quote! { None }, + Some(doc) => quote! { ::std::option::Option::Some(::std::string::String::from(#doc)) }, + None => quote! { ::std::option::Option::None }, }; let mut modifiers = vec![]; let kind = match &attr_signature_info.method_kind { - MethodKind::View(_) => quote! { near_sdk::__private::AbiFunctionKind::View }, + MethodKind::View(_) => quote! { ::near_sdk::__private::AbiFunctionKind::View }, MethodKind::Call(_) => { - quote! { near_sdk::__private::AbiFunctionKind::Call } + quote! { ::near_sdk::__private::AbiFunctionKind::Call } } MethodKind::Init(_) => { - modifiers.push(quote! { near_sdk::__private::AbiFunctionModifier::Init }); - quote! { near_sdk::__private::AbiFunctionKind::Call } + modifiers.push(quote! { ::near_sdk::__private::AbiFunctionModifier::Init }); + quote! { ::near_sdk::__private::AbiFunctionKind::Call } } }; if attr_signature_info.is_payable() { - modifiers.push(quote! { near_sdk::__private::AbiFunctionModifier::Payable }); + modifiers.push(quote! { ::near_sdk::__private::AbiFunctionModifier::Payable }); } if attr_signature_info.is_private() { - modifiers.push(quote! { near_sdk::__private::AbiFunctionModifier::Private }); + modifiers.push(quote! { ::near_sdk::__private::AbiFunctionModifier::Private }); } let modifiers = quote! { - vec![#(#modifiers),*] + ::std::vec![#(#modifiers),*] }; let mut params = Vec::::new(); @@ -114,14 +116,14 @@ impl ImplItemMethodInfo { let schema = generate_schema(typ, &arg.serializer_ty); match arg.serializer_ty { SerializerType::JSON => params.push(quote! { - near_sdk::__private::AbiJsonParameter { - name: #arg_name.to_string(), + ::near_sdk::__private::AbiJsonParameter { + name: ::std::string::String::from(#arg_name), type_schema: #schema, } }), SerializerType::Borsh => params.push(quote! { - near_sdk::__private::AbiBorshParameter { - name: #arg_name.to_string(), + ::near_sdk::__private::AbiBorshParameter { + name: ::std::string::String::from(#arg_name), type_schema: #schema, } }), @@ -168,28 +170,28 @@ impl ImplItemMethodInfo { } let params = match attr_signature_info.input_serializer { SerializerType::JSON => quote! { - near_sdk::__private::AbiParameters::Json { - args: vec![#(#params),*] + ::near_sdk::__private::AbiParameters::Json { + args: ::std::vec![#(#params),*] } }, SerializerType::Borsh => quote! { - near_sdk::__private::AbiParameters::Borsh { - args: vec![#(#params),*] + ::near_sdk::__private::AbiParameters::Borsh { + args: ::std::vec![#(#params),*] } }, }; - let callback_vec = callback_vec.unwrap_or(quote! { None }); + let callback_vec = callback_vec.unwrap_or(quote! { ::std::option::Option::None }); let result = self.abi_result_tokens(); quote! { - near_sdk::__private::AbiFunction { - name: #function_name_str.to_string(), + ::near_sdk::__private::AbiFunction { + name: ::std::string::String::from(#function_name_str), doc: #function_doc, kind: #kind, modifiers: #modifiers, params: #params, - callbacks: vec![#(#callbacks),*], + callbacks: ::std::vec![#(#callbacks),*], callbacks_vec: #callback_vec, result: #result } @@ -200,7 +202,7 @@ impl ImplItemMethodInfo { use ReturnKind::*; match &self.attr_signature_info.returns.kind { - Default => quote! { None }, + Default => quote! { ::std::option::Option::None }, General(ty) => self.abi_result_tokens_with_return_value(ty), HandlesResult { ok_type } => self.abi_result_tokens_with_return_value(ok_type), } @@ -211,13 +213,13 @@ impl ImplItemMethodInfo { let some_abi_type = |result_serializer: &SerializerType| { let abi_type = generate_abi_type(return_value_type, result_serializer); - quote! { Some(#abi_type) } + quote! { ::std::option::Option::Some(#abi_type) } }; match &self.attr_signature_info.method_kind { Call(call_method) => some_abi_type(&call_method.result_serializer), // Init methods don't return a value, they just save the newly created contract state. - Init(_) => quote! { None }, + Init(_) => quote! { ::std::option::Option::None }, View(view_method) => some_abi_type(&view_method.result_serializer), } } @@ -226,13 +228,13 @@ impl ImplItemMethodInfo { let abi_type = |result_serializer: &SerializerType| { let tokens = generate_abi_type(callback_vec_type, result_serializer); quote! { - Some(#tokens) + ::std::option::Option::Some(#tokens) } }; match &self.attr_signature_info.method_kind { MethodKind::Call(call_method) => abi_type(&call_method.result_serializer), - MethodKind::Init(_) => quote! { None }, + MethodKind::Init(_) => quote! { ::std::option::Option::None }, MethodKind::View(view_method) => abi_type(&view_method.result_serializer), } } @@ -244,7 +246,7 @@ fn generate_schema(ty: &Type, serializer_type: &SerializerType) -> TokenStream2 gen.subschema_for::<#ty>() }, SerializerType::Borsh => quote! { - <#ty as near_sdk::borsh::BorshSchema>::schema_container() + <#ty as ::near_sdk::borsh::BorshSchema>::schema_container() }, } } @@ -253,12 +255,12 @@ fn generate_abi_type(ty: &Type, serializer_type: &SerializerType) -> TokenStream let schema = generate_schema(ty, serializer_type); match serializer_type { SerializerType::JSON => quote! { - near_sdk::__private::AbiType::Json { + ::near_sdk::__private::AbiType::Json { type_schema: #schema, } }, SerializerType::Borsh => quote! { - near_sdk::__private::AbiType::Borsh { + ::near_sdk::__private::AbiType::Borsh { type_schema: #schema, } }, @@ -309,26 +311,26 @@ mod tests { let actual = method_info.abi_struct(); let expected = quote! { - near_sdk::__private::AbiFunction { - name: "f3".to_string(), - doc: Some(" I am a function.".to_string()), - kind: near_sdk::__private::AbiFunctionKind::Call, - modifiers: vec![], - params: near_sdk::__private::AbiParameters::Json { - args: vec![ - near_sdk::__private::AbiJsonParameter { - name: "arg0".to_string(), + ::near_sdk::__private::AbiFunction { + name: ::std::string::String::from("f3"), + doc: ::std::option::Option::Some(::std::string::String::from(" I am a function.")), + kind: ::near_sdk::__private::AbiFunctionKind::Call, + modifiers: ::std::vec![], + params: ::near_sdk::__private::AbiParameters::Json { + args: ::std::vec![ + ::near_sdk::__private::AbiJsonParameter { + name: ::std::string::String::from("arg0"), type_schema: gen.subschema_for::(), }, - near_sdk::__private::AbiJsonParameter { - name: "arg1".to_string(), + ::near_sdk::__private::AbiJsonParameter { + name: ::std::string::String::from("arg1"), type_schema: gen.subschema_for::(), } ] }, - callbacks: vec![], - callbacks_vec: None, - result: Some(near_sdk::__private::AbiType::Json { + callbacks: ::std::vec![], + callbacks_vec: ::std::option::Option::None, + result: ::std::option::Option::Some(::near_sdk::__private::AbiType::Json { type_schema: gen.subschema_for::(), }) } @@ -350,23 +352,23 @@ mod tests { let actual = method_info.abi_struct(); let expected = quote! { - near_sdk::__private::AbiFunction { - name: "f3".to_string(), - doc: None, - kind: near_sdk::__private::AbiFunctionKind::Call, - modifiers: vec![near_sdk::__private::AbiFunctionModifier::Payable], - params: near_sdk::__private::AbiParameters::Borsh { - args: vec![ - near_sdk::__private::AbiBorshParameter { - name: "arg0".to_string(), - type_schema: ::schema_container(), + ::near_sdk::__private::AbiFunction { + name: ::std::string::String::from("f3"), + doc: ::std::option::Option::None, + kind: ::near_sdk::__private::AbiFunctionKind::Call, + modifiers: ::std::vec![::near_sdk::__private::AbiFunctionModifier::Payable], + params: ::near_sdk::__private::AbiParameters::Borsh { + args: ::std::vec![ + ::near_sdk::__private::AbiBorshParameter { + name: ::std::string::String::from("arg0"), + type_schema: ::schema_container(), } ] }, - callbacks: vec![], - callbacks_vec: None, - result: Some(near_sdk::__private::AbiType::Borsh { - type_schema: ::schema_container(), + callbacks: ::std::vec![], + callbacks_vec: ::std::option::Option::None, + result: ::std::option::Option::Some(::near_sdk::__private::AbiType::Borsh { + type_schema: ::schema_container(), }) } }; @@ -388,19 +390,19 @@ mod tests { let actual = method_info.abi_struct(); let expected = quote! { - near_sdk::__private::AbiFunction { - name: "method".to_string(), - doc: None, - kind: near_sdk::__private::AbiFunctionKind::View , - modifiers: vec! [near_sdk::__private::AbiFunctionModifier::Private], - params: near_sdk::__private::AbiParameters::Json { - args: vec![] + ::near_sdk::__private::AbiFunction { + name: ::std::string::String::from("method"), + doc: ::std::option::Option::None, + kind: ::near_sdk::__private::AbiFunctionKind::View , + modifiers: ::std::vec! [::near_sdk::__private::AbiFunctionModifier::Private], + params: ::near_sdk::__private::AbiParameters::Json { + args: ::std::vec![] }, - callbacks: vec! [], - callbacks_vec: Some(near_sdk::__private::AbiType::Json { + callbacks: ::std::vec! [], + callbacks_vec: ::std::option::Option::Some(::near_sdk::__private::AbiType::Json { type_schema: gen.subschema_for::< String >() , }), - result: Some(near_sdk::__private::AbiType::Json { + result: ::std::option::Option::Some(::near_sdk::__private::AbiType::Json { type_schema: gen.subschema_for::< bool >() , }) } @@ -419,29 +421,29 @@ mod tests { let actual = method_info.abi_struct(); let expected = quote! { - near_sdk::__private::AbiFunction { - name: "method".to_string(), - doc: None, - kind: near_sdk::__private::AbiFunctionKind::View , - modifiers: vec! [], - params: near_sdk::__private::AbiParameters::Borsh { - args: vec! [ - near_sdk::__private::AbiBorshParameter { - name: "y".to_string(), - type_schema: < String as near_sdk::borsh::BorshSchema >::schema_container(), + ::near_sdk::__private::AbiFunction { + name: ::std::string::String::from("method"), + doc: ::std::option::Option::None, + kind: ::near_sdk::__private::AbiFunctionKind::View , + modifiers: ::std::vec! [], + params: ::near_sdk::__private::AbiParameters::Borsh { + args: ::std::vec! [ + ::near_sdk::__private::AbiBorshParameter { + name: ::std::string::String::from("y"), + type_schema: < String as ::near_sdk::borsh::BorshSchema >::schema_container(), } ] }, - callbacks: vec! [ - near_sdk::__private::AbiType::Borsh { - type_schema: ::schema_container(), + callbacks: ::std::vec! [ + ::near_sdk::__private::AbiType::Borsh { + type_schema: ::schema_container(), }, - near_sdk::__private::AbiType::Json { + ::near_sdk::__private::AbiType::Json { type_schema: gen.subschema_for::< Vec >(), } ], - callbacks_vec: None, - result: None + callbacks_vec: ::std::option::Option::None, + result: ::std::option::Option::None } }; @@ -459,19 +461,19 @@ mod tests { let actual = method_info.abi_struct(); let expected = quote! { - near_sdk::__private::AbiFunction { - name: "new".to_string(), - doc: None, - kind: near_sdk::__private::AbiFunctionKind::Call, - modifiers: vec![ - near_sdk::__private::AbiFunctionModifier::Init + ::near_sdk::__private::AbiFunction { + name: ::std::string::String::from("new"), + doc: ::std::option::Option::None, + kind: ::near_sdk::__private::AbiFunctionKind::Call, + modifiers: ::std::vec![ + ::near_sdk::__private::AbiFunctionModifier::Init ], - params: near_sdk::__private::AbiParameters::Json { - args: vec![] + params: ::near_sdk::__private::AbiParameters::Json { + args: ::std::vec![] }, - callbacks: vec![], - callbacks_vec: None, - result: None + callbacks: ::std::vec![], + callbacks_vec: ::std::option::Option::None, + result: ::std::option::Option::None } }; @@ -488,17 +490,17 @@ mod tests { let actual = method_info.abi_struct(); let expected = quote! { - near_sdk::__private::AbiFunction { - name: "method".to_string(), - doc: None, - kind: near_sdk::__private::AbiFunctionKind::View, - modifiers: vec![], - params: near_sdk::__private::AbiParameters::Json { - args: vec![] + ::near_sdk::__private::AbiFunction { + name: ::std::string::String::from("method"), + doc: ::std::option::Option::None, + kind: ::near_sdk::__private::AbiFunctionKind::View, + modifiers: ::std::vec![], + params: ::near_sdk::__private::AbiParameters::Json { + args: ::std::vec![] }, - callbacks: vec![], - callbacks_vec: None, - result: None + callbacks: ::std::vec![], + callbacks_vec: ::std::option::Option::None, + result: ::std::option::Option::None } }; diff --git a/near-sdk-macros/src/core_impl/code_generator/attr_sig_info.rs b/near-sdk-macros/src/core_impl/code_generator/attr_sig_info.rs index 559d1fe84..e6fb94bbc 100644 --- a/near-sdk-macros/src/core_impl/code_generator/attr_sig_info.rs +++ b/near-sdk-macros/src/core_impl/code_generator/attr_sig_info.rs @@ -43,11 +43,11 @@ impl AttrSigInfo { ); let attribute = match &self.input_serializer { SerializerType::JSON => quote! { - #[derive(near_sdk::serde::Serialize)] - #[serde(crate = "near_sdk::serde")] + #[derive(::near_sdk::serde::Serialize)] + #[serde(crate = "::near_sdk::serde")] }, SerializerType::Borsh => quote! { - #[derive(near_sdk::borsh::BorshSerialize)] + #[derive(::near_sdk::borsh::BorshSerialize)] }, }; let mut fields = TokenStream2::new(); @@ -89,11 +89,11 @@ impl AttrSigInfo { ); let attribute = match &self.input_serializer { SerializerType::JSON => quote! { - #[derive(near_sdk::serde::Deserialize)] - #[serde(crate = "near_sdk::serde")] + #[derive(::near_sdk::serde::Deserialize)] + #[serde(crate = "::near_sdk::serde")] }, SerializerType::Borsh => quote! { - #[derive(near_sdk::borsh::BorshDeserialize)] + #[derive(::near_sdk::borsh::BorshDeserialize)] }, }; let mut fields = TokenStream2::new(); @@ -222,9 +222,9 @@ impl AttrSigInfo { BindgenArgType::CallbackArg => { let error_msg = format!("Callback computation {} was not successful", idx); let read_data = quote! { - let data: Vec = match near_sdk::env::promise_result(#idx) { - near_sdk::PromiseResult::Successful(x) => x, - _ => near_sdk::env::panic_str(#error_msg) + let data: ::std::vec::Vec = match ::near_sdk::env::promise_result(#idx) { + ::near_sdk::PromiseResult::Successful(x) => x, + _ => ::near_sdk::env::panic_str(#error_msg) }; }; let invocation = deserialize_data(serializer_ty); @@ -255,19 +255,19 @@ impl AttrSigInfo { // deserialization otherwise. syn::Type::Tuple(type_tuple) if type_tuple.elems.is_empty() => quote! { - near_sdk::PromiseResult::Successful(data) if data.is_empty() => - Ok(()), - near_sdk::PromiseResult::Successful(data) => Ok(#deserialize) + ::near_sdk::PromiseResult::Successful(data) if data.is_empty() => + ::std::result::Result::Ok(()), + ::near_sdk::PromiseResult::Successful(data) => ::std::result::Result::Ok(#deserialize) }, _ => quote! { - near_sdk::PromiseResult::Successful(data) => Ok(#deserialize) + ::near_sdk::PromiseResult::Successful(data) => ::std::result::Result::Ok(#deserialize) } }; let result = quote! { - match near_sdk::env::promise_result(#idx) { + match ::near_sdk::env::promise_result(#idx) { #deserialization_branch, - near_sdk::PromiseResult::Failed => Err(near_sdk::PromiseError::Failed), + ::near_sdk::PromiseResult::Failed => ::std::result::Result::Err(::near_sdk::PromiseError::Failed), } }; quote! { @@ -290,16 +290,17 @@ impl AttrSigInfo { let ArgInfo { mutability, ident, ty, .. } = arg; let invocation = deserialize_data(&arg.serializer_ty); quote! { - #acc - let #mutability #ident: #ty = (0..near_sdk::env::promise_results_count()) - .map(|i| { - let data: Vec = match near_sdk::env::promise_result(i) { - near_sdk::PromiseResult::Successful(x) => x, - _ => near_sdk::env::panic_str(&format!("Callback computation {} was not successful", i)), - }; - #invocation - }).collect(); - } + #acc + let #mutability #ident: #ty = ::std::iter::Iterator::collect(::std::iter::Iterator::map( + 0..::near_sdk::env::promise_results_count(), + |i| { + let data: ::std::vec::Vec = match ::near_sdk::env::promise_result(i) { + ::near_sdk::PromiseResult::Successful(x) => x, + _ => ::near_sdk::env::panic_str(&::std::format!("Callback computation {} was not successful", i)), + }; + #invocation + })); + } }) } } @@ -307,10 +308,10 @@ impl AttrSigInfo { pub fn deserialize_data(ty: &SerializerType) -> TokenStream2 { match ty { SerializerType::JSON => quote! { - near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON") + ::near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON") }, SerializerType::Borsh => quote! { - near_sdk::borsh::BorshDeserialize::try_from_slice(&data).expect("Failed to deserialize callback using Borsh") + ::near_sdk::borsh::BorshDeserialize::try_from_slice(&data).expect("Failed to deserialize callback using Borsh") }, } } diff --git a/near-sdk-macros/src/core_impl/code_generator/ext.rs b/near-sdk-macros/src/core_impl/code_generator/ext.rs index 1b653db94..5a1e5d1b4 100644 --- a/near-sdk-macros/src/core_impl/code_generator/ext.rs +++ b/near-sdk-macros/src/core_impl/code_generator/ext.rs @@ -13,12 +13,12 @@ pub(crate) fn generate_ext_structs( let name = format_ident!("{}Ext", ident); let mut ext_code = quote! { /// API for calling this contract's functions in a subsequent execution. - pub fn ext(account_id: near_sdk::AccountId) -> #name { + pub fn ext(account_id: ::near_sdk::AccountId) -> #name { #name { account_id, deposit: 0, - static_gas: near_sdk::Gas(0), - gas_weight: near_sdk::GasWeight::default(), + static_gas: ::near_sdk::Gas(0), + gas_weight: ::near_sdk::GasWeight::default(), } } }; @@ -34,23 +34,23 @@ pub(crate) fn generate_ext_structs( quote! { #[must_use] pub struct #name { - pub(crate) account_id: near_sdk::AccountId, - pub(crate) deposit: near_sdk::Balance, - pub(crate) static_gas: near_sdk::Gas, - pub(crate) gas_weight: near_sdk::GasWeight, + pub(crate) account_id: ::near_sdk::AccountId, + pub(crate) deposit: ::near_sdk::Balance, + pub(crate) static_gas: ::near_sdk::Gas, + pub(crate) gas_weight: ::near_sdk::GasWeight, } impl #name { - pub fn with_attached_deposit(mut self, amount: near_sdk::Balance) -> Self { + pub fn with_attached_deposit(mut self, amount: ::near_sdk::Balance) -> Self { self.deposit = amount; self } - pub fn with_static_gas(mut self, static_gas: near_sdk::Gas) -> Self { + pub fn with_static_gas(mut self, static_gas: ::near_sdk::Gas) -> Self { self.static_gas = static_gas; self } pub fn with_unused_gas_weight(mut self, gas_weight: u64) -> Self { - self.gas_weight = near_sdk::GasWeight(gas_weight); + self.gas_weight = ::near_sdk::GasWeight(gas_weight); self } } @@ -127,11 +127,11 @@ fn generate_ext_function(attr_signature_info: &AttrSigInfo) -> TokenStream2 { let Signature { generics, .. } = original_sig; quote! { #new_non_bindgen_attrs - pub fn #ident #generics(self, #pat_type_list) -> near_sdk::Promise { + pub fn #ident #generics(self, #pat_type_list) -> ::near_sdk::Promise { let __args = #serialize; - near_sdk::Promise::new(self.account_id) + ::near_sdk::Promise::new(self.account_id) .function_call_weight( - #ident_str.to_string(), + ::std::string::String::from(#ident_str), __args, self.deposit, self.static_gas, @@ -157,33 +157,33 @@ mod tests { let expected = quote!( #[must_use] pub struct TestExt { - pub(crate) account_id: near_sdk::AccountId, - pub(crate) deposit: near_sdk::Balance, - pub(crate) static_gas: near_sdk::Gas, - pub(crate) gas_weight: near_sdk::GasWeight, + pub(crate) account_id: ::near_sdk::AccountId, + pub(crate) deposit: ::near_sdk::Balance, + pub(crate) static_gas: ::near_sdk::Gas, + pub(crate) gas_weight: ::near_sdk::GasWeight, } impl TestExt { - pub fn with_attached_deposit(mut self, amount: near_sdk::Balance) -> Self { + pub fn with_attached_deposit(mut self, amount: ::near_sdk::Balance) -> Self { self.deposit = amount; self } - pub fn with_static_gas(mut self, static_gas: near_sdk::Gas) -> Self { + pub fn with_static_gas(mut self, static_gas: ::near_sdk::Gas) -> Self { self.static_gas = static_gas; self } pub fn with_unused_gas_weight(mut self, gas_weight: u64) -> Self { - self.gas_weight = near_sdk::GasWeight(gas_weight); + self.gas_weight = ::near_sdk::GasWeight(gas_weight); self } } impl Test { /// API for calling this contract's functions in a subsequent execution. - pub fn ext(account_id: near_sdk::AccountId) -> TestExt { + pub fn ext(account_id: ::near_sdk::AccountId) -> TestExt { TestExt { account_id, deposit: 0, - static_gas: near_sdk::Gas(0), - gas_weight: near_sdk::GasWeight::default(), + static_gas: ::near_sdk::Gas(0), + gas_weight: ::near_sdk::GasWeight::default(), } } } @@ -198,32 +198,32 @@ mod tests { let expected = quote!( #[must_use] pub struct TestExt { - pub(crate) account_id: near_sdk::AccountId, - pub(crate) deposit: near_sdk::Balance, - pub(crate) static_gas: near_sdk::Gas, - pub(crate) gas_weight: near_sdk::GasWeight, + pub(crate) account_id: ::near_sdk::AccountId, + pub(crate) deposit: ::near_sdk::Balance, + pub(crate) static_gas: ::near_sdk::Gas, + pub(crate) gas_weight: ::near_sdk::GasWeight, } impl TestExt { - pub fn with_attached_deposit(mut self, amount: near_sdk::Balance) -> Self { + pub fn with_attached_deposit(mut self, amount: ::near_sdk::Balance) -> Self { self.deposit = amount; self } - pub fn with_static_gas(mut self, static_gas: near_sdk::Gas) -> Self { + pub fn with_static_gas(mut self, static_gas: ::near_sdk::Gas) -> Self { self.static_gas = static_gas; self } pub fn with_unused_gas_weight(mut self, gas_weight: u64) -> Self { - self.gas_weight = near_sdk::GasWeight(gas_weight); + self.gas_weight = ::near_sdk::GasWeight(gas_weight); self } } /// API for calling this contract's functions in a subsequent execution. - pub fn ext(account_id: near_sdk::AccountId) -> TestExt { + pub fn ext(account_id: ::near_sdk::AccountId) -> TestExt { TestExt { account_id, deposit: 0, - static_gas: near_sdk::Gas(0), - gas_weight: near_sdk::GasWeight::default(), + static_gas: ::near_sdk::Gas(0), + gas_weight: ::near_sdk::GasWeight::default(), } } ); @@ -247,10 +247,10 @@ mod tests { // Note: only whitelisted non-bindgen attributes are forwarded. let expected = quote! { #[cfg(target_os = "linux")] - pub fn method (self,) -> near_sdk::Promise { - let __args = vec![]; - near_sdk::Promise::new(self.account_id).function_call_weight( - "method".to_string(), + pub fn method (self,) -> ::near_sdk::Promise { + let __args = ::std::vec![]; + ::near_sdk::Promise::new(self.account_id).function_call_weight( + ::std::string::String::from("method"), __args, self.deposit, self.static_gas, @@ -270,18 +270,18 @@ mod tests { let method_info = ImplItemMethodInfo::new(&mut method, false, impl_type).unwrap().unwrap(); let actual = generate_ext_function(&method_info.attr_signature_info); let expected = quote!( - pub fn method(self, k: &String,) -> near_sdk::Promise { - let __args = {#[derive(near_sdk :: serde :: Serialize)] - #[serde(crate = "near_sdk::serde")] + pub fn method(self, k: &String,) -> ::near_sdk::Promise { + let __args = {#[derive(::near_sdk :: serde :: Serialize)] + #[serde(crate = "::near_sdk::serde")] struct Input<'nearinput> { k: &'nearinput String, } let __args = Input { k: &k, }; - near_sdk::serde_json::to_vec(&__args) + ::near_sdk::serde_json::to_vec(&__args) .expect("Failed to serialize the cross contract args using JSON.") }; - near_sdk::Promise::new(self.account_id).function_call_weight( - "method".to_string(), + ::near_sdk::Promise::new(self.account_id).function_call_weight( + ::std::string::String::from("method"), __args, self.deposit, self.static_gas, @@ -301,19 +301,19 @@ mod tests { let method_info = ImplItemMethodInfo::new(&mut method, false, impl_type).unwrap().unwrap(); let actual = generate_ext_function(&method_info.attr_signature_info); let expected = quote!( - pub fn borsh_test(self, a: String,) -> near_sdk::Promise { + pub fn borsh_test(self, a: String,) -> ::near_sdk::Promise { let __args = { - #[derive(near_sdk :: borsh :: BorshSerialize)] + #[derive(::near_sdk :: borsh :: BorshSerialize)] struct Input<'nearinput> { a: &'nearinput String, } let __args = Input { a: &a, }; - near_sdk::borsh::BorshSerialize::try_to_vec(&__args) + ::near_sdk::borsh::BorshSerialize::try_to_vec(&__args) .expect("Failed to serialize the cross contract args using Borsh.") }; - near_sdk::Promise::new(self.account_id) + ::near_sdk::Promise::new(self.account_id) .function_call_weight( - "borsh_test".to_string(), + ::std::string::String::from("borsh_test"), __args, self.deposit, self.static_gas, diff --git a/near-sdk-macros/src/core_impl/code_generator/impl_item_method_info.rs b/near-sdk-macros/src/core_impl/code_generator/impl_item_method_info.rs index c2e62d277..5a408a71f 100644 --- a/near-sdk-macros/src/core_impl/code_generator/impl_item_method_info.rs +++ b/near-sdk-macros/src/core_impl/code_generator/impl_item_method_info.rs @@ -89,19 +89,19 @@ impl ImplItemMethodInfo { #contract_init #method_invocation_with_return match #result_identifier { - Ok(#result_identifier) => { + ::std::result::Result::Ok(#result_identifier) => { #value_ser #value_return #contract_ser } - Err(err) => near_sdk::FunctionError::panic(&err) + ::std::result::Result::Err(err) => ::near_sdk::FunctionError::panic(&err) } } } fn panic_hook_tokens(&self) -> TokenStream2 { quote! { - near_sdk::env::setup_panic_hook(); + ::near_sdk::env::setup_panic_hook(); } } @@ -118,13 +118,13 @@ impl ImplItemMethodInfo { let decomposition = self.attr_signature_info.decomposition_pattern(); let serializer_invocation = match self.attr_signature_info.input_serializer { SerializerType::JSON => quote! { - near_sdk::serde_json::from_slice( - &near_sdk::env::input().expect("Expected input since method has arguments.") + ::near_sdk::serde_json::from_slice( + &::near_sdk::env::input().expect("Expected input since method has arguments.") ).expect("Failed to deserialize input from JSON.") }, SerializerType::Borsh => quote! { - near_sdk::borsh::BorshDeserialize::try_from_slice( - &near_sdk::env::input().expect("Expected input since method has arguments.") + ::near_sdk::borsh::BorshDeserialize::try_from_slice( + &::near_sdk::env::input().expect("Expected input since method has arguments.") ).expect("Failed to deserialize input from Borsh.") }, }; @@ -143,8 +143,8 @@ impl ImplItemMethodInfo { // If method is not payable, do a check to make sure that it doesn't consume deposit let error = format!("Method {} doesn't accept deposit", self.attr_signature_info.ident); quote! { - if near_sdk::env::attached_deposit() != 0 { - near_sdk::env::panic_str(#error); + if ::near_sdk::env::attached_deposit() != 0 { + ::near_sdk::env::panic_str(#error); } } }; @@ -174,8 +174,8 @@ impl ImplItemMethodInfo { if self.attr_signature_info.is_private() { let error = format!("Method {} is private", self.attr_signature_info.ident); quote! { - if near_sdk::env::current_account_id() != near_sdk::env::predecessor_account_id() { - near_sdk::env::panic_str(#error); + if ::near_sdk::env::current_account_id() != ::near_sdk::env::predecessor_account_id() { + ::near_sdk::env::panic_str(#error); } } } else { @@ -194,8 +194,8 @@ impl ImplItemMethodInfo { Init(init_method) => { if !init_method.ignores_state { quote! { - if near_sdk::env::state_exists() { - near_sdk::env::panic_str("The contract has already been initialized"); + if ::near_sdk::env::state_exists() { + ::near_sdk::env::panic_str("The contract has already been initialized"); } } } else { @@ -218,7 +218,7 @@ impl ImplItemMethodInfo { let mutability = receiver.mutability; quote! { - let #mutability contract: #struct_type = near_sdk::env::state_read().unwrap_or_default(); + let #mutability contract: #struct_type = ::near_sdk::env::state_read().unwrap_or_default(); } }; @@ -252,7 +252,7 @@ impl ImplItemMethodInfo { fn contract_ser() -> TokenStream2 { quote! { - near_sdk::env::state_write(&contract); + ::near_sdk::env::state_write(&contract); } } @@ -337,10 +337,10 @@ impl ImplItemMethodInfo { let value_ser = |result_serializer: &SerializerType| match result_serializer { SerializerType::JSON => quote! { - let result = near_sdk::serde_json::to_vec(&result).expect("Failed to serialize the return value using JSON."); + let result = ::near_sdk::serde_json::to_vec(&result).expect("Failed to serialize the return value using JSON."); }, SerializerType::Borsh => quote! { - let result = near_sdk::borsh::BorshSerialize::try_to_vec(&result).expect("Failed to serialize the return value using Borsh."); + let result = ::near_sdk::borsh::BorshSerialize::try_to_vec(&result).expect("Failed to serialize the return value using Borsh."); }, }; @@ -360,7 +360,7 @@ impl ImplItemMethodInfo { let value_return = || { quote! { - near_sdk::env::value_return(&result); + ::near_sdk::env::value_return(&result); } }; diff --git a/near-sdk-macros/src/core_impl/code_generator/item_impl_info.rs b/near-sdk-macros/src/core_impl/code_generator/item_impl_info.rs index ece480798..de66c53af 100644 --- a/near-sdk-macros/src/core_impl/code_generator/item_impl_info.rs +++ b/near-sdk-macros/src/core_impl/code_generator/item_impl_info.rs @@ -43,8 +43,8 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - let contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + ::near_sdk::env::setup_panic_hook(); + let contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); contract.method(); } ); @@ -61,8 +61,8 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - let contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + ::near_sdk::env::setup_panic_hook(); + let contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); contract.method(); } ); @@ -79,8 +79,8 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - let contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + ::near_sdk::env::setup_panic_hook(); + let contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); contract.method(); } ); @@ -98,8 +98,8 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - let mut contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + ::near_sdk::env::setup_panic_hook(); + let mut contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); contract.method(); } ); @@ -116,13 +116,13 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - if near_sdk::env::attached_deposit() != 0 { - near_sdk::env::panic_str("Method method doesn't accept deposit"); + ::near_sdk::env::setup_panic_hook(); + if ::near_sdk::env::attached_deposit() != 0 { + ::near_sdk::env::panic_str("Method method doesn't accept deposit"); } - let mut contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + let mut contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); contract.method(); - near_sdk::env::state_write(&contract); + ::near_sdk::env::state_write(&contract); } ); assert_eq!(expected.to_string(), actual.to_string()); @@ -138,17 +138,17 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - #[derive(near_sdk :: serde :: Deserialize)] - #[serde(crate = "near_sdk::serde")] + ::near_sdk::env::setup_panic_hook(); + #[derive(::near_sdk :: serde :: Deserialize)] + #[serde(crate = "::near_sdk::serde")] struct Input { k: u64, } - let Input { k, }: Input = near_sdk::serde_json::from_slice( - &near_sdk::env::input().expect("Expected input since method has arguments.") + let Input { k, }: Input = ::near_sdk::serde_json::from_slice( + &::near_sdk::env::input().expect("Expected input since method has arguments.") ) .expect("Failed to deserialize input from JSON."); - let contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + let contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); contract.method(k, ); } ); @@ -166,23 +166,23 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - if near_sdk::env::attached_deposit() != 0 { - near_sdk::env::panic_str("Method method doesn't accept deposit"); + ::near_sdk::env::setup_panic_hook(); + if ::near_sdk::env::attached_deposit() != 0 { + ::near_sdk::env::panic_str("Method method doesn't accept deposit"); } - #[derive(near_sdk :: serde :: Deserialize)] - #[serde(crate = "near_sdk::serde")] + #[derive(::near_sdk :: serde :: Deserialize)] + #[serde(crate = "::near_sdk::serde")] struct Input { k: u64, m: Bar, } - let Input { k, m, }: Input = near_sdk::serde_json::from_slice( - &near_sdk::env::input().expect("Expected input since method has arguments.") + let Input { k, m, }: Input = ::near_sdk::serde_json::from_slice( + &::near_sdk::env::input().expect("Expected input since method has arguments.") ) .expect("Failed to deserialize input from JSON."); - let mut contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + let mut contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); contract.method(k, m, ); - near_sdk::env::state_write(&contract); + ::near_sdk::env::state_write(&contract); } ); assert_eq!(expected.to_string(), actual.to_string()); @@ -199,26 +199,26 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - if near_sdk::env::attached_deposit() != 0 { - near_sdk::env::panic_str("Method method doesn't accept deposit"); + ::near_sdk::env::setup_panic_hook(); + if ::near_sdk::env::attached_deposit() != 0 { + ::near_sdk::env::panic_str("Method method doesn't accept deposit"); } - #[derive(near_sdk :: serde :: Deserialize)] - #[serde(crate = "near_sdk::serde")] + #[derive(::near_sdk :: serde :: Deserialize)] + #[serde(crate = "::near_sdk::serde")] struct Input { k: u64, m: Bar, } - let Input { k, m, }: Input = near_sdk::serde_json::from_slice( - &near_sdk::env::input().expect("Expected input since method has arguments.") + let Input { k, m, }: Input = ::near_sdk::serde_json::from_slice( + &::near_sdk::env::input().expect("Expected input since method has arguments.") ) .expect("Failed to deserialize input from JSON."); - let mut contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + let mut contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); let result = contract.method(k, m, ); let result = - near_sdk::serde_json::to_vec(&result).expect("Failed to serialize the return value using JSON."); - near_sdk::env::value_return(&result); - near_sdk::env::state_write(&contract); + ::near_sdk::serde_json::to_vec(&result).expect("Failed to serialize the return value using JSON."); + ::near_sdk::env::value_return(&result); + ::near_sdk::env::state_write(&contract); } ); assert_eq!(expected.to_string(), actual.to_string()); @@ -235,12 +235,12 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - let contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + ::near_sdk::env::setup_panic_hook(); + let contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); let result = contract.method(); let result = - near_sdk::serde_json::to_vec(&result).expect("Failed to serialize the return value using JSON."); - near_sdk::env::value_return(&result); + ::near_sdk::serde_json::to_vec(&result).expect("Failed to serialize the return value using JSON."); + ::near_sdk::env::value_return(&result); } ); assert_eq!(expected.to_string(), actual.to_string()); @@ -256,17 +256,17 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - #[derive(near_sdk :: serde :: Deserialize)] - #[serde(crate = "near_sdk::serde")] + ::near_sdk::env::setup_panic_hook(); + #[derive(::near_sdk :: serde :: Deserialize)] + #[serde(crate = "::near_sdk::serde")] struct Input { k: u64, } - let Input { k, }: Input = near_sdk::serde_json::from_slice( - &near_sdk::env::input().expect("Expected input since method has arguments.") + let Input { k, }: Input = ::near_sdk::serde_json::from_slice( + &::near_sdk::env::input().expect("Expected input since method has arguments.") ) .expect("Failed to deserialize input from JSON."); - let contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + let contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); contract.method(&k, ); } ); @@ -284,17 +284,17 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - #[derive(near_sdk :: serde :: Deserialize)] - #[serde(crate = "near_sdk::serde")] + ::near_sdk::env::setup_panic_hook(); + #[derive(::near_sdk :: serde :: Deserialize)] + #[serde(crate = "::near_sdk::serde")] struct Input { k: u64, } - let Input { mut k, }: Input = near_sdk::serde_json::from_slice( - &near_sdk::env::input().expect("Expected input since method has arguments.") + let Input { mut k, }: Input = ::near_sdk::serde_json::from_slice( + &::near_sdk::env::input().expect("Expected input since method has arguments.") ) .expect("Failed to deserialize input from JSON."); - let contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + let contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); contract.method(&mut k, ); } ); @@ -305,7 +305,7 @@ mod tests { fn callback_args() { let impl_type: Type = syn::parse_str("Hello").unwrap(); let mut method: ImplItemMethod = parse_quote! { - #[private] pub fn method(&self, #[callback_unwrap] x: &mut u64, y: String, #[callback_unwrap] z: Vec) { } + #[private] pub fn method(&self, #[callback_unwrap] x: &mut u64, y: ::std::string::String, #[callback_unwrap] z: ::std::vec::Vec) { } }; let method_info = ImplItemMethodInfo::new(&mut method, false, impl_type).unwrap().unwrap(); let actual = method_info.method_wrapper(); @@ -313,32 +313,32 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - if near_sdk::env::current_account_id() != near_sdk::env::predecessor_account_id() { - near_sdk::env::panic_str("Method method is private"); + ::near_sdk::env::setup_panic_hook(); + if ::near_sdk::env::current_account_id() != ::near_sdk::env::predecessor_account_id() { + ::near_sdk::env::panic_str("Method method is private"); } - #[derive(near_sdk :: serde :: Deserialize)] - #[serde(crate = "near_sdk::serde")] + #[derive(::near_sdk :: serde :: Deserialize)] + #[serde(crate = "::near_sdk::serde")] struct Input { - y: String, + y: ::std::string::String, } - let Input { y, }: Input = near_sdk::serde_json::from_slice( - &near_sdk::env::input().expect("Expected input since method has arguments.") + let Input { y, }: Input = ::near_sdk::serde_json::from_slice( + &::near_sdk::env::input().expect("Expected input since method has arguments.") ) .expect("Failed to deserialize input from JSON."); - let data: Vec = match near_sdk::env::promise_result(0u64) { - near_sdk::PromiseResult::Successful(x) => x, - _ => near_sdk::env::panic_str("Callback computation 0 was not successful") + let data: ::std::vec::Vec = match ::near_sdk::env::promise_result(0u64) { + ::near_sdk::PromiseResult::Successful(x) => x, + _ => ::near_sdk::env::panic_str("Callback computation 0 was not successful") }; let mut x: u64 = - near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON"); - let data: Vec = match near_sdk::env::promise_result(1u64) { - near_sdk::PromiseResult::Successful(x) => x, - _ => near_sdk::env::panic_str("Callback computation 1 was not successful") + ::near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON"); + let data: ::std::vec::Vec = match ::near_sdk::env::promise_result(1u64) { + ::near_sdk::PromiseResult::Successful(x) => x, + _ => ::near_sdk::env::panic_str("Callback computation 1 was not successful") }; - let z: Vec = - near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON"); - let contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + let z: ::std::vec::Vec = + ::near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON"); + let contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); contract.method(&mut x, y, z, ); } ); @@ -349,7 +349,7 @@ mod tests { fn callback_args_only() { let impl_type: Type = syn::parse_str("Hello").unwrap(); let mut method: ImplItemMethod = parse_quote! { - #[private] pub fn method(&self, #[callback_unwrap] x: &mut u64, #[callback_unwrap] y: String) { } + #[private] pub fn method(&self, #[callback_unwrap] x: &mut u64, #[callback_unwrap] y: ::std::string::String) { } }; let method_info = ImplItemMethodInfo::new(&mut method, false, impl_type).unwrap().unwrap(); let actual = method_info.method_wrapper(); @@ -357,23 +357,23 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - if near_sdk::env::current_account_id() != near_sdk::env::predecessor_account_id() { - near_sdk::env::panic_str("Method method is private"); + ::near_sdk::env::setup_panic_hook(); + if ::near_sdk::env::current_account_id() != ::near_sdk::env::predecessor_account_id() { + ::near_sdk::env::panic_str("Method method is private"); } - let data: Vec = match near_sdk::env::promise_result(0u64) { - near_sdk::PromiseResult::Successful(x) => x, - _ => near_sdk::env::panic_str("Callback computation 0 was not successful") + let data: ::std::vec::Vec = match ::near_sdk::env::promise_result(0u64) { + ::near_sdk::PromiseResult::Successful(x) => x, + _ => ::near_sdk::env::panic_str("Callback computation 0 was not successful") }; let mut x: u64 = - near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON"); - let data: Vec = match near_sdk::env::promise_result(1u64) { - near_sdk::PromiseResult::Successful(x) => x, - _ => near_sdk::env::panic_str("Callback computation 1 was not successful") + ::near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON"); + let data: ::std::vec::Vec = match ::near_sdk::env::promise_result(1u64) { + ::near_sdk::PromiseResult::Successful(x) => x, + _ => ::near_sdk::env::panic_str("Callback computation 1 was not successful") }; - let y: String = - near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON"); - let contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + let y: ::std::string::String = + ::near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON"); + let contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); contract.method(&mut x, y, ); } ); @@ -385,7 +385,7 @@ mod tests { fn callback_args_results() { let impl_type: Type = syn::parse_str("Hello").unwrap(); let mut method: ImplItemMethod = parse_quote! { - #[private] pub fn method(&self, #[callback_result] x: &mut Result, #[callback_result] y: Result) { } + #[private] pub fn method(&self, #[callback_result] x: &mut Result, #[callback_result] y: Result<::std::string::String, PromiseError>) { } }; let method_info = ImplItemMethodInfo::new(&mut method, false, impl_type).unwrap().unwrap(); let actual = method_info.method_wrapper(); @@ -393,19 +393,19 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - if near_sdk::env::current_account_id() != near_sdk::env::predecessor_account_id() { - near_sdk::env::panic_str("Method method is private"); + ::near_sdk::env::setup_panic_hook(); + if ::near_sdk::env::current_account_id() != ::near_sdk::env::predecessor_account_id() { + ::near_sdk::env::panic_str("Method method is private"); } - let mut x: Result = match near_sdk::env::promise_result(0u64) { - near_sdk::PromiseResult::Successful(data) => Ok(near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON")), - near_sdk::PromiseResult::Failed => Err(near_sdk::PromiseError::Failed), + let mut x: Result = match ::near_sdk::env::promise_result(0u64) { + ::near_sdk::PromiseResult::Successful(data) => ::std::result::Result::Ok(::near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON")), + ::near_sdk::PromiseResult::Failed => ::std::result::Result::Err(::near_sdk::PromiseError::Failed), }; - let y: Result = match near_sdk::env::promise_result(1u64) { - near_sdk::PromiseResult::Successful(data) => Ok(near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON")), - near_sdk::PromiseResult::Failed => Err(near_sdk::PromiseError::Failed), + let y: Result<::std::string::String, PromiseError> = match ::near_sdk::env::promise_result(1u64) { + ::near_sdk::PromiseResult::Successful(data) => ::std::result::Result::Ok(::near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON")), + ::near_sdk::PromiseResult::Failed => ::std::result::Result::Err(::near_sdk::PromiseError::Failed), }; - let contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + let contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); contract.method(&mut x, y, ); } ); @@ -425,29 +425,27 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - if near_sdk::env::current_account_id() != near_sdk::env::predecessor_account_id() { - near_sdk::env::panic_str("Method method is private"); + ::near_sdk::env::setup_panic_hook(); + if ::near_sdk::env::current_account_id() != ::near_sdk::env::predecessor_account_id() { + ::near_sdk::env::panic_str("Method method is private"); } - #[derive(near_sdk :: serde :: Deserialize)] - #[serde(crate = "near_sdk::serde")] + #[derive(::near_sdk :: serde :: Deserialize)] + #[serde(crate = "::near_sdk::serde")] struct Input { y: String, } - let Input { y, }: Input = near_sdk::serde_json::from_slice( - &near_sdk::env::input().expect("Expected input since method has arguments.") + let Input { y, }: Input = ::near_sdk::serde_json::from_slice( + &::near_sdk::env::input().expect("Expected input since method has arguments.") ) .expect("Failed to deserialize input from JSON."); - let x: Vec = (0..near_sdk::env::promise_results_count()) - .map(|i| { - let data: Vec = match near_sdk::env::promise_result(i) { - near_sdk::PromiseResult::Successful(x) => x, - _ => near_sdk::env::panic_str(&format!("Callback computation {} was not successful", i)), + let x: Vec = ::std::iter::Iterator::collect(::std::iter::Iterator::map(0..::near_sdk::env::promise_results_count(), |i| { + let data: ::std::vec::Vec = match ::near_sdk::env::promise_result(i) { + ::near_sdk::PromiseResult::Successful(x) => x, + _ => ::near_sdk::env::panic_str(&::std::format!("Callback computation {} was not successful", i)), }; - near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON") - }) - .collect(); - let contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + ::near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON") + })); + let contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); contract.method(x, y, ); } ); @@ -467,24 +465,24 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - if near_sdk::env::attached_deposit() != 0 { - near_sdk::env::panic_str("Method method doesn't accept deposit"); + ::near_sdk::env::setup_panic_hook(); + if ::near_sdk::env::attached_deposit() != 0 { + ::near_sdk::env::panic_str("Method method doesn't accept deposit"); } - #[derive(near_sdk :: serde :: Deserialize)] - #[serde(crate = "near_sdk::serde")] + #[derive(::near_sdk :: serde :: Deserialize)] + #[serde(crate = "::near_sdk::serde")] struct Input { k: u64, } - let Input { mut k, }: Input = near_sdk::serde_json::from_slice( - &near_sdk::env::input().expect("Expected input since method has arguments.") + let Input { mut k, }: Input = ::near_sdk::serde_json::from_slice( + &::near_sdk::env::input().expect("Expected input since method has arguments.") ) .expect("Failed to deserialize input from JSON."); - if near_sdk::env::state_exists() { - near_sdk::env::panic_str("The contract has already been initialized"); + if ::near_sdk::env::state_exists() { + ::near_sdk::env::panic_str("The contract has already been initialized"); } let contract = Hello::method(&mut k,); - near_sdk::env::state_write(&contract); + ::near_sdk::env::state_write(&contract); } ); assert_eq!(expected.to_string(), actual.to_string()); @@ -515,21 +513,21 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - if near_sdk::env::attached_deposit() != 0 { - near_sdk::env::panic_str("Method method doesn't accept deposit"); + ::near_sdk::env::setup_panic_hook(); + if ::near_sdk::env::attached_deposit() != 0 { + ::near_sdk::env::panic_str("Method method doesn't accept deposit"); } - #[derive(near_sdk :: serde :: Deserialize)] - #[serde(crate = "near_sdk::serde")] + #[derive(::near_sdk :: serde :: Deserialize)] + #[serde(crate = "::near_sdk::serde")] struct Input { k: u64, } - let Input { mut k, }: Input = near_sdk::serde_json::from_slice( - &near_sdk::env::input().expect("Expected input since method has arguments.") + let Input { mut k, }: Input = ::near_sdk::serde_json::from_slice( + &::near_sdk::env::input().expect("Expected input since method has arguments.") ) .expect("Failed to deserialize input from JSON."); let contract = Hello::method(&mut k,); - near_sdk::env::state_write(&contract); + ::near_sdk::env::state_write(&contract); } ); assert_eq!(expected.to_string(), actual.to_string()); @@ -549,21 +547,21 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - #[derive(near_sdk :: serde :: Deserialize)] - #[serde(crate = "near_sdk::serde")] + ::near_sdk::env::setup_panic_hook(); + #[derive(::near_sdk :: serde :: Deserialize)] + #[serde(crate = "::near_sdk::serde")] struct Input { k: u64, } - let Input { mut k, }: Input = near_sdk::serde_json::from_slice( - &near_sdk::env::input().expect("Expected input since method has arguments.") + let Input { mut k, }: Input = ::near_sdk::serde_json::from_slice( + &::near_sdk::env::input().expect("Expected input since method has arguments.") ) .expect("Failed to deserialize input from JSON."); - if near_sdk::env::state_exists() { - near_sdk::env::panic_str("The contract has already been initialized"); + if ::near_sdk::env::state_exists() { + ::near_sdk::env::panic_str("The contract has already been initialized"); } let contract = Hello::method(&mut k,); - near_sdk::env::state_write(&contract); + ::near_sdk::env::state_write(&contract); } ); assert_eq!(expected.to_string(), actual.to_string()); @@ -582,25 +580,25 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - if near_sdk::env::attached_deposit() != 0 { - near_sdk::env::panic_str("Method method doesn't accept deposit"); + ::near_sdk::env::setup_panic_hook(); + if ::near_sdk::env::attached_deposit() != 0 { + ::near_sdk::env::panic_str("Method method doesn't accept deposit"); } - #[derive(near_sdk :: borsh :: BorshDeserialize)] + #[derive(::near_sdk :: borsh :: BorshDeserialize)] struct Input { k: u64, m: Bar, } - let Input { k, m, }: Input = near_sdk::borsh::BorshDeserialize::try_from_slice( - &near_sdk::env::input().expect("Expected input since method has arguments.") + let Input { k, m, }: Input = ::near_sdk::borsh::BorshDeserialize::try_from_slice( + &::near_sdk::env::input().expect("Expected input since method has arguments.") ) .expect("Failed to deserialize input from Borsh."); - let mut contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + let mut contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); let result = contract.method(k, m, ); - let result = near_sdk::borsh::BorshSerialize::try_to_vec(&result) + let result = ::near_sdk::borsh::BorshSerialize::try_to_vec(&result) .expect("Failed to serialize the return value using Borsh."); - near_sdk::env::value_return(&result); - near_sdk::env::state_write(&contract); + ::near_sdk::env::value_return(&result); + ::near_sdk::env::state_write(&contract); } ); assert_eq!(expected.to_string(), actual.to_string()); @@ -610,7 +608,7 @@ mod tests { fn callback_args_mixed_serialization() { let impl_type: Type = syn::parse_str("Hello").unwrap(); let mut method: ImplItemMethod = parse_quote! { - #[private] pub fn method(&self, #[callback_unwrap] #[serializer(borsh)] x: &mut u64, #[serializer(borsh)] y: String, #[callback_unwrap] #[serializer(json)] z: Vec) { } + #[private] pub fn method(&self, #[callback_unwrap] #[serializer(borsh)] x: &mut u64, #[serializer(borsh)] y: ::std::string::String, #[callback_unwrap] #[serializer(json)] z: ::std::vec::Vec) { } }; let method_info = ImplItemMethodInfo::new(&mut method, false, impl_type).unwrap().unwrap(); let actual = method_info.method_wrapper(); @@ -618,31 +616,31 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - if near_sdk::env::current_account_id() != near_sdk::env::predecessor_account_id() { - near_sdk::env::panic_str("Method method is private"); + ::near_sdk::env::setup_panic_hook(); + if ::near_sdk::env::current_account_id() != ::near_sdk::env::predecessor_account_id() { + ::near_sdk::env::panic_str("Method method is private"); } - #[derive(near_sdk :: borsh :: BorshDeserialize)] + #[derive(::near_sdk :: borsh :: BorshDeserialize)] struct Input { - y: String, + y: ::std::string::String, } - let Input { y, }: Input = near_sdk::borsh::BorshDeserialize::try_from_slice( - &near_sdk::env::input().expect("Expected input since method has arguments.") + let Input { y, }: Input = ::near_sdk::borsh::BorshDeserialize::try_from_slice( + &::near_sdk::env::input().expect("Expected input since method has arguments.") ) .expect("Failed to deserialize input from Borsh."); - let data: Vec = match near_sdk::env::promise_result(0u64) { - near_sdk::PromiseResult::Successful(x) => x, - _ => near_sdk::env::panic_str("Callback computation 0 was not successful") + let data: ::std::vec::Vec = match ::near_sdk::env::promise_result(0u64) { + ::near_sdk::PromiseResult::Successful(x) => x, + _ => ::near_sdk::env::panic_str("Callback computation 0 was not successful") }; - let mut x: u64 = near_sdk::borsh::BorshDeserialize::try_from_slice(&data) + let mut x: u64 = ::near_sdk::borsh::BorshDeserialize::try_from_slice(&data) .expect("Failed to deserialize callback using Borsh"); - let data: Vec = match near_sdk::env::promise_result(1u64) { - near_sdk::PromiseResult::Successful(x) => x, - _ => near_sdk::env::panic_str("Callback computation 1 was not successful") + let data: ::std::vec::Vec = match ::near_sdk::env::promise_result(1u64) { + ::near_sdk::PromiseResult::Successful(x) => x, + _ => ::near_sdk::env::panic_str("Callback computation 1 was not successful") }; - let z: Vec = - near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON"); - let contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + let z: ::std::vec::Vec = + ::near_sdk::serde_json::from_slice(&data).expect("Failed to deserialize callback using JSON"); + let contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); contract.method(&mut x, y, z, ); } ); @@ -659,10 +657,10 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - let mut contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + ::near_sdk::env::setup_panic_hook(); + let mut contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); contract.method(); - near_sdk::env::state_write(&contract); + ::near_sdk::env::state_write(&contract); } ); assert_eq!(expected.to_string(), actual.to_string()); @@ -678,16 +676,16 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn private_method() { - near_sdk::env::setup_panic_hook(); - if near_sdk::env::current_account_id() != near_sdk::env::predecessor_account_id() { - near_sdk::env::panic_str("Method private_method is private"); + ::near_sdk::env::setup_panic_hook(); + if ::near_sdk::env::current_account_id() != ::near_sdk::env::predecessor_account_id() { + ::near_sdk::env::panic_str("Method private_method is private"); } - if near_sdk::env::attached_deposit() != 0 { - near_sdk::env::panic_str("Method private_method doesn't accept deposit"); + if ::near_sdk::env::attached_deposit() != 0 { + ::near_sdk::env::panic_str("Method private_method doesn't accept deposit"); } - let mut contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + let mut contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); contract.private_method(); - near_sdk::env::state_write(&contract); + ::near_sdk::env::state_write(&contract); } ); assert_eq!(expected.to_string(), actual.to_string()); @@ -698,7 +696,7 @@ mod tests { let impl_type: Type = syn::parse_str("Hello").unwrap(); let mut method: ImplItemMethod = parse_quote! { #[handle_result] - pub fn method(&self) -> Result { } + pub fn method(&self) -> Result:: { } }; let method_info = ImplItemMethodInfo::new(&mut method, false, impl_type).unwrap().unwrap(); let actual = method_info.method_wrapper(); @@ -706,16 +704,16 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - let contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + ::near_sdk::env::setup_panic_hook(); + let contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); let result = contract.method(); match result { - Ok(result) => { + ::std::result::Result::Ok(result) => { let result = - near_sdk::serde_json::to_vec(&result).expect("Failed to serialize the return value using JSON."); - near_sdk::env::value_return(&result); + ::near_sdk::serde_json::to_vec(&result).expect("Failed to serialize the return value using JSON."); + ::near_sdk::env::value_return(&result); } - Err(err) => near_sdk::FunctionError::panic(&err) + ::std::result::Result::Err(err) => ::near_sdk::FunctionError::panic(&err) } } ); @@ -735,20 +733,20 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - if near_sdk::env::attached_deposit() != 0 { - near_sdk::env::panic_str("Method method doesn't accept deposit"); + ::near_sdk::env::setup_panic_hook(); + if ::near_sdk::env::attached_deposit() != 0 { + ::near_sdk::env::panic_str("Method method doesn't accept deposit"); } - let mut contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + let mut contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); let result = contract.method(); match result { - Ok(result) => { + ::std::result::Result::Ok(result) => { let result = - near_sdk::serde_json::to_vec(&result).expect("Failed to serialize the return value using JSON."); - near_sdk::env::value_return(&result); - near_sdk::env::state_write(&contract); + ::near_sdk::serde_json::to_vec(&result).expect("Failed to serialize the return value using JSON."); + ::near_sdk::env::value_return(&result); + ::near_sdk::env::state_write(&contract); } - Err(err) => near_sdk::FunctionError::panic(&err) + ::std::result::Result::Err(err) => ::near_sdk::FunctionError::panic(&err) } } ); @@ -769,16 +767,16 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); - let contract: Hello = near_sdk::env::state_read().unwrap_or_default(); + ::near_sdk::env::setup_panic_hook(); + let contract: Hello = ::near_sdk::env::state_read().unwrap_or_default(); let result = contract.method(); match result { - Ok(result) => { + ::std::result::Result::Ok(result) => { let result = - near_sdk::borsh::BorshSerialize::try_to_vec(&result).expect("Failed to serialize the return value using Borsh."); - near_sdk::env::value_return(&result); + ::near_sdk::borsh::BorshSerialize::try_to_vec(&result).expect("Failed to serialize the return value using Borsh."); + ::near_sdk::env::value_return(&result); } - Err(err) => near_sdk::FunctionError::panic(&err) + ::std::result::Result::Err(err) => ::near_sdk::FunctionError::panic(&err) } } ); @@ -799,19 +797,19 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn new() { - near_sdk::env::setup_panic_hook(); - if near_sdk::env::attached_deposit() != 0 { - near_sdk::env::panic_str("Method new doesn't accept deposit"); + ::near_sdk::env::setup_panic_hook(); + if ::near_sdk::env::attached_deposit() != 0 { + ::near_sdk::env::panic_str("Method new doesn't accept deposit"); } - if near_sdk::env::state_exists() { - near_sdk::env::panic_str("The contract has already been initialized"); + if ::near_sdk::env::state_exists() { + ::near_sdk::env::panic_str("The contract has already been initialized"); } let contract = Hello::new(); match contract { - Ok(contract) => { - near_sdk::env::state_write(&contract); + ::std::result::Result::Ok(contract) => { + ::near_sdk::env::state_write(&contract); } - Err(err) => near_sdk::FunctionError::panic(&err) + ::std::result::Result::Err(err) => ::near_sdk::FunctionError::panic(&err) } } ); @@ -832,16 +830,16 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn new() { - near_sdk::env::setup_panic_hook(); - if near_sdk::env::attached_deposit() != 0 { - near_sdk::env::panic_str("Method new doesn't accept deposit"); + ::near_sdk::env::setup_panic_hook(); + if ::near_sdk::env::attached_deposit() != 0 { + ::near_sdk::env::panic_str("Method new doesn't accept deposit"); } let contract = Hello::new(); match contract { - Ok(contract) => { - near_sdk::env::state_write(&contract); + ::std::result::Result::Ok(contract) => { + ::near_sdk::env::state_write(&contract); } - Err(err) => near_sdk::FunctionError::panic(&err) + ::std::result::Result::Err(err) => ::near_sdk::FunctionError::panic(&err) } } ); @@ -858,7 +856,7 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn method() { - near_sdk::env::setup_panic_hook(); + ::near_sdk::env::setup_panic_hook(); Hello::method(); } ); diff --git a/near-sdk-macros/src/core_impl/code_generator/item_trait_info.rs b/near-sdk-macros/src/core_impl/code_generator/item_trait_info.rs index 16604834b..b6d263515 100644 --- a/near-sdk-macros/src/core_impl/code_generator/item_trait_info.rs +++ b/near-sdk-macros/src/core_impl/code_generator/item_trait_info.rs @@ -37,16 +37,16 @@ mod tests { let mut t: ItemTrait = syn::parse2( quote!{ pub trait ExternalCrossContract { - fn merge_sort(&self, arr: Vec) -> PromiseOrValue>; + fn merge_sort(&self, arr: ::std::vec::Vec) -> PromiseOrValue<::std::vec::Vec>; fn merge( &self, #[callback_unwrap] #[serializer(borsh)] - data0: Vec, + data0: ::std::vec::Vec, #[callback_unwrap] #[serializer(borsh)] - data1: Vec, - ) -> Vec; + data1: ::std::vec::Vec, + ) -> ::std::vec::Vec; } } ).unwrap(); @@ -58,63 +58,63 @@ mod tests { use super::*; #[must_use] pub struct ExternalCrossContractExt { - pub(crate) account_id: near_sdk::AccountId, - pub(crate) deposit: near_sdk::Balance, - pub(crate) static_gas: near_sdk::Gas, - pub(crate) gas_weight: near_sdk::GasWeight, + pub(crate) account_id: ::near_sdk::AccountId, + pub(crate) deposit: ::near_sdk::Balance, + pub(crate) static_gas: ::near_sdk::Gas, + pub(crate) gas_weight: ::near_sdk::GasWeight, } impl ExternalCrossContractExt { - pub fn with_attached_deposit(mut self, amount: near_sdk::Balance) -> Self { + pub fn with_attached_deposit(mut self, amount: ::near_sdk::Balance) -> Self { self.deposit = amount; self } - pub fn with_static_gas(mut self, static_gas: near_sdk::Gas) -> Self { + pub fn with_static_gas(mut self, static_gas: ::near_sdk::Gas) -> Self { self.static_gas = static_gas; self } pub fn with_unused_gas_weight(mut self, gas_weight: u64) -> Self { - self.gas_weight = near_sdk::GasWeight(gas_weight); + self.gas_weight = ::near_sdk::GasWeight(gas_weight); self } } /// API for calling this contract's functions in a subsequent execution. - pub fn ext(account_id: near_sdk::AccountId) -> ExternalCrossContractExt { + pub fn ext(account_id: ::near_sdk::AccountId) -> ExternalCrossContractExt { ExternalCrossContractExt { account_id, deposit: 0, - static_gas: near_sdk::Gas(0), - gas_weight: near_sdk::GasWeight::default(), + static_gas: ::near_sdk::Gas(0), + gas_weight: ::near_sdk::GasWeight::default(), } } impl ExternalCrossContractExt { pub fn merge_sort( self, - arr: Vec, - ) -> near_sdk::Promise { + arr: ::std::vec::Vec, + ) -> ::near_sdk::Promise { let __args = { - #[derive(near_sdk :: serde :: Serialize)] - #[serde(crate = "near_sdk::serde")] + #[derive(::near_sdk :: serde :: Serialize)] + #[serde(crate = "::near_sdk::serde")] struct Input<'nearinput> { - arr: &'nearinput Vec, + arr: &'nearinput ::std::vec::Vec, } let __args = Input { arr: &arr, }; - near_sdk::serde_json::to_vec(&__args) + ::near_sdk::serde_json::to_vec(&__args) .expect("Failed to serialize the cross contract args using JSON.") }; - near_sdk::Promise::new(self.account_id) + ::near_sdk::Promise::new(self.account_id) .function_call_weight( - "merge_sort".to_string(), + ::std::string::String::from("merge_sort"), __args, self.deposit, self.static_gas, self.gas_weight, ) } - pub fn merge(self,) -> near_sdk::Promise { - let __args = vec![]; - near_sdk::Promise::new(self.account_id) + pub fn merge(self,) -> ::near_sdk::Promise { + let __args = ::std::vec![]; + ::near_sdk::Promise::new(self.account_id) .function_call_weight( - "merge".to_string(), + ::std::string::String::from("merge"), __args, self.deposit, self.static_gas, @@ -133,7 +133,7 @@ mod tests { quote!{ trait Test { #[result_serializer(borsh)] - fn test(#[serializer(borsh)] v: Vec) -> Vec; + fn test(#[serializer(borsh)] v: ::std::vec::Vec) -> ::std::vec::Vec; } } ).unwrap(); @@ -145,51 +145,51 @@ mod tests { use super::*; #[must_use] pub struct TestExt { - pub(crate) account_id: near_sdk::AccountId, - pub(crate) deposit: near_sdk::Balance, - pub(crate) static_gas: near_sdk::Gas, - pub(crate) gas_weight: near_sdk::GasWeight, + pub(crate) account_id: ::near_sdk::AccountId, + pub(crate) deposit: ::near_sdk::Balance, + pub(crate) static_gas: ::near_sdk::Gas, + pub(crate) gas_weight: ::near_sdk::GasWeight, } impl TestExt { - pub fn with_attached_deposit(mut self, amount: near_sdk::Balance) -> Self { + pub fn with_attached_deposit(mut self, amount: ::near_sdk::Balance) -> Self { self.deposit = amount; self } - pub fn with_static_gas(mut self, static_gas: near_sdk::Gas) -> Self { + pub fn with_static_gas(mut self, static_gas: ::near_sdk::Gas) -> Self { self.static_gas = static_gas; self } pub fn with_unused_gas_weight(mut self, gas_weight: u64) -> Self { - self.gas_weight = near_sdk::GasWeight(gas_weight); + self.gas_weight = ::near_sdk::GasWeight(gas_weight); self } } /// API for calling this contract's functions in a subsequent execution. - pub fn ext(account_id: near_sdk::AccountId) -> TestExt { + pub fn ext(account_id: ::near_sdk::AccountId) -> TestExt { TestExt { account_id, deposit: 0, - static_gas: near_sdk::Gas(0), - gas_weight: near_sdk::GasWeight::default(), + static_gas: ::near_sdk::Gas(0), + gas_weight: ::near_sdk::GasWeight::default(), } } impl TestExt { pub fn test( self, - v: Vec, - ) -> near_sdk::Promise { + v: ::std::vec::Vec, + ) -> ::near_sdk::Promise { let __args = { - #[derive(near_sdk :: borsh :: BorshSerialize)] + #[derive(::near_sdk :: borsh :: BorshSerialize)] struct Input<'nearinput> { - v: &'nearinput Vec, + v: &'nearinput ::std::vec::Vec, } let __args = Input { v: &v, }; - near_sdk::borsh::BorshSerialize::try_to_vec(&__args) + ::near_sdk::borsh::BorshSerialize::try_to_vec(&__args) .expect("Failed to serialize the cross contract args using Borsh.") }; - near_sdk::Promise::new(self.account_id) + ::near_sdk::Promise::new(self.account_id) .function_call_weight( - "test".to_string(), + ::std::string::String::from("test"), __args, self.deposit, self.static_gas, diff --git a/near-sdk-macros/src/core_impl/code_generator/serializer.rs b/near-sdk-macros/src/core_impl/code_generator/serializer.rs index 76da7a118..f499ee670 100644 --- a/near-sdk-macros/src/core_impl/code_generator/serializer.rs +++ b/near-sdk-macros/src/core_impl/code_generator/serializer.rs @@ -8,17 +8,17 @@ pub fn generate_serializer( ) -> TokenStream2 { let has_input_args = attr_sig_info.input_args().next().is_some(); if !has_input_args { - return quote! { vec![] }; + return quote! { ::std::vec![] }; } let struct_decl = attr_sig_info.input_struct_ser(); let constructor_call = attr_sig_info.constructor_expr_ref(); let constructor = quote! { let __args = #constructor_call; }; let value_ser = match serializer { SerializerType::JSON => quote! { - near_sdk::serde_json::to_vec(&__args).expect("Failed to serialize the cross contract args using JSON.") + ::near_sdk::serde_json::to_vec(&__args).expect("Failed to serialize the cross contract args using JSON.") }, SerializerType::Borsh => quote! { - near_sdk::borsh::BorshSerialize::try_to_vec(&__args).expect("Failed to serialize the cross contract args using Borsh.") + ::near_sdk::borsh::BorshSerialize::try_to_vec(&__args).expect("Failed to serialize the cross contract args using Borsh.") }, }; diff --git a/near-sdk-macros/src/core_impl/event/mod.rs b/near-sdk-macros/src/core_impl/event/mod.rs index 7bfc698e6..75b1aa54e 100644 --- a/near-sdk-macros/src/core_impl/event/mod.rs +++ b/near-sdk-macros/src/core_impl/event/mod.rs @@ -24,10 +24,10 @@ pub(crate) fn near_events(attr: TokenStream, item: TokenStream) -> TokenStream { let standard_name = format!("{}_event_standard", name); let standard_ident = syn::Ident::new(&standard_name, Span::call_site()); // NearEvent Macro handles implementation - input - .attrs - .push(parse_quote! (#[derive(near_sdk::serde::Serialize, near_sdk::EventMetadata)])); - input.attrs.push(parse_quote! (#[serde(crate="near_sdk::serde")])); + input.attrs.push( + parse_quote! (#[derive(::near_sdk::serde::Serialize, ::near_sdk::EventMetadata)]), + ); + input.attrs.push(parse_quote! (#[serde(crate="::near_sdk::serde")])); input.attrs.push(parse_quote! (#[serde(tag = "event", content = "data")])); input.attrs.push(parse_quote! (#[serde(rename_all = "snake_case")])); diff --git a/near-sdk-macros/src/core_impl/metadata/metadata_generator.rs b/near-sdk-macros/src/core_impl/metadata/metadata_generator.rs index d8d72d482..03fe5912d 100644 --- a/near-sdk-macros/src/core_impl/metadata/metadata_generator.rs +++ b/near-sdk-macros/src/core_impl/metadata/metadata_generator.rs @@ -44,7 +44,7 @@ impl ImplItemMethodInfo { let additional_schema = match &self.attr_signature_info.input_serializer { SerializerType::Borsh => TokenStream2::new(), SerializerType::JSON => quote! { - #[derive(borsh::BorshSchema)] + #[derive(::borsh::BorshSchema)] }, }; quote! { @@ -52,12 +52,12 @@ impl ImplItemMethodInfo { #additional_schema #[allow(dead_code)] #input_struct - Some(Input::schema_container()) + ::std::option::Option::Some(::schema_container()) } } } else { quote! { - None + ::std::option::Option::None } }; let callbacks: Vec<_> = self @@ -68,7 +68,7 @@ impl ImplItemMethodInfo { .map(|arg| { let ty = &arg.ty; quote! { - #ty::schema_container() + <#ty as ::near_sdk::borsh::BorshSchema>::schema_container() } }) .collect(); @@ -81,36 +81,36 @@ impl ImplItemMethodInfo { { None => { quote! { - None + ::std::option::Option::None } } Some(arg) => { let ty = &arg.ty; quote! { - Some(#ty::schema_container()) + ::std::option::Option::Some(<#ty as ::near_sdk::borsh::BorshSchema>::schema_container()) } } }; let result = match &self.attr_signature_info.returns.original { ReturnType::Default => { quote! { - None + ::std::option::Option::None } } ReturnType::Type(_, ty) => { quote! { - Some(#ty::schema_container()) + ::std::option::Option::Some(<#ty as ::near_sdk::borsh::BorshSchema>::schema_container()) } } }; quote! { - near_sdk::__private::MethodMetadata { - name: #method_name_str.to_string(), + ::near_sdk::__private::MethodMetadata { + name: ::std::string::String::from(#method_name_str), is_view: #is_view, is_init: #is_init, args: #args, - callbacks: vec![#(#callbacks),*], + callbacks: ::std::vec![#(#callbacks),*], callbacks_vec: #callbacks_vec, result: #result } diff --git a/near-sdk-macros/src/core_impl/metadata/metadata_visitor.rs b/near-sdk-macros/src/core_impl/metadata/metadata_visitor.rs index 686a8a5e1..0721ab7af 100644 --- a/near-sdk-macros/src/core_impl/metadata/metadata_visitor.rs +++ b/near-sdk-macros/src/core_impl/metadata/metadata_visitor.rs @@ -43,7 +43,7 @@ impl MetadataVisitor { return Err(self.errors[0].clone()); } let panic_hook = quote! { - near_sdk::env::setup_panic_hook(); + ::near_sdk::env::setup_panic_hook(); }; let methods: Vec = self .impl_item_infos @@ -56,12 +56,12 @@ impl MetadataVisitor { #[no_mangle] pub extern "C" fn metadata() { #panic_hook - use borsh::*; - let metadata = near_sdk::__private::Metadata::new(vec![ + use ::borsh::*; + let metadata = ::near_sdk::__private::Metadata::new(::std::vec![ #(#methods),* ]); - let data = near_sdk::borsh::BorshSerialize::try_to_vec(&metadata).expect("Failed to serialize the metadata using Borsh"); - near_sdk::env::value_return(&data); + let data = ::near_sdk::borsh::BorshSerialize::try_to_vec(&metadata).expect("Failed to serialize the metadata using Borsh"); + ::near_sdk::env::value_return(&data); } }) } @@ -98,60 +98,60 @@ mod tests { #[cfg(target_arch = "wasm32")] #[no_mangle] pub extern "C" fn metadata() { - near_sdk::env::setup_panic_hook(); - use borsh::*; - let metadata = near_sdk::__private::Metadata::new(vec![ - near_sdk::__private::MethodMetadata { - name: "f1".to_string(), + ::near_sdk::env::setup_panic_hook(); + use ::borsh::*; + let metadata = ::near_sdk::__private::Metadata::new(::std::vec![ + ::near_sdk::__private::MethodMetadata { + name: ::std::string::String::from("f1"), is_view: true, is_init: false, - args: None, - callbacks: vec![], - callbacks_vec: None, - result: None + args: ::std::option::Option::None, + callbacks: ::std::vec![], + callbacks_vec: ::std::option::Option::None, + result: ::std::option::Option::None }, - near_sdk::__private::MethodMetadata { - name: "f2".to_string(), + ::near_sdk::__private::MethodMetadata { + name: ::std::string::String::from("f2"), is_view: false, is_init: false, args: { - #[derive(borsh::BorshSchema)] + #[derive(::borsh::BorshSchema)] #[allow(dead_code)] - #[derive(near_sdk :: serde :: Deserialize)] - #[serde(crate = "near_sdk::serde")] + #[derive(::near_sdk :: serde :: Deserialize)] + #[serde(crate = "::near_sdk::serde")] struct Input { arg0: FancyStruct, arg1: u64, } - Some(Input::schema_container()) + ::std::option::Option::Some(::schema_container()) }, - callbacks: vec![], - callbacks_vec: None, - result: None + callbacks: ::std::vec![], + callbacks_vec: ::std::option::Option::None, + result: ::std::option::Option::None }, - near_sdk::__private::MethodMetadata { - name: "f3".to_string(), + ::near_sdk::__private::MethodMetadata { + name: ::std::string::String::from("f3"), is_view: false, is_init: false, args: { - #[derive(borsh::BorshSchema)] + #[derive(::borsh::BorshSchema)] #[allow(dead_code)] - #[derive(near_sdk :: serde :: Deserialize)] - #[serde(crate = "near_sdk::serde")] + #[derive(::near_sdk :: serde :: Deserialize)] + #[serde(crate = "::near_sdk::serde")] struct Input { arg0: FancyStruct, arg1: u64, } - Some(Input::schema_container()) + ::std::option::Option::Some(::schema_container()) }, - callbacks: vec![], - callbacks_vec: None, - result: Some(Either < IsOk, Error > ::schema_container()) + callbacks: ::std::vec![], + callbacks_vec: ::std::option::Option::None, + result: ::std::option::Option::Some( as ::near_sdk::borsh::BorshSchema> ::schema_container()) } ]); - let data = near_sdk::borsh::BorshSerialize::try_to_vec(&metadata) + let data = ::near_sdk::borsh::BorshSerialize::try_to_vec(&metadata) .expect("Failed to serialize the metadata using Borsh"); - near_sdk::env::value_return(&data); + ::near_sdk::env::value_return(&data); } ); assert_eq!(expected.to_string(), actual.to_string()); diff --git a/near-sdk-macros/src/lib.rs b/near-sdk-macros/src/lib.rs index 5f95fe08e..37081425b 100644 --- a/near-sdk-macros/src/lib.rs +++ b/near-sdk-macros/src/lib.rs @@ -435,8 +435,8 @@ pub fn derive_near_schema(input: TokenStream) -> TokenStream { #[allow(non_camel_case_types)] type #input_ident_proxy = #input_ident; { - use near_sdk::borsh; - use near_sdk::__private::schemars; + use ::near_sdk::borsh; + use ::near_sdk::__private::schemars; #derive #input @@ -457,9 +457,9 @@ pub fn derive_no_default(item: TokenStream) -> TokenStream { if let Ok(input) = syn::parse::(item) { let name = &input.ident; TokenStream::from(quote! { - impl Default for #name { + impl ::std::default::Default for #name { fn default() -> Self { - near_sdk::env::panic_str("The contract is not initialized"); + ::near_sdk::env::panic_str("The contract is not initialized"); } } }) @@ -501,7 +501,7 @@ pub fn borsh_storage_key(item: TokenStream) -> TokenStream { parse_quote!(where #predicate) }; TokenStream::from(quote! { - impl #impl_generics near_sdk::__private::BorshIntoStorageKey for #name #ty_generics #where_clause {} + impl #impl_generics ::near_sdk::__private::BorshIntoStorageKey for #name #ty_generics #where_clause {} }) } @@ -524,9 +524,9 @@ pub fn function_error(item: TokenStream) -> TokenStream { ); }; TokenStream::from(quote! { - impl near_sdk::FunctionError for #name { + impl ::near_sdk::FunctionError for #name { fn panic(&self) -> ! { - near_sdk::env::panic_str(&::std::string::ToString::to_string(&self)) + ::near_sdk::env::panic_str(&::std::string::ToString::to_string(&self)) } } }) @@ -559,7 +559,7 @@ pub fn derive_event_attributes(item: TokenStream) -> TokenStream { if let Some(version) = core_impl::get_event_version(var) { let var_ident = &var.ident; event_meta.push(quote! { - #name::#var_ident { .. } => {(#standard_ident.to_string(), #version.to_string())} + #name::#var_ident { .. } => {(::std::string::ToString::to_string(&#standard_ident), ::std::string::ToString::to_string(#version))} }) } else { return TokenStream::from( @@ -585,12 +585,14 @@ pub fn derive_event_attributes(item: TokenStream) -> TokenStream { TokenStream::from(quote! { impl #impl_generics #name #type_generics #where_clause { pub fn emit(&self) { + use ::std::string::String; + let (standard, version): (String, String) = match self { #(#event_meta),* }; - #[derive(near_sdk::serde::Serialize)] - #[serde(crate="near_sdk::serde")] + #[derive(::near_sdk::serde::Serialize)] + #[serde(crate="::near_sdk::serde")] #[serde(rename_all="snake_case")] struct EventBuilder #custom_impl_generics #where_clause { standard: String, @@ -599,9 +601,9 @@ pub fn derive_event_attributes(item: TokenStream) -> TokenStream { event_data: &#event_lifetime #name #type_generics } let event = EventBuilder { standard, version, event_data: self }; - let json = near_sdk::serde_json::to_string(&event) - .unwrap_or_else(|_| near_sdk::env::abort()); - near_sdk::env::log_str(&format!("EVENT_JSON:{}", json)); + let json = ::near_sdk::serde_json::to_string(&event) + .unwrap_or_else(|_| ::near_sdk::env::abort()); + ::near_sdk::env::log_str(&::std::format!("EVENT_JSON:{}", json)); } } }) From f84510edcd965b814ec7b88a92472ad57bb00021 Mon Sep 17 00:00:00 2001 From: Tomasz Kurcz Date: Wed, 26 Jul 2023 16:02:10 +0200 Subject: [PATCH 2/2] macro tests: cosmetic --- .../code_generator/item_trait_info.rs | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/near-sdk-macros/src/core_impl/code_generator/item_trait_info.rs b/near-sdk-macros/src/core_impl/code_generator/item_trait_info.rs index b6d263515..aad2b98f1 100644 --- a/near-sdk-macros/src/core_impl/code_generator/item_trait_info.rs +++ b/near-sdk-macros/src/core_impl/code_generator/item_trait_info.rs @@ -37,16 +37,16 @@ mod tests { let mut t: ItemTrait = syn::parse2( quote!{ pub trait ExternalCrossContract { - fn merge_sort(&self, arr: ::std::vec::Vec) -> PromiseOrValue<::std::vec::Vec>; + fn merge_sort(&self, arr: Vec) -> PromiseOrValue>; fn merge( &self, #[callback_unwrap] #[serializer(borsh)] - data0: ::std::vec::Vec, + data0: Vec, #[callback_unwrap] #[serializer(borsh)] - data1: ::std::vec::Vec, - ) -> ::std::vec::Vec; + data1: Vec, + ) -> Vec; } } ).unwrap(); @@ -89,13 +89,13 @@ mod tests { impl ExternalCrossContractExt { pub fn merge_sort( self, - arr: ::std::vec::Vec, + arr: Vec, ) -> ::near_sdk::Promise { let __args = { #[derive(::near_sdk :: serde :: Serialize)] #[serde(crate = "::near_sdk::serde")] struct Input<'nearinput> { - arr: &'nearinput ::std::vec::Vec, + arr: &'nearinput Vec, } let __args = Input { arr: &arr, }; ::near_sdk::serde_json::to_vec(&__args) @@ -133,7 +133,7 @@ mod tests { quote!{ trait Test { #[result_serializer(borsh)] - fn test(#[serializer(borsh)] v: ::std::vec::Vec) -> ::std::vec::Vec; + fn test(#[serializer(borsh)] v: Vec) -> Vec; } } ).unwrap(); @@ -176,12 +176,12 @@ mod tests { impl TestExt { pub fn test( self, - v: ::std::vec::Vec, + v: Vec, ) -> ::near_sdk::Promise { let __args = { #[derive(::near_sdk :: borsh :: BorshSerialize)] struct Input<'nearinput> { - v: &'nearinput ::std::vec::Vec, + v: &'nearinput Vec, } let __args = Input { v: &v, }; ::near_sdk::borsh::BorshSerialize::try_to_vec(&__args)