parent
1119976dc7
commit
debd6fec3d
|
@ -337,7 +337,7 @@ where
|
||||||
if not_aliased.len() > 1 {
|
if not_aliased.len() > 1 {
|
||||||
let mut overloaded_aliases = Vec::new();
|
let mut overloaded_aliases = Vec::new();
|
||||||
for (idx, (sig, name)) in not_aliased.into_iter().enumerate() {
|
for (idx, (sig, name)) in not_aliased.into_iter().enumerate() {
|
||||||
let unique_name = format!("{}{}", name, idx + 1);
|
let unique_name = format!("{name}{}", idx + 1);
|
||||||
overloaded_aliases.push((sig, get_ident(&unique_name)));
|
overloaded_aliases.push((sig, get_ident(&unique_name)));
|
||||||
}
|
}
|
||||||
aliases.extend(overloaded_aliases);
|
aliases.extend(overloaded_aliases);
|
||||||
|
|
|
@ -64,7 +64,7 @@ where
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn imports(name: &str) -> TokenStream {
|
pub(crate) fn imports(name: &str) -> TokenStream {
|
||||||
let doc = util::expand_doc(&format!("{} was auto-generated with ethers-rs Abigen. More information at: https://github.com/gakonst/ethers-rs", name));
|
let doc = util::expand_doc(&format!("{name} was auto-generated with ethers-rs Abigen. More information at: https://github.com/gakonst/ethers-rs"));
|
||||||
|
|
||||||
let ethers_core = ethers_core_crate();
|
let ethers_core = ethers_core_crate();
|
||||||
let ethers_providers = ethers_providers_crate();
|
let ethers_providers = ethers_providers_crate();
|
||||||
|
@ -116,7 +116,7 @@ pub(crate) fn struct_declaration(cx: &Context) -> TokenStream {
|
||||||
|
|
||||||
let bytecode = if let Some(ref bytecode) = cx.contract_bytecode {
|
let bytecode = if let Some(ref bytecode) = cx.contract_bytecode {
|
||||||
let bytecode_name = cx.inline_bytecode_ident();
|
let bytecode_name = cx.inline_bytecode_ident();
|
||||||
let hex_bytecode = format!("{}", bytecode);
|
let hex_bytecode = format!("{bytecode}");
|
||||||
quote! {
|
quote! {
|
||||||
/// Bytecode of the #name contract
|
/// Bytecode of the #name contract
|
||||||
pub static #bytecode_name: #ethers_contract::Lazy<#ethers_core::types::Bytes> = #ethers_contract::Lazy::new(|| #hex_bytecode.parse()
|
pub static #bytecode_name: #ethers_contract::Lazy<#ethers_core::types::Bytes> = #ethers_contract::Lazy::new(|| #hex_bytecode.parse()
|
||||||
|
|
|
@ -34,7 +34,7 @@ impl Context {
|
||||||
.map(|function| {
|
.map(|function| {
|
||||||
let signature = function.abi_signature();
|
let signature = function.abi_signature();
|
||||||
self.expand_function(function, aliases.get(&signature).cloned())
|
self.expand_function(function, aliases.get(&signature).cloned())
|
||||||
.with_context(|| format!("error expanding function '{}'", signature))
|
.with_context(|| format!("error expanding function '{signature}'"))
|
||||||
})
|
})
|
||||||
.collect::<Result<Vec<_>>>()?;
|
.collect::<Result<Vec<_>>>()?;
|
||||||
|
|
||||||
|
@ -593,7 +593,7 @@ impl Context {
|
||||||
name_conflicts(*idx, &diffs)
|
name_conflicts(*idx, &diffs)
|
||||||
{
|
{
|
||||||
needs_alias_for_first_fun_using_idx = true;
|
needs_alias_for_first_fun_using_idx = true;
|
||||||
format!("{}{}", overloaded_fun.name.to_snake_case(), idx)
|
format!("{}{idx}", overloaded_fun.name.to_snake_case())
|
||||||
} else {
|
} else {
|
||||||
format!(
|
format!(
|
||||||
"{}_with_{}",
|
"{}_with_{}",
|
||||||
|
@ -608,7 +608,7 @@ impl Context {
|
||||||
name_conflicts(*idx, &diffs)
|
name_conflicts(*idx, &diffs)
|
||||||
{
|
{
|
||||||
needs_alias_for_first_fun_using_idx = true;
|
needs_alias_for_first_fun_using_idx = true;
|
||||||
format!("{}{}", overloaded_fun.name.to_snake_case(), idx)
|
format!("{}{idx}", overloaded_fun.name.to_snake_case())
|
||||||
} else {
|
} else {
|
||||||
// 1 + n additional input params
|
// 1 + n additional input params
|
||||||
let and = diff
|
let and = diff
|
||||||
|
@ -632,7 +632,7 @@ impl Context {
|
||||||
|
|
||||||
if needs_alias_for_first_fun_using_idx {
|
if needs_alias_for_first_fun_using_idx {
|
||||||
// insert an alias for the root duplicated call
|
// insert an alias for the root duplicated call
|
||||||
let prev_alias = format!("{}{}", first_fun.name.to_snake_case(), first_fun_idx);
|
let prev_alias = format!("{}{first_fun_idx}", first_fun.name.to_snake_case());
|
||||||
|
|
||||||
let alias = MethodAlias::new(&prev_alias);
|
let alias = MethodAlias::new(&prev_alias);
|
||||||
|
|
||||||
|
@ -698,9 +698,9 @@ fn expand_struct_name_postfix(
|
||||||
postfix: &str,
|
postfix: &str,
|
||||||
) -> Ident {
|
) -> Ident {
|
||||||
let name = if let Some(alias) = alias {
|
let name = if let Some(alias) = alias {
|
||||||
format!("{}{}", alias.struct_name, postfix)
|
format!("{}{postfix}", alias.struct_name)
|
||||||
} else {
|
} else {
|
||||||
format!("{}{}", util::safe_pascal_case(&function.name), postfix)
|
format!("{}{postfix}", util::safe_pascal_case(&function.name))
|
||||||
};
|
};
|
||||||
util::ident(&name)
|
util::ident(&name)
|
||||||
}
|
}
|
||||||
|
|
|
@ -129,9 +129,9 @@ impl Context {
|
||||||
"".to_string()
|
"".to_string()
|
||||||
};
|
};
|
||||||
|
|
||||||
let abi_signature = format!("{}({})", name, sig,);
|
let abi_signature = format!("{name}({sig})",);
|
||||||
|
|
||||||
let abi_signature_doc = util::expand_doc(&format!("`{}`", abi_signature));
|
let abi_signature_doc = util::expand_doc(&format!("`{abi_signature}`"));
|
||||||
|
|
||||||
// use the same derives as for events
|
// use the same derives as for events
|
||||||
let derives = util::expand_derives(&self.event_derives);
|
let derives = util::expand_derives(&self.event_derives);
|
||||||
|
@ -184,7 +184,7 @@ impl Context {
|
||||||
param_types.iter().map(|kind| kind.to_string()).collect::<Vec<_>>().join(","),
|
param_types.iter().map(|kind| kind.to_string()).collect::<Vec<_>>().join(","),
|
||||||
);
|
);
|
||||||
|
|
||||||
let abi_signature_doc = util::expand_doc(&format!("`{}`", abi_signature));
|
let abi_signature_doc = util::expand_doc(&format!("`{abi_signature}`"));
|
||||||
|
|
||||||
let name = util::ident(name);
|
let name = util::ident(name);
|
||||||
|
|
||||||
|
@ -392,12 +392,12 @@ fn insert_rust_type_name(
|
||||||
let mut other_name = name.clone();
|
let mut other_name = name.clone();
|
||||||
// name collision `A.name` `B.name`, rename to `AName`, `BName`
|
// name collision `A.name` `B.name`, rename to `AName`, `BName`
|
||||||
if !other_projections.is_empty() {
|
if !other_projections.is_empty() {
|
||||||
other_name = format!("{}{}", other_projections.remove(0).to_pascal_case(), other_name);
|
other_name = format!("{}{other_name}", other_projections.remove(0).to_pascal_case());
|
||||||
}
|
}
|
||||||
insert_rust_type_name(type_names, other_name, other_projections, other_id);
|
insert_rust_type_name(type_names, other_name, other_projections, other_id);
|
||||||
|
|
||||||
if !projections.is_empty() {
|
if !projections.is_empty() {
|
||||||
name = format!("{}{}", projections.remove(0).to_pascal_case(), name);
|
name = format!("{}{name}", projections.remove(0).to_pascal_case());
|
||||||
}
|
}
|
||||||
insert_rust_type_name(type_names, name, projections, id);
|
insert_rust_type_name(type_names, name, projections, id);
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -598,8 +598,8 @@ ethers = {{ git = "https://github.com/gakonst/ethers-rs", default-features = fal
|
||||||
mod_names.insert(shared.name.to_snake_case());
|
mod_names.insert(shared.name.to_snake_case());
|
||||||
}
|
}
|
||||||
|
|
||||||
for module in mod_names.into_iter().map(|name| format!("pub mod {};", name)) {
|
for module in mod_names.into_iter().map(|name| format!("pub mod {name};")) {
|
||||||
writeln!(buf, "{}", module)?;
|
writeln!(buf, "{module}")?;
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
|
|
|
@ -248,7 +248,7 @@ fn get_local_contract(path: impl AsRef<str>) -> Result<String> {
|
||||||
#[cfg(not(target_arch = "wasm32"))]
|
#[cfg(not(target_arch = "wasm32"))]
|
||||||
fn get_http_contract(url: &Url) -> Result<String> {
|
fn get_http_contract(url: &Url) -> Result<String> {
|
||||||
let json = util::http_get(url.as_str())
|
let json = util::http_get(url.as_str())
|
||||||
.with_context(|| format!("failed to retrieve JSON from {}", url))?;
|
.with_context(|| format!("failed to retrieve JSON from {url}"))?;
|
||||||
Ok(json)
|
Ok(json)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -266,15 +266,14 @@ fn get_etherscan_contract(address: Address, domain: &str) -> Result<String> {
|
||||||
"snowtrace.io" => env::var("SNOWTRACE_API_KEY").ok(),
|
"snowtrace.io" => env::var("SNOWTRACE_API_KEY").ok(),
|
||||||
_ => None,
|
_ => None,
|
||||||
};
|
};
|
||||||
key_res.map(|key| format!("&apikey={}", key)).unwrap_or_default()
|
key_res.map(|key| format!("&apikey={key}")).unwrap_or_default()
|
||||||
};
|
};
|
||||||
|
|
||||||
let abi_url = format!(
|
let abi_url = format!(
|
||||||
"http://api.{}/api?module=contract&action=getabi&address={:?}&format=raw{}",
|
"http://api.{}/api?module=contract&action=getabi&address={:?}&format=raw{}",
|
||||||
domain, address, api_key,
|
domain, address, api_key,
|
||||||
);
|
);
|
||||||
let abi =
|
let abi = util::http_get(&abi_url).context(format!("failed to retrieve ABI from {domain}"))?;
|
||||||
util::http_get(&abi_url).context(format!("failed to retrieve ABI from {}", domain))?;
|
|
||||||
|
|
||||||
if abi.starts_with("Contract source code not verified") {
|
if abi.starts_with("Contract source code not verified") {
|
||||||
eyre::bail!("Contract source code not verified: {:?}", address);
|
eyre::bail!("Contract source code not verified: {:?}", address);
|
||||||
|
@ -292,9 +291,9 @@ fn get_etherscan_contract(address: Address, domain: &str) -> Result<String> {
|
||||||
/// Retrieves a Truffle artifact or ABI from an npm package through `unpkg.io`.
|
/// Retrieves a Truffle artifact or ABI from an npm package through `unpkg.io`.
|
||||||
#[cfg(not(target_arch = "wasm32"))]
|
#[cfg(not(target_arch = "wasm32"))]
|
||||||
fn get_npm_contract(package: &str) -> Result<String> {
|
fn get_npm_contract(package: &str) -> Result<String> {
|
||||||
let unpkg_url = format!("https://unpkg.io/{}", package);
|
let unpkg_url = format!("https://unpkg.io/{package}");
|
||||||
let json = util::http_get(&unpkg_url)
|
let json = util::http_get(&unpkg_url)
|
||||||
.with_context(|| format!("failed to retrieve JSON from for npm package {}", package))?;
|
.with_context(|| format!("failed to retrieve JSON from for npm package {package}"))?;
|
||||||
|
|
||||||
Ok(json)
|
Ok(json)
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,7 +19,7 @@ pub fn ident(name: &str) -> Ident {
|
||||||
///
|
///
|
||||||
/// Parsing keywords like `self` can fail, in this case we add an underscore.
|
/// Parsing keywords like `self` can fail, in this case we add an underscore.
|
||||||
pub fn safe_ident(name: &str) -> Ident {
|
pub fn safe_ident(name: &str) -> Ident {
|
||||||
syn::parse_str::<SynIdent>(name).unwrap_or_else(|_| ident(&format!("{}_", name)))
|
syn::parse_str::<SynIdent>(name).unwrap_or_else(|_| ident(&format!("{name}_")))
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Converts a `&str` to `snake_case` `String` while respecting identifier rules
|
/// Converts a `&str` to `snake_case` `String` while respecting identifier rules
|
||||||
|
@ -35,7 +35,7 @@ pub fn safe_pascal_case(ident: &str) -> String {
|
||||||
/// respects identifier rules, such as, an identifier must not start with a numeric char
|
/// respects identifier rules, such as, an identifier must not start with a numeric char
|
||||||
fn safe_identifier_name(name: String) -> String {
|
fn safe_identifier_name(name: String) -> String {
|
||||||
if name.starts_with(|c: char| c.is_numeric()) {
|
if name.starts_with(|c: char| c.is_numeric()) {
|
||||||
format!("_{}", name)
|
format!("_{name}")
|
||||||
} else {
|
} else {
|
||||||
name
|
name
|
||||||
}
|
}
|
||||||
|
@ -76,7 +76,7 @@ pub fn preserve_underscore_delim(ident: &str, alias: &str) -> String {
|
||||||
/// identifiers that are reserved keywords get `_` appended to them.
|
/// identifiers that are reserved keywords get `_` appended to them.
|
||||||
pub fn expand_input_name(index: usize, name: &str) -> TokenStream {
|
pub fn expand_input_name(index: usize, name: &str) -> TokenStream {
|
||||||
let name_str = match name {
|
let name_str = match name {
|
||||||
"" => format!("p{}", index),
|
"" => format!("p{index}"),
|
||||||
n => n.to_snake_case(),
|
n => n.to_snake_case(),
|
||||||
};
|
};
|
||||||
let name = safe_ident(&name_str);
|
let name = safe_ident(&name_str);
|
||||||
|
|
|
@ -184,7 +184,7 @@ impl Parse for Parameter {
|
||||||
_ => {
|
_ => {
|
||||||
return Err(ParseError::new(
|
return Err(ParseError::new(
|
||||||
name.span(),
|
name.span(),
|
||||||
format!("unexpected named parameter `{}`", name),
|
format!("unexpected named parameter `{name}`"),
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -33,7 +33,7 @@ pub(crate) fn derive_eth_call_impl(input: DeriveInput) -> TokenStream {
|
||||||
) {
|
) {
|
||||||
Ok(derived) => derived,
|
Ok(derived) => derived,
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
Error::new(span, format!("Unable to determine ABI for `{}` : {}", src, err))
|
Error::new(span, format!("Unable to determine ABI for `{src}` : {err}"))
|
||||||
.to_compile_error()
|
.to_compile_error()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,14 +32,14 @@ pub fn parse_calllike_attributes(
|
||||||
Meta::Path(path) => {
|
Meta::Path(path) => {
|
||||||
return Err(Error::new(
|
return Err(Error::new(
|
||||||
path.span(),
|
path.span(),
|
||||||
format!("unrecognized {} parameter", attr_name),
|
format!("unrecognized {attr_name} parameter"),
|
||||||
)
|
)
|
||||||
.to_compile_error())
|
.to_compile_error())
|
||||||
}
|
}
|
||||||
Meta::List(meta) => {
|
Meta::List(meta) => {
|
||||||
return Err(Error::new(
|
return Err(Error::new(
|
||||||
meta.path.span(),
|
meta.path.span(),
|
||||||
format!("unrecognized {} parameter", attr_name),
|
format!("unrecognized {attr_name} parameter"),
|
||||||
)
|
)
|
||||||
.to_compile_error())
|
.to_compile_error())
|
||||||
}
|
}
|
||||||
|
@ -85,7 +85,7 @@ pub fn parse_calllike_attributes(
|
||||||
} else {
|
} else {
|
||||||
return Err(Error::new(
|
return Err(Error::new(
|
||||||
meta.span(),
|
meta.span(),
|
||||||
format!("unrecognized {} parameter", attr_name),
|
format!("unrecognized {attr_name} parameter"),
|
||||||
)
|
)
|
||||||
.to_compile_error())
|
.to_compile_error())
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,7 +32,7 @@ pub(crate) fn derive_eth_error_impl(input: DeriveInput) -> TokenStream {
|
||||||
) {
|
) {
|
||||||
Ok(derived) => derived,
|
Ok(derived) => derived,
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
Error::new(span, format!("Unable to determine ABI for `{}` : {}", src, err))
|
Error::new(span, format!("Unable to determine ABI for `{src}` : {err}"))
|
||||||
.to_compile_error()
|
.to_compile_error()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -168,20 +168,20 @@ pub fn derive_abi_inputs_from_fields(
|
||||||
Fields::Unit => {
|
Fields::Unit => {
|
||||||
return Err(Error::new(
|
return Err(Error::new(
|
||||||
input.span(),
|
input.span(),
|
||||||
format!("{} cannot be derived for empty structs and unit", trait_name),
|
format!("{trait_name} cannot be derived for empty structs and unit"),
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
Data::Enum(_) => {
|
Data::Enum(_) => {
|
||||||
return Err(Error::new(
|
return Err(Error::new(
|
||||||
input.span(),
|
input.span(),
|
||||||
format!("{} cannot be derived for enums", trait_name),
|
format!("{trait_name} cannot be derived for enums"),
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
Data::Union(_) => {
|
Data::Union(_) => {
|
||||||
return Err(Error::new(
|
return Err(Error::new(
|
||||||
input.span(),
|
input.span(),
|
||||||
format!("{} cannot be derived for unions", trait_name),
|
format!("{trait_name} cannot be derived for unions"),
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -258,20 +258,20 @@ pub fn derive_abi_parameters_array(
|
||||||
Fields::Unit => {
|
Fields::Unit => {
|
||||||
return Err(Error::new(
|
return Err(Error::new(
|
||||||
input.span(),
|
input.span(),
|
||||||
format!("{} cannot be derived for empty structs and unit", trait_name),
|
format!("{trait_name} cannot be derived for empty structs and unit"),
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
Data::Enum(_) => {
|
Data::Enum(_) => {
|
||||||
return Err(Error::new(
|
return Err(Error::new(
|
||||||
input.span(),
|
input.span(),
|
||||||
format!("{} cannot be derived for enums", trait_name),
|
format!("{trait_name} cannot be derived for enums"),
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
Data::Union(_) => {
|
Data::Union(_) => {
|
||||||
return Err(Error::new(
|
return Err(Error::new(
|
||||||
input.span(),
|
input.span(),
|
||||||
format!("{} cannot be derived for unions", trait_name),
|
format!("{trait_name} cannot be derived for unions"),
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -140,7 +140,7 @@ impl TryFrom<u8> for MulticallVersion {
|
||||||
1 => Ok(MulticallVersion::Multicall),
|
1 => Ok(MulticallVersion::Multicall),
|
||||||
2 => Ok(MulticallVersion::Multicall2),
|
2 => Ok(MulticallVersion::Multicall2),
|
||||||
3 => Ok(MulticallVersion::Multicall3),
|
3 => Ok(MulticallVersion::Multicall3),
|
||||||
_ => Err(format!("Invalid Multicall version: {}. Accepted values: 1, 2, 3.", v)),
|
_ => Err(format!("Invalid Multicall version: {v}. Accepted values: 1, 2, 3.")),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -85,7 +85,7 @@ fn can_gen_structs_readable() {
|
||||||
assert_codec::<Value>();
|
assert_codec::<Value>();
|
||||||
assert_codec::<Addresses>();
|
assert_codec::<Addresses>();
|
||||||
let encoded = addr.clone().encode();
|
let encoded = addr.clone().encode();
|
||||||
let other = Addresses::decode(&encoded).unwrap();
|
let other = Addresses::decode(encoded).unwrap();
|
||||||
assert_eq!(addr, other);
|
assert_eq!(addr, other);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -178,7 +178,7 @@ fn can_gen_return_struct() {
|
||||||
binding: T,
|
binding: T,
|
||||||
) {
|
) {
|
||||||
let encoded = binding.clone().encode();
|
let encoded = binding.clone().encode();
|
||||||
let decoded = T::decode(&encoded).unwrap();
|
let decoded = T::decode(encoded).unwrap();
|
||||||
assert_eq!(binding, decoded);
|
assert_eq!(binding, decoded);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -394,7 +394,7 @@ fn eth_display_works() {
|
||||||
hex::encode(&item.v),
|
hex::encode(&item.v),
|
||||||
);
|
);
|
||||||
|
|
||||||
assert_eq!(val, format!("{}", item));
|
assert_eq!(val, format!("{item}"));
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -408,9 +408,9 @@ fn eth_display_works_for_human_readable() {
|
||||||
);
|
);
|
||||||
|
|
||||||
let log = LogFilter("abc".to_string());
|
let log = LogFilter("abc".to_string());
|
||||||
assert_eq!("abc".to_string(), format!("{}", log));
|
assert_eq!("abc".to_string(), format!("{log}"));
|
||||||
let log = Log2Filter { x: "abc".to_string() };
|
let log = Log2Filter { x: "abc".to_string() };
|
||||||
assert_eq!("abc".to_string(), format!("{}", log));
|
assert_eq!("abc".to_string(), format!("{log}"));
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -493,7 +493,7 @@ fn can_derive_abi_codec() {
|
||||||
let val = SomeType { inner: Default::default(), msg: "hello".to_string() };
|
let val = SomeType { inner: Default::default(), msg: "hello".to_string() };
|
||||||
|
|
||||||
let encoded = val.clone().encode();
|
let encoded = val.clone().encode();
|
||||||
let other = SomeType::decode(&encoded).unwrap();
|
let other = SomeType::decode(encoded).unwrap();
|
||||||
assert_eq!(val, other);
|
assert_eq!(val, other);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -603,7 +603,7 @@ fn eth_display_works_on_ethers_bytes() {
|
||||||
}
|
}
|
||||||
let call = LogBytesCall { p_0: hex::decode(b"aaaaaa").unwrap().into() };
|
let call = LogBytesCall { p_0: hex::decode(b"aaaaaa").unwrap().into() };
|
||||||
|
|
||||||
let s = format!("{}", call);
|
let s = format!("{call}");
|
||||||
assert_eq!(s, "0xaaaaaa");
|
assert_eq!(s, "0xaaaaaa");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,7 @@ pub struct ValueChanged {
|
||||||
/// compiles the given contract and returns the ABI and Bytecode
|
/// compiles the given contract and returns the ABI and Bytecode
|
||||||
#[track_caller]
|
#[track_caller]
|
||||||
pub fn compile_contract(name: &str, filename: &str) -> (Abi, Bytes) {
|
pub fn compile_contract(name: &str, filename: &str) -> (Abi, Bytes) {
|
||||||
let path = format!("./tests/solidity-contracts/{}", filename);
|
let path = format!("./tests/solidity-contracts/{filename}");
|
||||||
let compiled = Solc::default().compile_source(&path).unwrap();
|
let compiled = Solc::default().compile_source(&path).unwrap();
|
||||||
let contract = compiled.get(&path, name).expect("could not find contract");
|
let contract = compiled.get(&path, name).expect("could not find contract");
|
||||||
let (abi, bin, _) = contract.into_parts_or_default();
|
let (abi, bin, _) = contract.into_parts_or_default();
|
||||||
|
|
|
@ -94,12 +94,12 @@ impl<'input> Token<'input> {
|
||||||
impl<'input> fmt::Display for Token<'input> {
|
impl<'input> fmt::Display for Token<'input> {
|
||||||
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
||||||
match self {
|
match self {
|
||||||
Token::Identifier(id) => write!(f, "{}", id),
|
Token::Identifier(id) => write!(f, "{id}"),
|
||||||
Token::Number(num) => write!(f, "{}", num),
|
Token::Number(num) => write!(f, "{num}"),
|
||||||
Token::HexNumber(num) => write!(f, "0x{}", num),
|
Token::HexNumber(num) => write!(f, "0x{num}"),
|
||||||
Token::Uint(w) => write!(f, "uint{}", w),
|
Token::Uint(w) => write!(f, "uint{w}"),
|
||||||
Token::Int(w) => write!(f, "int{}", w),
|
Token::Int(w) => write!(f, "int{w}"),
|
||||||
Token::Bytes(w) => write!(f, "bytes{}", w),
|
Token::Bytes(w) => write!(f, "bytes{w}"),
|
||||||
Token::Byte => write!(f, "byte"),
|
Token::Byte => write!(f, "byte"),
|
||||||
Token::DynamicBytes => write!(f, "bytes"),
|
Token::DynamicBytes => write!(f, "bytes"),
|
||||||
Token::Semicolon => write!(f, ";"),
|
Token::Semicolon => write!(f, ";"),
|
||||||
|
|
|
@ -95,7 +95,7 @@ impl ErrorExt for ethabi::AbiError {
|
||||||
return format!("{}()", self.name)
|
return format!("{}()", self.name)
|
||||||
}
|
}
|
||||||
let inputs = self.inputs.iter().map(|p| p.kind.to_string()).collect::<Vec<_>>().join(",");
|
let inputs = self.inputs.iter().map(|p| p.kind.to_string()).collect::<Vec<_>>().join(",");
|
||||||
format!("{}({})", self.name, inputs)
|
format!("{}({inputs})", self.name)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn selector(&self) -> Selector {
|
fn selector(&self) -> Selector {
|
||||||
|
|
|
@ -257,10 +257,10 @@ mod tests {
|
||||||
assert!(matches!(abi, JsonAbi::Array(_)));
|
assert!(matches!(abi, JsonAbi::Array(_)));
|
||||||
|
|
||||||
let code = "0x608060405234801561001057600080fd5b50610242806100206000396000f3fe608060405234801561001057600080fd5b506004361061002b5760003560e01c80635581701b14610030575b600080fd5b61004a60048036038101906100459190610199565b610060565b60405161005791906101f1565b60405180910390f35b610068610070565b819050919050565b60405180602001604052806000151581525090565b6000604051905090565b600080fd5b600080fd5b6000601f19601f8301169050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b6100e282610099565b810181811067ffffffffffffffff82111715610101576101006100aa565b5b80604052505050565b6000610114610085565b905061012082826100d9565b919050565b60008115159050919050565b61013a81610125565b811461014557600080fd5b50565b60008135905061015781610131565b92915050565b60006020828403121561017357610172610094565b5b61017d602061010a565b9050600061018d84828501610148565b60008301525092915050565b6000602082840312156101af576101ae61008f565b5b60006101bd8482850161015d565b91505092915050565b6101cf81610125565b82525050565b6020820160008201516101eb60008501826101c6565b50505050565b600060208201905061020660008301846101d5565b9291505056fea2646970667358221220890202b0964477379a457ab3725a21d7c14581e4596552e32a54e23f1c6564e064736f6c634300080c0033";
|
let code = "0x608060405234801561001057600080fd5b50610242806100206000396000f3fe608060405234801561001057600080fd5b506004361061002b5760003560e01c80635581701b14610030575b600080fd5b61004a60048036038101906100459190610199565b610060565b60405161005791906101f1565b60405180910390f35b610068610070565b819050919050565b60405180602001604052806000151581525090565b6000604051905090565b600080fd5b600080fd5b6000601f19601f8301169050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b6100e282610099565b810181811067ffffffffffffffff82111715610101576101006100aa565b5b80604052505050565b6000610114610085565b905061012082826100d9565b919050565b60008115159050919050565b61013a81610125565b811461014557600080fd5b50565b60008135905061015781610131565b92915050565b60006020828403121561017357610172610094565b5b61017d602061010a565b9050600061018d84828501610148565b60008301525092915050565b6000602082840312156101af576101ae61008f565b5b60006101bd8482850161015d565b91505092915050565b6101cf81610125565b82525050565b6020820160008201516101eb60008501826101c6565b50505050565b600060208201905061020660008301846101d5565b9291505056fea2646970667358221220890202b0964477379a457ab3725a21d7c14581e4596552e32a54e23f1c6564e064736f6c634300080c0033";
|
||||||
let s = format!(r#"{{"abi": {}, "bin" : "{}" }}"#, abi_str, code);
|
let s = format!(r#"{{"abi": {abi_str}, "bin" : "{code}" }}"#);
|
||||||
assert_has_bytecode(&s);
|
assert_has_bytecode(&s);
|
||||||
|
|
||||||
let s = format!(r#"{{"abi": {}, "bytecode" : {{ "object": "{}" }} }}"#, abi_str, code);
|
let s = format!(r#"{{"abi": {abi_str}, "bytecode" : {{ "object": "{code}" }} }}"#);
|
||||||
assert_has_bytecode(&s);
|
assert_has_bytecode(&s);
|
||||||
|
|
||||||
let hh_artifact = include_str!(
|
let hh_artifact = include_str!(
|
||||||
|
@ -286,7 +286,7 @@ mod tests {
|
||||||
#[test]
|
#[test]
|
||||||
fn ignores_empty_bytecode() {
|
fn ignores_empty_bytecode() {
|
||||||
let abi_str = r#"[{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint64","name":"number","type":"uint64"}],"name":"MyEvent","type":"event"},{"inputs":[],"name":"greet","outputs":[],"stateMutability":"nonpayable","type":"function"}]"#;
|
let abi_str = r#"[{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint64","name":"number","type":"uint64"}],"name":"MyEvent","type":"event"},{"inputs":[],"name":"greet","outputs":[],"stateMutability":"nonpayable","type":"function"}]"#;
|
||||||
let s = format!(r#"{{"abi": {}, "bin" : "0x" }}"#, abi_str);
|
let s = format!(r#"{{"abi": {abi_str}, "bin" : "0x" }}"#);
|
||||||
|
|
||||||
match serde_json::from_str::<JsonAbi>(&s).unwrap() {
|
match serde_json::from_str::<JsonAbi>(&s).unwrap() {
|
||||||
JsonAbi::Object(abi) => {
|
JsonAbi::Object(abi) => {
|
||||||
|
@ -297,7 +297,7 @@ mod tests {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
let s = format!(r#"{{"abi": {}, "bytecode" : {{ "object": "0x" }} }}"#, abi_str);
|
let s = format!(r#"{{"abi": {abi_str}, "bytecode" : {{ "object": "0x" }} }}"#);
|
||||||
|
|
||||||
match serde_json::from_str::<JsonAbi>(&s).unwrap() {
|
match serde_json::from_str::<JsonAbi>(&s).unwrap() {
|
||||||
JsonAbi::Object(abi) => {
|
JsonAbi::Object(abi) => {
|
||||||
|
|
|
@ -127,7 +127,7 @@ impl StructFieldType {
|
||||||
if path.is_empty() {
|
if path.is_empty() {
|
||||||
name.to_string()
|
name.to_string()
|
||||||
} else {
|
} else {
|
||||||
format!("{}.{}", path, name)
|
format!("{path}.{name}")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -59,11 +59,11 @@ pub fn determine_ethers_crates() -> (&'static str, &'static str, &'static str) {
|
||||||
};
|
};
|
||||||
|
|
||||||
// check if the lock file exists, if it's missing we need to clean up afterward
|
// check if the lock file exists, if it's missing we need to clean up afterward
|
||||||
let lock_file = format!("{}/Cargo.lock", manifest_dir);
|
let lock_file = format!("{manifest_dir}/Cargo.lock");
|
||||||
let needs_lock_file_cleanup = !std::path::Path::new(&lock_file).exists();
|
let needs_lock_file_cleanup = !std::path::Path::new(&lock_file).exists();
|
||||||
|
|
||||||
let res = MetadataCommand::new()
|
let res = MetadataCommand::new()
|
||||||
.manifest_path(&format!("{}/Cargo.toml", manifest_dir))
|
.manifest_path(&format!("{manifest_dir}/Cargo.toml"))
|
||||||
.exec()
|
.exec()
|
||||||
.ok()
|
.ok()
|
||||||
.and_then(|metadata| {
|
.and_then(|metadata| {
|
||||||
|
|
|
@ -461,7 +461,7 @@ impl Serialize for BlockId {
|
||||||
match *self {
|
match *self {
|
||||||
BlockId::Hash(ref x) => {
|
BlockId::Hash(ref x) => {
|
||||||
let mut s = serializer.serialize_struct("BlockIdEip1898", 1)?;
|
let mut s = serializer.serialize_struct("BlockIdEip1898", 1)?;
|
||||||
s.serialize_field("blockHash", &format!("{:?}", x))?;
|
s.serialize_field("blockHash", &format!("{x:?}"))?;
|
||||||
s.end()
|
s.end()
|
||||||
}
|
}
|
||||||
BlockId::Number(ref num) => num.serialize(serializer),
|
BlockId::Number(ref num) => num.serialize(serializer),
|
||||||
|
@ -599,7 +599,7 @@ impl Serialize for BlockNumber {
|
||||||
S: Serializer,
|
S: Serializer,
|
||||||
{
|
{
|
||||||
match *self {
|
match *self {
|
||||||
BlockNumber::Number(ref x) => serializer.serialize_str(&format!("0x{:x}", x)),
|
BlockNumber::Number(ref x) => serializer.serialize_str(&format!("0x{x:x}")),
|
||||||
BlockNumber::Latest => serializer.serialize_str("latest"),
|
BlockNumber::Latest => serializer.serialize_str("latest"),
|
||||||
BlockNumber::Finalized => serializer.serialize_str("finalized"),
|
BlockNumber::Finalized => serializer.serialize_str("finalized"),
|
||||||
BlockNumber::Safe => serializer.serialize_str("safe"),
|
BlockNumber::Safe => serializer.serialize_str("safe"),
|
||||||
|
@ -638,7 +638,7 @@ impl FromStr for BlockNumber {
|
||||||
impl fmt::Display for BlockNumber {
|
impl fmt::Display for BlockNumber {
|
||||||
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
||||||
match self {
|
match self {
|
||||||
BlockNumber::Number(ref x) => format!("0x{:x}", x).fmt(f),
|
BlockNumber::Number(ref x) => format!("0x{x:x}").fmt(f),
|
||||||
BlockNumber::Latest => f.write_str("latest"),
|
BlockNumber::Latest => f.write_str("latest"),
|
||||||
BlockNumber::Finalized => f.write_str("finalized"),
|
BlockNumber::Finalized => f.write_str("finalized"),
|
||||||
BlockNumber::Safe => f.write_str("safe"),
|
BlockNumber::Safe => f.write_str("safe"),
|
||||||
|
|
|
@ -166,7 +166,7 @@ impl FromStr for Bytes {
|
||||||
hex::decode(value)
|
hex::decode(value)
|
||||||
}
|
}
|
||||||
.map(Into::into)
|
.map(Into::into)
|
||||||
.map_err(|e| ParseBytesError(format!("Invalid hex: {}", e)))
|
.map_err(|e| ParseBytesError(format!("Invalid hex: {e}")))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -200,8 +200,8 @@ mod tests {
|
||||||
fn hex_formatting() {
|
fn hex_formatting() {
|
||||||
let b = Bytes::from(vec![1, 35, 69, 103, 137, 171, 205, 239]);
|
let b = Bytes::from(vec![1, 35, 69, 103, 137, 171, 205, 239]);
|
||||||
let expected = String::from("0x0123456789abcdef");
|
let expected = String::from("0x0123456789abcdef");
|
||||||
assert_eq!(format!("{:x}", b), expected);
|
assert_eq!(format!("{b:x}"), expected);
|
||||||
assert_eq!(format!("{}", b), expected);
|
assert_eq!(format!("{b}"), expected);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -219,7 +219,7 @@ mod tests {
|
||||||
#[test]
|
#[test]
|
||||||
fn test_debug_formatting() {
|
fn test_debug_formatting() {
|
||||||
let b = Bytes::from(vec![1, 35, 69, 103, 137, 171, 205, 239]);
|
let b = Bytes::from(vec![1, 35, 69, 103, 137, 171, 205, 239]);
|
||||||
assert_eq!(format!("{:?}", b), "Bytes(0x0123456789abcdef)");
|
assert_eq!(format!("{b:?}"), "Bytes(0x0123456789abcdef)");
|
||||||
assert_eq!(format!("{:#?}", b), "Bytes(0x0123456789abcdef)");
|
assert_eq!(format!("{b:#?}"), "Bytes(0x0123456789abcdef)");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -271,7 +271,7 @@ impl fmt::Display for Chain {
|
||||||
Chain::AuroraTestnet => "aurora-testnet",
|
Chain::AuroraTestnet => "aurora-testnet",
|
||||||
};
|
};
|
||||||
|
|
||||||
write!(formatter, "{}", chain)
|
write!(formatter, "{chain}")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -626,7 +626,7 @@ where
|
||||||
}
|
}
|
||||||
|
|
||||||
match serde_json::from_value::<Variadic<T>>(value).map_err(|err| {
|
match serde_json::from_value::<Variadic<T>>(value).map_err(|err| {
|
||||||
serde::de::Error::custom(format!("Invalid variadic value or array type: {}", err))
|
serde::de::Error::custom(format!("Invalid variadic value or array type: {err}"))
|
||||||
})? {
|
})? {
|
||||||
Variadic::Value(val) => Ok(ValueOrArray::Value(val)),
|
Variadic::Value(val) => Ok(ValueOrArray::Value(val)),
|
||||||
Variadic::Array(arr) => Ok(ValueOrArray::Array(arr)),
|
Variadic::Array(arr) => Ok(ValueOrArray::Array(arr)),
|
||||||
|
|
|
@ -1046,7 +1046,7 @@ impl fmt::Display for I256 {
|
||||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||||
let (sign, abs) = self.into_sign_and_abs();
|
let (sign, abs) = self.into_sign_and_abs();
|
||||||
sign.fmt(f)?;
|
sign.fmt(f)?;
|
||||||
write!(f, "{}", abs)
|
write!(f, "{abs}")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1054,7 +1054,7 @@ impl fmt::LowerHex for I256 {
|
||||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||||
let (sign, abs) = self.into_sign_and_abs();
|
let (sign, abs) = self.into_sign_and_abs();
|
||||||
fmt::Display::fmt(&sign, f)?;
|
fmt::Display::fmt(&sign, f)?;
|
||||||
write!(f, "{:x}", abs)
|
write!(f, "{abs:x}")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1064,9 +1064,9 @@ impl fmt::UpperHex for I256 {
|
||||||
fmt::Display::fmt(&sign, f)?;
|
fmt::Display::fmt(&sign, f)?;
|
||||||
|
|
||||||
// NOTE: Work around `U256: !UpperHex`.
|
// NOTE: Work around `U256: !UpperHex`.
|
||||||
let mut buffer = format!("{:x}", abs);
|
let mut buffer = format!("{abs:x}");
|
||||||
buffer.make_ascii_uppercase();
|
buffer.make_ascii_uppercase();
|
||||||
write!(f, "{}", buffer)
|
write!(f, "{buffer}")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1385,13 +1385,13 @@ mod tests {
|
||||||
fn parse_dec_str() {
|
fn parse_dec_str() {
|
||||||
let unsigned = U256::from_dec_str("314159265358979323846264338327950288419716").unwrap();
|
let unsigned = U256::from_dec_str("314159265358979323846264338327950288419716").unwrap();
|
||||||
|
|
||||||
let value = I256::from_dec_str(&format!("-{}", unsigned)).unwrap();
|
let value = I256::from_dec_str(&format!("-{unsigned}")).unwrap();
|
||||||
assert_eq!(value.into_sign_and_abs(), (Sign::Negative, unsigned));
|
assert_eq!(value.into_sign_and_abs(), (Sign::Negative, unsigned));
|
||||||
|
|
||||||
let value = I256::from_dec_str(&format!("{}", unsigned)).unwrap();
|
let value = I256::from_dec_str(&format!("{unsigned}")).unwrap();
|
||||||
assert_eq!(value.into_sign_and_abs(), (Sign::Positive, unsigned));
|
assert_eq!(value.into_sign_and_abs(), (Sign::Positive, unsigned));
|
||||||
|
|
||||||
let value = I256::from_dec_str(&format!("+{}", unsigned)).unwrap();
|
let value = I256::from_dec_str(&format!("+{unsigned}")).unwrap();
|
||||||
assert_eq!(value.into_sign_and_abs(), (Sign::Positive, unsigned));
|
assert_eq!(value.into_sign_and_abs(), (Sign::Positive, unsigned));
|
||||||
|
|
||||||
let err = I256::from_dec_str("invalid string").unwrap_err();
|
let err = I256::from_dec_str("invalid string").unwrap_err();
|
||||||
|
@ -1414,13 +1414,13 @@ mod tests {
|
||||||
fn parse_hex_str() {
|
fn parse_hex_str() {
|
||||||
let unsigned = U256::from_dec_str("314159265358979323846264338327950288419716").unwrap();
|
let unsigned = U256::from_dec_str("314159265358979323846264338327950288419716").unwrap();
|
||||||
|
|
||||||
let value = I256::from_hex_str(&format!("-{:x}", unsigned)).unwrap();
|
let value = I256::from_hex_str(&format!("-{unsigned:x}")).unwrap();
|
||||||
assert_eq!(value.into_sign_and_abs(), (Sign::Negative, unsigned));
|
assert_eq!(value.into_sign_and_abs(), (Sign::Negative, unsigned));
|
||||||
|
|
||||||
let value = I256::from_hex_str(&format!("{:x}", unsigned)).unwrap();
|
let value = I256::from_hex_str(&format!("{unsigned:x}")).unwrap();
|
||||||
assert_eq!(value.into_sign_and_abs(), (Sign::Positive, unsigned));
|
assert_eq!(value.into_sign_and_abs(), (Sign::Positive, unsigned));
|
||||||
|
|
||||||
let value = I256::from_hex_str(&format!("+{:x}", unsigned)).unwrap();
|
let value = I256::from_hex_str(&format!("+{unsigned:x}")).unwrap();
|
||||||
assert_eq!(value.into_sign_and_abs(), (Sign::Positive, unsigned));
|
assert_eq!(value.into_sign_and_abs(), (Sign::Positive, unsigned));
|
||||||
|
|
||||||
let err = I256::from_hex_str("invalid string").unwrap_err();
|
let err = I256::from_hex_str("invalid string").unwrap_err();
|
||||||
|
@ -1445,20 +1445,20 @@ mod tests {
|
||||||
let positive = I256::try_from(unsigned).unwrap();
|
let positive = I256::try_from(unsigned).unwrap();
|
||||||
let negative = -positive;
|
let negative = -positive;
|
||||||
|
|
||||||
assert_eq!(format!("{}", positive), format!("{}", unsigned));
|
assert_eq!(format!("{positive}"), format!("{unsigned}"));
|
||||||
assert_eq!(format!("{}", negative), format!("-{}", unsigned));
|
assert_eq!(format!("{negative}"), format!("-{unsigned}"));
|
||||||
assert_eq!(format!("{:+}", positive), format!("+{}", unsigned));
|
assert_eq!(format!("{positive:+}"), format!("+{unsigned}"));
|
||||||
assert_eq!(format!("{:+}", negative), format!("-{}", unsigned));
|
assert_eq!(format!("{negative:+}"), format!("-{unsigned}"));
|
||||||
|
|
||||||
assert_eq!(format!("{:x}", positive), format!("{:x}", unsigned));
|
assert_eq!(format!("{positive:x}"), format!("{unsigned:x}"));
|
||||||
assert_eq!(format!("{:x}", negative), format!("-{:x}", unsigned));
|
assert_eq!(format!("{negative:x}"), format!("-{unsigned:x}"));
|
||||||
assert_eq!(format!("{:+x}", positive), format!("+{:x}", unsigned));
|
assert_eq!(format!("{positive:+x}"), format!("+{unsigned:x}"));
|
||||||
assert_eq!(format!("{:+x}", negative), format!("-{:x}", unsigned));
|
assert_eq!(format!("{negative:+x}"), format!("-{unsigned:x}"));
|
||||||
|
|
||||||
assert_eq!(format!("{:X}", positive), format!("{:x}", unsigned).to_uppercase());
|
assert_eq!(format!("{positive:X}"), format!("{unsigned:x}").to_uppercase());
|
||||||
assert_eq!(format!("{:X}", negative), format!("-{:x}", unsigned).to_uppercase());
|
assert_eq!(format!("{negative:X}"), format!("-{unsigned:x}").to_uppercase());
|
||||||
assert_eq!(format!("{:+X}", positive), format!("+{:x}", unsigned).to_uppercase());
|
assert_eq!(format!("{positive:+X}"), format!("+{unsigned:x}").to_uppercase());
|
||||||
assert_eq!(format!("{:+X}", negative), format!("-{:x}", unsigned).to_uppercase());
|
assert_eq!(format!("{negative:+X}"), format!("-{unsigned:x}").to_uppercase());
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|
|
@ -741,7 +741,7 @@ pub fn encode_field(
|
||||||
// uints are commonly stringified due to how ethers-js encodes
|
// uints are commonly stringified due to how ethers-js encodes
|
||||||
let val: StringifiedNumeric = serde_json::from_value(value.clone())?;
|
let val: StringifiedNumeric = serde_json::from_value(value.clone())?;
|
||||||
let val = val.try_into().map_err(|err| {
|
let val = val.try_into().map_err(|err| {
|
||||||
Eip712Error::Message(format!("Failed to parse uint {}", err))
|
Eip712Error::Message(format!("Failed to parse uint {err}"))
|
||||||
})?;
|
})?;
|
||||||
|
|
||||||
Token::Uint(val)
|
Token::Uint(val)
|
||||||
|
@ -808,7 +808,7 @@ pub fn find_parameter_type(ty: &Type) -> Result<ParamType, TokenStream> {
|
||||||
s => parse_int_param_type(s).ok_or_else(|| {
|
s => parse_int_param_type(s).ok_or_else(|| {
|
||||||
Error::new(
|
Error::new(
|
||||||
ty.span(),
|
ty.span(),
|
||||||
format!("Failed to derive proper ABI from field: {})", s),
|
format!("Failed to derive proper ABI from field: {s})"),
|
||||||
)
|
)
|
||||||
.to_compile_error()
|
.to_compile_error()
|
||||||
}),
|
}),
|
||||||
|
@ -906,9 +906,9 @@ pub fn parse_fields(ast: &DeriveInput) -> Result<Vec<(String, ParamType)>, Token
|
||||||
/// Convert hash map of field names and types into a type hash corresponding to enc types;
|
/// Convert hash map of field names and types into a type hash corresponding to enc types;
|
||||||
pub fn make_type_hash(primary_type: String, fields: &[(String, ParamType)]) -> [u8; 32] {
|
pub fn make_type_hash(primary_type: String, fields: &[(String, ParamType)]) -> [u8; 32] {
|
||||||
let parameters =
|
let parameters =
|
||||||
fields.iter().map(|(k, v)| format!("{} {}", v, k)).collect::<Vec<String>>().join(",");
|
fields.iter().map(|(k, v)| format!("{v} {k}")).collect::<Vec<String>>().join(",");
|
||||||
|
|
||||||
let sig = format!("{}({})", primary_type, parameters);
|
let sig = format!("{primary_type}({parameters})");
|
||||||
|
|
||||||
keccak256(sig)
|
keccak256(sig)
|
||||||
}
|
}
|
||||||
|
|
|
@ -83,7 +83,7 @@ impl Tokenizable for Uint8 {
|
||||||
}
|
}
|
||||||
Ok(Uint8(data.low_u32() as u8))
|
Ok(Uint8(data.low_u32() as u8))
|
||||||
}
|
}
|
||||||
other => Err(InvalidOutputType(format!("Expected `uint8`, got {:?}", other))),
|
other => Err(InvalidOutputType(format!("Expected `uint8`, got {other:?}"))),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fn into_token(self) -> Token {
|
fn into_token(self) -> Token {
|
||||||
|
|
|
@ -15,7 +15,7 @@ where
|
||||||
{
|
{
|
||||||
let message = message.as_ref();
|
let message = message.as_ref();
|
||||||
|
|
||||||
let mut eth_message = format!("{}{}", PREFIX, message.len()).into_bytes();
|
let mut eth_message = format!("{PREFIX}{}", message.len()).into_bytes();
|
||||||
eth_message.extend_from_slice(message);
|
eth_message.extend_from_slice(message);
|
||||||
|
|
||||||
keccak256(ð_message).into()
|
keccak256(ð_message).into()
|
||||||
|
|
|
@ -265,7 +265,7 @@ pub fn get_create2_address_from_hash(
|
||||||
[&[0xff], from.into().as_bytes(), salt.into().as_ref(), init_code_hash.into().as_ref()]
|
[&[0xff], from.into().as_bytes(), salt.into().as_ref(), init_code_hash.into().as_ref()]
|
||||||
.concat();
|
.concat();
|
||||||
|
|
||||||
let hash = keccak256(&bytes);
|
let hash = keccak256(bytes);
|
||||||
|
|
||||||
let mut bytes = [0u8; 20];
|
let mut bytes = [0u8; 20];
|
||||||
bytes.copy_from_slice(&hash[12..]);
|
bytes.copy_from_slice(&hash[12..]);
|
||||||
|
@ -286,10 +286,10 @@ pub fn secret_key_to_address(secret_key: &SigningKey) -> Address {
|
||||||
/// Ref: <https://github.com/ethereum/EIPs/blob/master/EIPS/eip-55.md>
|
/// Ref: <https://github.com/ethereum/EIPs/blob/master/EIPS/eip-55.md>
|
||||||
pub fn to_checksum(addr: &Address, chain_id: Option<u8>) -> String {
|
pub fn to_checksum(addr: &Address, chain_id: Option<u8>) -> String {
|
||||||
let prefixed_addr = match chain_id {
|
let prefixed_addr = match chain_id {
|
||||||
Some(chain_id) => format!("{}0x{:x}", chain_id, addr),
|
Some(chain_id) => format!("{chain_id}0x{addr:x}"),
|
||||||
None => format!("{:x}", addr),
|
None => format!("{addr:x}"),
|
||||||
};
|
};
|
||||||
let hash = hex::encode(keccak256(&prefixed_addr));
|
let hash = hex::encode(keccak256(prefixed_addr));
|
||||||
let hash = hash.as_bytes();
|
let hash = hash.as_bytes();
|
||||||
|
|
||||||
let addr_hex = hex::encode(addr.as_bytes());
|
let addr_hex = hex::encode(addr.as_bytes());
|
||||||
|
|
|
@ -448,16 +448,16 @@ impl TokenQueryOption {
|
||||||
let mut params: HashMap<&'static str, String> = list_params.into();
|
let mut params: HashMap<&'static str, String> = list_params.into();
|
||||||
match self {
|
match self {
|
||||||
TokenQueryOption::ByAddress(address) => {
|
TokenQueryOption::ByAddress(address) => {
|
||||||
params.insert("address", format!("{:?}", address));
|
params.insert("address", format!("{address:?}"));
|
||||||
params
|
params
|
||||||
}
|
}
|
||||||
TokenQueryOption::ByContract(contract) => {
|
TokenQueryOption::ByContract(contract) => {
|
||||||
params.insert("contractaddress", format!("{:?}", contract));
|
params.insert("contractaddress", format!("{contract:?}"));
|
||||||
params
|
params
|
||||||
}
|
}
|
||||||
TokenQueryOption::ByAddressAndContract(address, contract) => {
|
TokenQueryOption::ByAddressAndContract(address, contract) => {
|
||||||
params.insert("address", format!("{:?}", address));
|
params.insert("address", format!("{address:?}"));
|
||||||
params.insert("contractaddress", format!("{:?}", contract));
|
params.insert("contractaddress", format!("{contract:?}"));
|
||||||
params
|
params
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -507,7 +507,7 @@ impl Client {
|
||||||
tag: Option<Tag>,
|
tag: Option<Tag>,
|
||||||
) -> Result<AccountBalance> {
|
) -> Result<AccountBalance> {
|
||||||
let tag_str = tag.unwrap_or_default().to_string();
|
let tag_str = tag.unwrap_or_default().to_string();
|
||||||
let addr_str = format!("{:?}", address);
|
let addr_str = format!("{address:?}");
|
||||||
let query = self.create_query(
|
let query = self.create_query(
|
||||||
"account",
|
"account",
|
||||||
"balance",
|
"balance",
|
||||||
|
@ -542,7 +542,7 @@ impl Client {
|
||||||
tag: Option<Tag>,
|
tag: Option<Tag>,
|
||||||
) -> Result<Vec<AccountBalance>> {
|
) -> Result<Vec<AccountBalance>> {
|
||||||
let tag_str = tag.unwrap_or_default().to_string();
|
let tag_str = tag.unwrap_or_default().to_string();
|
||||||
let addrs = addresses.iter().map(|x| format!("{:?}", x)).collect::<Vec<String>>().join(",");
|
let addrs = addresses.iter().map(|x| format!("{x:?}")).collect::<Vec<String>>().join(",");
|
||||||
let query: Query<HashMap<&str, &str>> = self.create_query(
|
let query: Query<HashMap<&str, &str>> = self.create_query(
|
||||||
"account",
|
"account",
|
||||||
"balancemulti",
|
"balancemulti",
|
||||||
|
@ -577,7 +577,7 @@ impl Client {
|
||||||
params: Option<TxListParams>,
|
params: Option<TxListParams>,
|
||||||
) -> Result<Vec<NormalTransaction>> {
|
) -> Result<Vec<NormalTransaction>> {
|
||||||
let mut tx_params: HashMap<&str, String> = params.unwrap_or_default().into();
|
let mut tx_params: HashMap<&str, String> = params.unwrap_or_default().into();
|
||||||
tx_params.insert("address", format!("{:?}", address));
|
tx_params.insert("address", format!("{address:?}"));
|
||||||
let query = self.create_query("account", "txlist", tx_params);
|
let query = self.create_query("account", "txlist", tx_params);
|
||||||
let response: Response<Vec<NormalTransaction>> = self.get_json(&query).await?;
|
let response: Response<Vec<NormalTransaction>> = self.get_json(&query).await?;
|
||||||
|
|
||||||
|
@ -608,10 +608,10 @@ impl Client {
|
||||||
let mut tx_params: HashMap<&str, String> = params.unwrap_or_default().into();
|
let mut tx_params: HashMap<&str, String> = params.unwrap_or_default().into();
|
||||||
match tx_query_option {
|
match tx_query_option {
|
||||||
InternalTxQueryOption::ByAddress(address) => {
|
InternalTxQueryOption::ByAddress(address) => {
|
||||||
tx_params.insert("address", format!("{:?}", address));
|
tx_params.insert("address", format!("{address:?}"));
|
||||||
}
|
}
|
||||||
InternalTxQueryOption::ByTransactionHash(tx_hash) => {
|
InternalTxQueryOption::ByTransactionHash(tx_hash) => {
|
||||||
tx_params.insert("txhash", format!("{:?}", tx_hash));
|
tx_params.insert("txhash", format!("{tx_hash:?}"));
|
||||||
}
|
}
|
||||||
_ => {}
|
_ => {}
|
||||||
}
|
}
|
||||||
|
@ -730,7 +730,7 @@ impl Client {
|
||||||
page_and_offset: Option<(u64, u64)>,
|
page_and_offset: Option<(u64, u64)>,
|
||||||
) -> Result<Vec<MinedBlock>> {
|
) -> Result<Vec<MinedBlock>> {
|
||||||
let mut params = HashMap::new();
|
let mut params = HashMap::new();
|
||||||
params.insert("address", format!("{:?}", address));
|
params.insert("address", format!("{address:?}"));
|
||||||
params.insert("blocktype", block_type.unwrap_or_default().to_string());
|
params.insert("blocktype", block_type.unwrap_or_default().to_string());
|
||||||
if let Some((page, offset)) = page_and_offset {
|
if let Some((page, offset)) = page_and_offset {
|
||||||
params.insert("page", page.to_string());
|
params.insert("page", page.to_string());
|
||||||
|
|
|
@ -139,22 +139,22 @@ impl Client {
|
||||||
|
|
||||||
/// Return the URL for the given block number
|
/// Return the URL for the given block number
|
||||||
pub fn block_url(&self, block: u64) -> String {
|
pub fn block_url(&self, block: u64) -> String {
|
||||||
format!("{}block/{}", self.etherscan_url, block)
|
format!("{}block/{block}", self.etherscan_url)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Return the URL for the given address
|
/// Return the URL for the given address
|
||||||
pub fn address_url(&self, address: Address) -> String {
|
pub fn address_url(&self, address: Address) -> String {
|
||||||
format!("{}address/{:?}", self.etherscan_url, address)
|
format!("{}address/{address:?}", self.etherscan_url)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Return the URL for the given transaction hash
|
/// Return the URL for the given transaction hash
|
||||||
pub fn transaction_url(&self, tx_hash: H256) -> String {
|
pub fn transaction_url(&self, tx_hash: H256) -> String {
|
||||||
format!("{}tx/{:?}", self.etherscan_url, tx_hash)
|
format!("{}tx/{tx_hash:?}", self.etherscan_url)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Return the URL for the given token hash
|
/// Return the URL for the given token hash
|
||||||
pub fn token_url(&self, token_hash: Address) -> String {
|
pub fn token_url(&self, token_hash: Address) -> String {
|
||||||
format!("{}token/{:?}", self.etherscan_url, token_hash)
|
format!("{}token/{token_hash:?}", self.etherscan_url)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Execute an GET request with parameters.
|
/// Execute an GET request with parameters.
|
||||||
|
@ -373,7 +373,7 @@ impl Cache {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn set<T: Serialize>(&self, prefix: &str, address: Address, item: T) {
|
fn set<T: Serialize>(&self, prefix: &str, address: Address, item: T) {
|
||||||
let path = self.root.join(prefix).join(format!("{:?}.json", address));
|
let path = self.root.join(prefix).join(format!("{address:?}.json"));
|
||||||
let writer = std::fs::File::create(path).ok().map(std::io::BufWriter::new);
|
let writer = std::fs::File::create(path).ok().map(std::io::BufWriter::new);
|
||||||
if let Some(mut writer) = writer {
|
if let Some(mut writer) = writer {
|
||||||
let _ = serde_json::to_writer(
|
let _ = serde_json::to_writer(
|
||||||
|
@ -393,7 +393,7 @@ impl Cache {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get<T: DeserializeOwned>(&self, prefix: &str, address: Address) -> Option<T> {
|
fn get<T: DeserializeOwned>(&self, prefix: &str, address: Address) -> Option<T> {
|
||||||
let path = self.root.join(prefix).join(format!("{:?}.json", address));
|
let path = self.root.join(prefix).join(format!("{address:?}.json"));
|
||||||
let reader = std::io::BufReader::new(std::fs::File::open(path).ok()?);
|
let reader = std::io::BufReader::new(std::fs::File::open(path).ok()?);
|
||||||
if let Ok(inner) = serde_json::from_reader::<_, CacheEnvelope<T>>(reader) {
|
if let Ok(inner) = serde_json::from_reader::<_, CacheEnvelope<T>>(reader) {
|
||||||
// If this does not return None then we have passed the expiry
|
// If this does not return None then we have passed the expiry
|
||||||
|
@ -459,7 +459,7 @@ mod tests {
|
||||||
let etherscan = Client::new_from_env(Chain::Mainnet).unwrap();
|
let etherscan = Client::new_from_env(Chain::Mainnet).unwrap();
|
||||||
let block: u64 = 1;
|
let block: u64 = 1;
|
||||||
let block_url: String = etherscan.block_url(block);
|
let block_url: String = etherscan.block_url(block);
|
||||||
assert_eq!(block_url, format!("https://etherscan.io/block/{}", block));
|
assert_eq!(block_url, format!("https://etherscan.io/block/{block}"));
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -467,7 +467,7 @@ mod tests {
|
||||||
let etherscan = Client::new_from_env(Chain::Mainnet).unwrap();
|
let etherscan = Client::new_from_env(Chain::Mainnet).unwrap();
|
||||||
let addr: Address = Address::zero();
|
let addr: Address = Address::zero();
|
||||||
let address_url: String = etherscan.address_url(addr);
|
let address_url: String = etherscan.address_url(addr);
|
||||||
assert_eq!(address_url, format!("https://etherscan.io/address/{:?}", addr));
|
assert_eq!(address_url, format!("https://etherscan.io/address/{addr:?}"));
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -475,7 +475,7 @@ mod tests {
|
||||||
let etherscan = Client::new_from_env(Chain::Mainnet).unwrap();
|
let etherscan = Client::new_from_env(Chain::Mainnet).unwrap();
|
||||||
let tx_hash = H256::zero();
|
let tx_hash = H256::zero();
|
||||||
let tx_url: String = etherscan.transaction_url(tx_hash);
|
let tx_url: String = etherscan.transaction_url(tx_hash);
|
||||||
assert_eq!(tx_url, format!("https://etherscan.io/tx/{:?}", tx_hash));
|
assert_eq!(tx_url, format!("https://etherscan.io/tx/{tx_hash:?}"));
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -483,7 +483,7 @@ mod tests {
|
||||||
let etherscan = Client::new_from_env(Chain::Mainnet).unwrap();
|
let etherscan = Client::new_from_env(Chain::Mainnet).unwrap();
|
||||||
let token_hash = Address::zero();
|
let token_hash = Address::zero();
|
||||||
let token_url: String = etherscan.token_url(token_hash);
|
let token_url: String = etherscan.token_url(token_hash);
|
||||||
assert_eq!(token_url, format!("https://etherscan.io/token/{:?}", token_hash));
|
assert_eq!(token_url, format!("https://etherscan.io/token/{token_hash:?}"));
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|
|
@ -57,7 +57,7 @@ impl VerifyContract {
|
||||||
|
|
||||||
#[must_use]
|
#[must_use]
|
||||||
pub fn runs(mut self, runs: u32) -> Self {
|
pub fn runs(mut self, runs: u32) -> Self {
|
||||||
self.runs = Some(format!("{}", runs));
|
self.runs = Some(format!("{runs}"));
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -150,7 +150,7 @@ mod dsproxyfactory_mod {
|
||||||
cache: Tokenizable::from_token(iter.next().unwrap())?,
|
cache: Tokenizable::from_token(iter.next().unwrap())?,
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
Err(InvalidOutputType(format!("Expected Tuple, got {:?}", token)))
|
Err(InvalidOutputType(format!("Expected Tuple, got {token:?}")))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fn into_token(self) -> Token {
|
fn into_token(self) -> Token {
|
||||||
|
|
|
@ -245,7 +245,7 @@ async fn deploy_and_call_contract() {
|
||||||
|
|
||||||
// compiles the given contract and returns the ABI and Bytecode
|
// compiles the given contract and returns the ABI and Bytecode
|
||||||
fn compile_contract(path: &str, name: &str) -> (Abi, Bytes) {
|
fn compile_contract(path: &str, name: &str) -> (Abi, Bytes) {
|
||||||
let path = format!("./tests/solidity-contracts/{}", path);
|
let path = format!("./tests/solidity-contracts/{path}");
|
||||||
let compiled = Solc::default().compile_source(&path).unwrap();
|
let compiled = Solc::default().compile_source(&path).unwrap();
|
||||||
let contract = compiled.get(&path, name).expect("could not find contract");
|
let contract = compiled.get(&path, name).expect("could not find contract");
|
||||||
let (abi, bin, _) = contract.into_parts_or_default();
|
let (abi, bin, _) = contract.into_parts_or_default();
|
||||||
|
@ -308,7 +308,7 @@ impl TestWallets {
|
||||||
let mut nonce = provider.get_transaction_count(addr, None).await.unwrap();
|
let mut nonce = provider.get_transaction_count(addr, None).await.unwrap();
|
||||||
let mut pending_txs = Vec::new();
|
let mut pending_txs = Vec::new();
|
||||||
for addr in addrs {
|
for addr in addrs {
|
||||||
println!("Funding wallet {:?}", addr);
|
println!("Funding wallet {addr:?}");
|
||||||
let tx = TransactionRequest::new()
|
let tx = TransactionRequest::new()
|
||||||
.nonce(nonce)
|
.nonce(nonce)
|
||||||
.to(addr)
|
.to(addr)
|
||||||
|
|
|
@ -16,7 +16,7 @@ type HttpWallet = SignerMiddleware<Provider<Http>, LocalWallet>;
|
||||||
|
|
||||||
// compiles the given contract and returns the ABI and Bytecode
|
// compiles the given contract and returns the ABI and Bytecode
|
||||||
fn compile_contract(path: &str, name: &str) -> (Abi, Bytes) {
|
fn compile_contract(path: &str, name: &str) -> (Abi, Bytes) {
|
||||||
let path = format!("./tests/solidity-contracts/{}", path);
|
let path = format!("./tests/solidity-contracts/{path}");
|
||||||
let compiled = Solc::default().compile_source(&path).unwrap();
|
let compiled = Solc::default().compile_source(&path).unwrap();
|
||||||
let contract = compiled.get(&path, name).expect("could not find contract");
|
let contract = compiled.get(&path, name).expect("could not find contract");
|
||||||
let (abi, bin, _) = contract.into_parts_or_default();
|
let (abi, bin, _) = contract.into_parts_or_default();
|
||||||
|
|
|
@ -72,7 +72,7 @@ pub fn resolve<T: Into<NameOrAddress>>(
|
||||||
|
|
||||||
/// Returns the reverse-registrar name of an address.
|
/// Returns the reverse-registrar name of an address.
|
||||||
pub fn reverse_address(addr: Address) -> String {
|
pub fn reverse_address(addr: Address) -> String {
|
||||||
format!("{:?}.{}", addr, ENS_REVERSE_REGISTRAR_DOMAIN)[2..].to_string()
|
format!("{addr:?}.{ENS_REVERSE_REGISTRAR_DOMAIN}")[2..].to_string()
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns the ENS namehash as specified in [EIP-137](https://eips.ethereum.org/EIPS/eip-137)
|
/// Returns the ENS namehash as specified in [EIP-137](https://eips.ethereum.org/EIPS/eip-137)
|
||||||
|
@ -83,7 +83,7 @@ pub fn namehash(name: &str) -> H256 {
|
||||||
|
|
||||||
// iterate in reverse
|
// iterate in reverse
|
||||||
name.rsplit('.')
|
name.rsplit('.')
|
||||||
.fold([0u8; 32], |node, label| keccak256(&[node, keccak256(label.as_bytes())].concat()))
|
.fold([0u8; 32], |node, label| keccak256([node, keccak256(label.as_bytes())].concat()))
|
||||||
.into()
|
.into()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -38,12 +38,12 @@ impl FromStr for ERCNFT {
|
||||||
let token_split: Vec<&str> = inner_path.split('/').collect();
|
let token_split: Vec<&str> = inner_path.split('/').collect();
|
||||||
let (contract_addr, token_id) = if token_split.len() == 2 {
|
let (contract_addr, token_id) = if token_split.len() == 2 {
|
||||||
let token_id = U256::from_dec_str(token_split[1])
|
let token_id = U256::from_dec_str(token_split[1])
|
||||||
.map_err(|e| format!("Unsupported token id type: {} {}", token_split[1], e))?;
|
.map_err(|e| format!("Unsupported token id type: {} {e}", token_split[1]))?;
|
||||||
let mut token_id_bytes = [0x0; 32];
|
let mut token_id_bytes = [0x0; 32];
|
||||||
token_id.to_big_endian(&mut token_id_bytes);
|
token_id.to_big_endian(&mut token_id_bytes);
|
||||||
(
|
(
|
||||||
Address::from_str(token_split[0].trim_start_matches("0x"))
|
Address::from_str(token_split[0].trim_start_matches("0x"))
|
||||||
.map_err(|e| format!("Invalid contract address: {} {}", token_split[0], e))?,
|
.map_err(|e| format!("Invalid contract address: {} {e}", token_split[0]))?,
|
||||||
token_id_bytes,
|
token_id_bytes,
|
||||||
)
|
)
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -130,7 +130,7 @@ macro_rules! completed {
|
||||||
|
|
||||||
/// Tests Provider error for nonce too low issue through debug contents
|
/// Tests Provider error for nonce too low issue through debug contents
|
||||||
fn is_nonce_too_low(e: &ProviderError) -> bool {
|
fn is_nonce_too_low(e: &ProviderError) -> bool {
|
||||||
let debug_str = format!("{:?}", e);
|
let debug_str = format!("{e:?}");
|
||||||
|
|
||||||
debug_str.contains("nonce too low") // Geth, Arbitrum, Optimism
|
debug_str.contains("nonce too low") // Geth, Arbitrum, Optimism
|
||||||
|| debug_str.contains("nonce is too low") // Parity
|
|| debug_str.contains("nonce is too low") // Parity
|
||||||
|
|
|
@ -137,7 +137,7 @@ impl<'a, P> PendingTransaction<'a, P> {
|
||||||
|
|
||||||
/// Logs the pending transaction hash along with a custom message before it.
|
/// Logs the pending transaction hash along with a custom message before it.
|
||||||
pub fn log_msg<S: std::fmt::Display>(self, msg: S) -> Self {
|
pub fn log_msg<S: std::fmt::Display>(self, msg: S) -> Self {
|
||||||
self.inspect(|s| println!("{}: {:?}", msg, **s))
|
self.inspect(|s| println!("{msg}: {:?}", **s))
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Logs the pending transaction's hash
|
/// Logs the pending transaction's hash
|
||||||
|
|
|
@ -939,7 +939,7 @@ impl<P: JsonRpcClient> Middleware for Provider<P> {
|
||||||
};
|
};
|
||||||
let data = self.call(&tx.into(), None).await?;
|
let data = self.call(&tx.into(), None).await?;
|
||||||
let mut metadata_url = Url::parse(&decode_bytes::<String>(ParamType::String, data))
|
let mut metadata_url = Url::parse(&decode_bytes::<String>(ParamType::String, data))
|
||||||
.map_err(|e| ProviderError::CustomError(format!("Invalid metadata url: {}", e)))?;
|
.map_err(|e| ProviderError::CustomError(format!("Invalid metadata url: {e}")))?;
|
||||||
|
|
||||||
if token.type_ == erc::ERCNFTType::ERC1155 {
|
if token.type_ == erc::ERCNFTType::ERC1155 {
|
||||||
metadata_url.set_path(&metadata_url.path().replace("%7Bid%7D", &hex::encode(token.id)));
|
metadata_url.set_path(&metadata_url.path().replace("%7Bid%7D", &hex::encode(token.id)));
|
||||||
|
@ -1832,7 +1832,7 @@ mod tests {
|
||||||
("cdixon.eth", "https://ipfs.io/ipfs/QmYA6ZpEARgHvRHZQdFPynMMX8NtdL2JCadvyuyG2oA88u"),
|
("cdixon.eth", "https://ipfs.io/ipfs/QmYA6ZpEARgHvRHZQdFPynMMX8NtdL2JCadvyuyG2oA88u"),
|
||||||
("0age.eth", "")
|
("0age.eth", "")
|
||||||
] {
|
] {
|
||||||
println!("Resolving: {}", ens_name);
|
println!("Resolving: {ens_name}");
|
||||||
assert_eq!(provider.resolve_avatar(ens_name).await.unwrap(), Url::parse(res).unwrap());
|
assert_eq!(provider.resolve_avatar(ens_name).await.unwrap(), Url::parse(res).unwrap());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -204,8 +204,8 @@ impl Authorization {
|
||||||
impl fmt::Display for Authorization {
|
impl fmt::Display for Authorization {
|
||||||
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
||||||
match self {
|
match self {
|
||||||
Authorization::Basic(auth_secret) => write!(f, "Basic {}", auth_secret),
|
Authorization::Basic(auth_secret) => write!(f, "Basic {auth_secret}"),
|
||||||
Authorization::Bearer(token) => write!(f, "Bearer {}", token),
|
Authorization::Bearer(token) => write!(f, "Bearer {token}"),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -205,7 +205,7 @@ impl Shared {
|
||||||
match msg {
|
match msg {
|
||||||
Request { id, request, sender } => {
|
Request { id, request, sender } => {
|
||||||
let prev = self.pending.borrow_mut().insert(id, sender);
|
let prev = self.pending.borrow_mut().insert(id, sender);
|
||||||
assert!(prev.is_none(), "replaced pending IPC request (id={})", id);
|
assert!(prev.is_none(), "{}", "replaced pending IPC request (id={id})");
|
||||||
|
|
||||||
if let Err(err) = writer.write_all(&request).await {
|
if let Err(err) = writer.write_all(&request).await {
|
||||||
tracing::error!("IPC connection error: {:?}", err);
|
tracing::error!("IPC connection error: {:?}", err);
|
||||||
|
|
|
@ -210,7 +210,7 @@ pub enum RetryClientError {
|
||||||
|
|
||||||
impl std::fmt::Display for RetryClientError {
|
impl std::fmt::Display for RetryClientError {
|
||||||
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
||||||
write!(f, "{:?}", self)
|
write!(f, "{self:?}")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -419,7 +419,7 @@ where
|
||||||
|
|
||||||
// TrySendError is private :(
|
// TrySendError is private :(
|
||||||
fn to_client_error<T: Debug>(err: T) -> ClientError {
|
fn to_client_error<T: Debug>(err: T) -> ClientError {
|
||||||
ClientError::ChannelError(format!("{:?}", err))
|
ClientError::ChannelError(format!("{err:?}"))
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Error, Debug)]
|
#[derive(Error, Debug)]
|
||||||
|
|
|
@ -21,8 +21,8 @@ impl fmt::Display for DerivationType {
|
||||||
f,
|
f,
|
||||||
"{}",
|
"{}",
|
||||||
match self {
|
match self {
|
||||||
DerivationType::Legacy(index) => format!("m/44'/60'/0'/{}", index),
|
DerivationType::Legacy(index) => format!("m/44'/60'/0'/{index}"),
|
||||||
DerivationType::LedgerLive(index) => format!("m/44'/60'/{}'/0/0", index),
|
DerivationType::LedgerLive(index) => format!("m/44'/60'/{index}'/0/0"),
|
||||||
DerivationType::Other(inner) => inner.to_owned(),
|
DerivationType::Other(inner) => inner.to_owned(),
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
|
@ -23,7 +23,7 @@ impl fmt::Display for DerivationType {
|
||||||
f,
|
f,
|
||||||
"{}",
|
"{}",
|
||||||
match self {
|
match self {
|
||||||
DerivationType::TrezorLive(index) => format!("m/44'/60'/{}'/0/0", index),
|
DerivationType::TrezorLive(index) => format!("m/44'/60'/{index}'/0/0"),
|
||||||
DerivationType::Other(inner) => inner.to_owned(),
|
DerivationType::Other(inner) => inner.to_owned(),
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
|
@ -152,7 +152,7 @@ mod tests {
|
||||||
// read from the encrypted JSON keystore and decrypt it, while validating that the
|
// read from the encrypted JSON keystore and decrypt it, while validating that the
|
||||||
// signatures produced by both the keys should match
|
// signatures produced by both the keys should match
|
||||||
let path = Path::new(dir.path()).join(uuid);
|
let path = Path::new(dir.path()).join(uuid);
|
||||||
let key2 = Wallet::<SigningKey>::decrypt_keystore(&path.clone(), "randpsswd").unwrap();
|
let key2 = Wallet::<SigningKey>::decrypt_keystore(path.clone(), "randpsswd").unwrap();
|
||||||
let signature2 = key2.sign_message(message).await.unwrap();
|
let signature2 = key2.sign_message(message).await.unwrap();
|
||||||
assert_eq!(signature, signature2);
|
assert_eq!(signature, signature2);
|
||||||
std::fs::remove_file(&path).unwrap();
|
std::fs::remove_file(&path).unwrap();
|
||||||
|
|
|
@ -33,7 +33,7 @@ fn read_all_benchmark(c: &mut Criterion) {
|
||||||
fn prepare_contracts(root: &Path, num: usize) -> Vec<PathBuf> {
|
fn prepare_contracts(root: &Path, num: usize) -> Vec<PathBuf> {
|
||||||
let mut files = Vec::with_capacity(num);
|
let mut files = Vec::with_capacity(num);
|
||||||
for _ in 0..num {
|
for _ in 0..num {
|
||||||
let path = root.join(format!("file{}.sol", num));
|
let path = root.join(format!("file{num}.sol"));
|
||||||
let f = File::create(&path).unwrap();
|
let f = File::create(&path).unwrap();
|
||||||
let mut writer = BufWriter::new(f);
|
let mut writer = BufWriter::new(f);
|
||||||
|
|
||||||
|
|
|
@ -1133,7 +1133,7 @@ mod tests {
|
||||||
|
|
||||||
let alternative = ConfigurableArtifacts::conflict_free_output_file(
|
let alternative = ConfigurableArtifacts::conflict_free_output_file(
|
||||||
&already_taken,
|
&already_taken,
|
||||||
conflict.clone(),
|
conflict,
|
||||||
file,
|
file,
|
||||||
"/Users/carter/dev/goldfinch/mono/packages/protocol/artifacts",
|
"/Users/carter/dev/goldfinch/mono/packages/protocol/artifacts",
|
||||||
);
|
);
|
||||||
|
|
|
@ -73,7 +73,7 @@ impl FromStr for SourceLocation {
|
||||||
type Err = String;
|
type Err = String;
|
||||||
|
|
||||||
fn from_str(s: &str) -> Result<Self, Self::Err> {
|
fn from_str(s: &str) -> Result<Self, Self::Err> {
|
||||||
let invalid_location = move || format!("{} invalid source location", s);
|
let invalid_location = move || format!("{s} invalid source location");
|
||||||
|
|
||||||
let mut split = s.split(':');
|
let mut split = s.split(':');
|
||||||
let start = split
|
let start = split
|
||||||
|
|
|
@ -305,8 +305,8 @@ impl BytecodeObject {
|
||||||
let fully_qualified_placeholder = utils::library_fully_qualified_placeholder(name);
|
let fully_qualified_placeholder = utils::library_fully_qualified_placeholder(name);
|
||||||
|
|
||||||
*unlinked = unlinked
|
*unlinked = unlinked
|
||||||
.replace(&format!("__{}__", fully_qualified_placeholder), &hex_addr)
|
.replace(&format!("__{fully_qualified_placeholder}__"), &hex_addr)
|
||||||
.replace(&format!("__{}__", place_holder), &hex_addr)
|
.replace(&format!("__{place_holder}__"), &hex_addr)
|
||||||
}
|
}
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
|
@ -522,14 +522,14 @@ impl Libraries {
|
||||||
for lib in libs {
|
for lib in libs {
|
||||||
let mut items = lib.split(':');
|
let mut items = lib.split(':');
|
||||||
let file = items.next().ok_or_else(|| {
|
let file = items.next().ok_or_else(|| {
|
||||||
SolcError::msg(format!("failed to parse path to library file: {}", lib))
|
SolcError::msg(format!("failed to parse path to library file: {lib}"))
|
||||||
})?;
|
})?;
|
||||||
let lib = items
|
let lib = items
|
||||||
.next()
|
.next()
|
||||||
.ok_or_else(|| SolcError::msg(format!("failed to parse library name: {}", lib)))?;
|
.ok_or_else(|| SolcError::msg(format!("failed to parse library name: {lib}")))?;
|
||||||
let addr = items.next().ok_or_else(|| {
|
let addr = items
|
||||||
SolcError::msg(format!("failed to parse library address: {}", lib))
|
.next()
|
||||||
})?;
|
.ok_or_else(|| SolcError::msg(format!("failed to parse library address: {lib}")))?;
|
||||||
if items.next().is_some() {
|
if items.next().is_some() {
|
||||||
return Err(SolcError::msg(format!(
|
return Err(SolcError::msg(format!(
|
||||||
"failed to parse, too many arguments passed: {}",
|
"failed to parse, too many arguments passed: {}",
|
||||||
|
@ -735,7 +735,7 @@ impl fmt::Display for EvmVersion {
|
||||||
EvmVersion::London => "london",
|
EvmVersion::London => "london",
|
||||||
EvmVersion::Byzantium => "byzantium",
|
EvmVersion::Byzantium => "byzantium",
|
||||||
};
|
};
|
||||||
write!(f, "{}", string)
|
write!(f, "{string}")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -753,7 +753,7 @@ impl FromStr for EvmVersion {
|
||||||
"berlin" => Ok(EvmVersion::Berlin),
|
"berlin" => Ok(EvmVersion::Berlin),
|
||||||
"london" => Ok(EvmVersion::London),
|
"london" => Ok(EvmVersion::London),
|
||||||
"byzantium" => Ok(EvmVersion::Byzantium),
|
"byzantium" => Ok(EvmVersion::Byzantium),
|
||||||
s => Err(format!("Unknown evm version: {}", s)),
|
s => Err(format!("Unknown evm version: {s}")),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -807,7 +807,7 @@ impl fmt::Display for RevertStrings {
|
||||||
RevertStrings::Debug => "debug",
|
RevertStrings::Debug => "debug",
|
||||||
RevertStrings::VerboseDebug => "verboseDebug",
|
RevertStrings::VerboseDebug => "verboseDebug",
|
||||||
};
|
};
|
||||||
write!(f, "{}", string)
|
write!(f, "{string}")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -820,7 +820,7 @@ impl FromStr for RevertStrings {
|
||||||
"strip" => Ok(RevertStrings::Strip),
|
"strip" => Ok(RevertStrings::Strip),
|
||||||
"debug" => Ok(RevertStrings::Debug),
|
"debug" => Ok(RevertStrings::Debug),
|
||||||
"verboseDebug" | "verbosedebug" => Ok(RevertStrings::VerboseDebug),
|
"verboseDebug" | "verbosedebug" => Ok(RevertStrings::VerboseDebug),
|
||||||
s => Err(format!("Unknown evm version: {}", s)),
|
s => Err(format!("Unknown evm version: {s}")),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -887,7 +887,7 @@ impl FromStr for BytecodeHash {
|
||||||
"none" => Ok(BytecodeHash::None),
|
"none" => Ok(BytecodeHash::None),
|
||||||
"ipfs" => Ok(BytecodeHash::Ipfs),
|
"ipfs" => Ok(BytecodeHash::Ipfs),
|
||||||
"bzzr1" => Ok(BytecodeHash::Bzzr1),
|
"bzzr1" => Ok(BytecodeHash::Bzzr1),
|
||||||
s => Err(format!("Unknown bytecode hash: {}", s)),
|
s => Err(format!("Unknown bytecode hash: {s}")),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1050,7 +1050,7 @@ impl fmt::Display for ModelCheckerEngine {
|
||||||
ModelCheckerEngine::BMC => "bmc",
|
ModelCheckerEngine::BMC => "bmc",
|
||||||
ModelCheckerEngine::CHC => "chc",
|
ModelCheckerEngine::CHC => "chc",
|
||||||
};
|
};
|
||||||
write!(f, "{}", string)
|
write!(f, "{string}")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1063,7 +1063,7 @@ impl FromStr for ModelCheckerEngine {
|
||||||
"all" => Ok(ModelCheckerEngine::All),
|
"all" => Ok(ModelCheckerEngine::All),
|
||||||
"bmc" => Ok(ModelCheckerEngine::BMC),
|
"bmc" => Ok(ModelCheckerEngine::BMC),
|
||||||
"chc" => Ok(ModelCheckerEngine::CHC),
|
"chc" => Ok(ModelCheckerEngine::CHC),
|
||||||
s => Err(format!("Unknown model checker engine: {}", s)),
|
s => Err(format!("Unknown model checker engine: {s}")),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1100,7 +1100,7 @@ impl fmt::Display for ModelCheckerTarget {
|
||||||
ModelCheckerTarget::OutOfBounds => "outOfBounds",
|
ModelCheckerTarget::OutOfBounds => "outOfBounds",
|
||||||
ModelCheckerTarget::Balance => "balance",
|
ModelCheckerTarget::Balance => "balance",
|
||||||
};
|
};
|
||||||
write!(f, "{}", string)
|
write!(f, "{string}")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1117,7 +1117,7 @@ impl FromStr for ModelCheckerTarget {
|
||||||
"popEmptyArray" => Ok(ModelCheckerTarget::PopEmptyArray),
|
"popEmptyArray" => Ok(ModelCheckerTarget::PopEmptyArray),
|
||||||
"outOfBounds" => Ok(ModelCheckerTarget::OutOfBounds),
|
"outOfBounds" => Ok(ModelCheckerTarget::OutOfBounds),
|
||||||
"balance" => Ok(ModelCheckerTarget::Balance),
|
"balance" => Ok(ModelCheckerTarget::Balance),
|
||||||
s => Err(format!("Unknown model checker target: {}", s)),
|
s => Err(format!("Unknown model checker target: {s}")),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1729,13 +1729,13 @@ impl fmt::Display for Error {
|
||||||
match self.severity {
|
match self.severity {
|
||||||
Severity::Error => {
|
Severity::Error => {
|
||||||
if let Some(code) = self.error_code {
|
if let Some(code) = self.error_code {
|
||||||
Paint::red(format!("error[{}]: ", code)).fmt(f)?;
|
Paint::red(format!("error[{code}]: ")).fmt(f)?;
|
||||||
}
|
}
|
||||||
Paint::red(msg).fmt(f)
|
Paint::red(msg).fmt(f)
|
||||||
}
|
}
|
||||||
Severity::Warning | Severity::Info => {
|
Severity::Warning | Severity::Info => {
|
||||||
if let Some(code) = self.error_code {
|
if let Some(code) = self.error_code {
|
||||||
Paint::yellow(format!("warning[{}]: ", code)).fmt(f)?;
|
Paint::yellow(format!("warning[{code}]: ")).fmt(f)?;
|
||||||
}
|
}
|
||||||
Paint::yellow(msg).fmt(f)
|
Paint::yellow(msg).fmt(f)
|
||||||
}
|
}
|
||||||
|
@ -1786,7 +1786,7 @@ impl FromStr for Severity {
|
||||||
"error" => Ok(Severity::Error),
|
"error" => Ok(Severity::Error),
|
||||||
"warning" => Ok(Severity::Warning),
|
"warning" => Ok(Severity::Warning),
|
||||||
"info" => Ok(Severity::Info),
|
"info" => Ok(Severity::Info),
|
||||||
s => Err(format!("Invalid severity: {}", s)),
|
s => Err(format!("Invalid severity: {s}")),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -256,7 +256,7 @@ impl FromStr for ContractOutputSelection {
|
||||||
s => EvmOutputSelection::from_str(s)
|
s => EvmOutputSelection::from_str(s)
|
||||||
.map(ContractOutputSelection::Evm)
|
.map(ContractOutputSelection::Evm)
|
||||||
.or_else(|_| EwasmOutputSelection::from_str(s).map(ContractOutputSelection::Ewasm))
|
.or_else(|_| EwasmOutputSelection::from_str(s).map(ContractOutputSelection::Ewasm))
|
||||||
.map_err(|_| format!("Invalid contract output selection: {}", s)),
|
.map_err(|_| format!("Invalid contract output selection: {s}")),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -347,7 +347,7 @@ impl FromStr for EvmOutputSelection {
|
||||||
DeployedBytecodeOutputSelection::from_str(s)
|
DeployedBytecodeOutputSelection::from_str(s)
|
||||||
.map(EvmOutputSelection::DeployedByteCode)
|
.map(EvmOutputSelection::DeployedByteCode)
|
||||||
})
|
})
|
||||||
.map_err(|_| format!("Invalid evm selection: {}", s)),
|
.map_err(|_| format!("Invalid evm selection: {s}")),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -412,7 +412,7 @@ impl FromStr for BytecodeOutputSelection {
|
||||||
"evm.bytecode.sourceMap" => Ok(BytecodeOutputSelection::SourceMap),
|
"evm.bytecode.sourceMap" => Ok(BytecodeOutputSelection::SourceMap),
|
||||||
"evm.bytecode.linkReferences" => Ok(BytecodeOutputSelection::LinkReferences),
|
"evm.bytecode.linkReferences" => Ok(BytecodeOutputSelection::LinkReferences),
|
||||||
"evm.bytecode.generatedSources" => Ok(BytecodeOutputSelection::GeneratedSources),
|
"evm.bytecode.generatedSources" => Ok(BytecodeOutputSelection::GeneratedSources),
|
||||||
s => Err(format!("Invalid bytecode selection: {}", s)),
|
s => Err(format!("Invalid bytecode selection: {s}")),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -494,7 +494,7 @@ impl FromStr for DeployedBytecodeOutputSelection {
|
||||||
"evm.deployedBytecode.immutableReferences" => {
|
"evm.deployedBytecode.immutableReferences" => {
|
||||||
Ok(DeployedBytecodeOutputSelection::ImmutableReferences)
|
Ok(DeployedBytecodeOutputSelection::ImmutableReferences)
|
||||||
}
|
}
|
||||||
s => Err(format!("Invalid deployedBytecode selection: {}", s)),
|
s => Err(format!("Invalid deployedBytecode selection: {s}")),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -543,7 +543,7 @@ impl FromStr for EwasmOutputSelection {
|
||||||
"ewasm" => Ok(EwasmOutputSelection::All),
|
"ewasm" => Ok(EwasmOutputSelection::All),
|
||||||
"ewasm.wast" => Ok(EwasmOutputSelection::Wast),
|
"ewasm.wast" => Ok(EwasmOutputSelection::Wast),
|
||||||
"ewasm.wasm" => Ok(EwasmOutputSelection::Wasm),
|
"ewasm.wasm" => Ok(EwasmOutputSelection::Wasm),
|
||||||
s => Err(format!("Invalid ewasm selection: {}", s)),
|
s => Err(format!("Invalid ewasm selection: {s}")),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -120,7 +120,7 @@ pub mod string_bytes {
|
||||||
if value.starts_with("0x") {
|
if value.starts_with("0x") {
|
||||||
serializer.serialize_str(value.as_str())
|
serializer.serialize_str(value.as_str())
|
||||||
} else {
|
} else {
|
||||||
serializer.serialize_str(&format!("0x{}", value))
|
serializer.serialize_str(&format!("0x{value}"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -149,7 +149,7 @@ impl Default for Solc {
|
||||||
#[cfg(not(target_arch = "wasm32"))]
|
#[cfg(not(target_arch = "wasm32"))]
|
||||||
{
|
{
|
||||||
if let Some(solc) = Solc::svm_global_version()
|
if let Some(solc) = Solc::svm_global_version()
|
||||||
.and_then(|vers| Solc::find_svm_installed_version(&vers.to_string()).ok())
|
.and_then(|vers| Solc::find_svm_installed_version(vers.to_string()).ok())
|
||||||
.flatten()
|
.flatten()
|
||||||
{
|
{
|
||||||
return solc
|
return solc
|
||||||
|
@ -279,7 +279,7 @@ impl Solc {
|
||||||
let solc = Self::svm_home()
|
let solc = Self::svm_home()
|
||||||
.ok_or_else(|| SolcError::solc("svm home dir not found"))?
|
.ok_or_else(|| SolcError::solc("svm home dir not found"))?
|
||||||
.join(version)
|
.join(version)
|
||||||
.join(format!("solc-{}", version));
|
.join(format!("solc-{version}"));
|
||||||
|
|
||||||
if !solc.is_file() {
|
if !solc.is_file() {
|
||||||
return Ok(None)
|
return Ok(None)
|
||||||
|
@ -688,7 +688,7 @@ fn version_from_output(output: Output) -> Result<Version> {
|
||||||
.lines()
|
.lines()
|
||||||
.last()
|
.last()
|
||||||
.ok_or_else(|| SolcError::solc("version not found in solc output"))?
|
.ok_or_else(|| SolcError::solc("version not found in solc output"))?
|
||||||
.map_err(|err| SolcError::msg(format!("Failed to read output: {}", err)))?;
|
.map_err(|err| SolcError::msg(format!("Failed to read output: {err}")))?;
|
||||||
// NOTE: semver doesn't like `+` in g++ in build metadata which is invalid semver
|
// NOTE: semver doesn't like `+` in g++ in build metadata which is invalid semver
|
||||||
Ok(Version::from_str(&version.trim_start_matches("Version: ").replace(".g++", ".gcc"))?)
|
Ok(Version::from_str(&version.trim_start_matches("Version: ").replace(".g++", ".gcc"))?)
|
||||||
} else {
|
} else {
|
||||||
|
@ -858,8 +858,8 @@ mod tests {
|
||||||
{
|
{
|
||||||
Solc::blocking_install(&version).unwrap();
|
Solc::blocking_install(&version).unwrap();
|
||||||
}
|
}
|
||||||
let res = Solc::find_svm_installed_version(&version.to_string()).unwrap().unwrap();
|
let res = Solc::find_svm_installed_version(version.to_string()).unwrap().unwrap();
|
||||||
let expected = svm::SVM_HOME.join(ver).join(format!("solc-{}", ver));
|
let expected = svm::SVM_HOME.join(ver).join(format!("solc-{ver}"));
|
||||||
assert_eq!(res.solc, expected);
|
assert_eq!(res.solc, expected);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -876,7 +876,7 @@ mod tests {
|
||||||
fn does_not_find_not_installed_version() {
|
fn does_not_find_not_installed_version() {
|
||||||
let ver = "1.1.1";
|
let ver = "1.1.1";
|
||||||
let version = Version::from_str(ver).unwrap();
|
let version = Version::from_str(ver).unwrap();
|
||||||
let res = Solc::find_svm_installed_version(&version.to_string()).unwrap();
|
let res = Solc::find_svm_installed_version(version.to_string()).unwrap();
|
||||||
assert!(res.is_none());
|
assert!(res.is_none());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -908,6 +908,6 @@ mod tests {
|
||||||
///// helpers
|
///// helpers
|
||||||
|
|
||||||
fn source(version: &str) -> Source {
|
fn source(version: &str) -> Source {
|
||||||
Source { content: format!("pragma solidity {};\n", version) }
|
Source { content: format!("pragma solidity {version};\n") }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,7 +41,7 @@ impl ContractInfo {
|
||||||
impl fmt::Display for ContractInfo {
|
impl fmt::Display for ContractInfo {
|
||||||
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
||||||
if let Some(ref path) = self.path {
|
if let Some(ref path) = self.path {
|
||||||
write!(f, "{}:{}", path, self.name)
|
write!(f, "{path}:{}", self.name)
|
||||||
} else {
|
} else {
|
||||||
write!(f, "{}", self.name)
|
write!(f, "{}", self.name)
|
||||||
}
|
}
|
||||||
|
|
|
@ -752,10 +752,10 @@ impl<'a> fmt::Display for OutputDiagnostics<'a> {
|
||||||
});
|
});
|
||||||
|
|
||||||
if !is_ignored {
|
if !is_ignored {
|
||||||
writeln!(f, "\n{}", err)?;
|
writeln!(f, "\n{err}")?;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
writeln!(f, "\n{}", err)?;
|
writeln!(f, "\n{err}")?;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Ok(())
|
Ok(())
|
||||||
|
|
|
@ -230,7 +230,7 @@ impl ProjectPathsConfig {
|
||||||
// if the import is relative we assume it's already part of the processed input
|
// if the import is relative we assume it's already part of the processed input
|
||||||
// file set
|
// file set
|
||||||
utils::canonicalize(cwd.join(import)).map_err(|err| {
|
utils::canonicalize(cwd.join(import)).map_err(|err| {
|
||||||
SolcError::msg(format!("failed to resolve relative import \"{:?}\"", err))
|
SolcError::msg(format!("failed to resolve relative import \"{err:?}\""))
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
// resolve library file
|
// resolve library file
|
||||||
|
@ -477,7 +477,7 @@ impl ProjectPathsConfig {
|
||||||
}
|
}
|
||||||
|
|
||||||
let result = String::from_utf8(content).map_err(|err| {
|
let result = String::from_utf8(content).map_err(|err| {
|
||||||
SolcError::msg(format!("failed to convert extended bytes to string: {}", err))
|
SolcError::msg(format!("failed to convert extended bytes to string: {err}"))
|
||||||
})?;
|
})?;
|
||||||
|
|
||||||
Ok(result)
|
Ok(result)
|
||||||
|
@ -497,7 +497,7 @@ impl fmt::Display for ProjectPathsConfig {
|
||||||
}
|
}
|
||||||
writeln!(f, "remappings:")?;
|
writeln!(f, "remappings:")?;
|
||||||
for remapping in &self.remappings {
|
for remapping in &self.remappings {
|
||||||
writeln!(f, " {}", remapping)?;
|
writeln!(f, " {remapping}")?;
|
||||||
}
|
}
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
@ -588,7 +588,7 @@ impl PathStyle {
|
||||||
.artifacts(root.join("out"))
|
.artifacts(root.join("out"))
|
||||||
.build_infos(root.join("out").join("build-info"))
|
.build_infos(root.join("out").join("build-info"))
|
||||||
.lib(root.join("lib"))
|
.lib(root.join("lib"))
|
||||||
.remappings(Remapping::find_many(&root.join("lib")))
|
.remappings(Remapping::find_many(root.join("lib")))
|
||||||
.root(root)
|
.root(root)
|
||||||
.build()?,
|
.build()?,
|
||||||
PathStyle::HardHat => ProjectPathsConfig::builder()
|
PathStyle::HardHat => ProjectPathsConfig::builder()
|
||||||
|
@ -883,7 +883,7 @@ impl fmt::Display for AllowedLibPaths {
|
||||||
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
||||||
let lib_paths =
|
let lib_paths =
|
||||||
self.paths().map(|path| format!("{}", path.display())).collect::<Vec<_>>().join(",");
|
self.paths().map(|path| format!("{}", path.display())).collect::<Vec<_>>().join(",");
|
||||||
write!(f, "{}", lib_paths)
|
write!(f, "{lib_paths}")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -981,9 +981,9 @@ mod tests {
|
||||||
.lib(root.join("lib1"))
|
.lib(root.join("lib1"))
|
||||||
.lib(root.join("lib2"))
|
.lib(root.join("lib2"))
|
||||||
.remappings(
|
.remappings(
|
||||||
Remapping::find_many(&root.join("lib1"))
|
Remapping::find_many(root.join("lib1"))
|
||||||
.into_iter()
|
.into_iter()
|
||||||
.chain(Remapping::find_many(&root.join("lib2"))),
|
.chain(Remapping::find_many(root.join("lib2"))),
|
||||||
)
|
)
|
||||||
.build()
|
.build()
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
@ -1009,7 +1009,7 @@ mod tests {
|
||||||
.root(&root)
|
.root(&root)
|
||||||
.sources(root.join("src"))
|
.sources(root.join("src"))
|
||||||
.lib(root.join("lib"))
|
.lib(root.join("lib"))
|
||||||
.remappings(Remapping::find_many(&root.join("lib")))
|
.remappings(Remapping::find_many(root.join("lib")))
|
||||||
.build()
|
.build()
|
||||||
.unwrap();
|
.unwrap();
|
||||||
let project = Project::builder().no_artifacts().paths(paths).ephemeral().build().unwrap();
|
let project = Project::builder().no_artifacts().paths(paths).ephemeral().build().unwrap();
|
||||||
|
|
|
@ -395,15 +395,15 @@ pub struct SimpleNamingStrategy {
|
||||||
|
|
||||||
impl NamingStrategy for SimpleNamingStrategy {
|
impl NamingStrategy for SimpleNamingStrategy {
|
||||||
fn new_source_file_name(&mut self, id: usize) -> String {
|
fn new_source_file_name(&mut self, id: usize) -> String {
|
||||||
format!("SourceFile{}", id)
|
format!("SourceFile{id}")
|
||||||
}
|
}
|
||||||
|
|
||||||
fn new_lib_file_name(&mut self, id: usize) -> String {
|
fn new_lib_file_name(&mut self, id: usize) -> String {
|
||||||
format!("LibFile{}", id)
|
format!("LibFile{id}")
|
||||||
}
|
}
|
||||||
|
|
||||||
fn new_lib_name(&mut self, id: usize) -> String {
|
fn new_lib_name(&mut self, id: usize) -> String {
|
||||||
format!("Lib{}", id)
|
format!("Lib{id}")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -388,7 +388,7 @@ fn contract_file_name(name: impl AsRef<str>) -> String {
|
||||||
if name.ends_with(".sol") {
|
if name.ends_with(".sol") {
|
||||||
name.to_string()
|
name.to_string()
|
||||||
} else {
|
} else {
|
||||||
format!("{}.sol", name)
|
format!("{name}.sol")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -419,7 +419,7 @@ impl TempProject<ConfigurableArtifacts> {
|
||||||
pub fn dapptools_init() -> Result<Self> {
|
pub fn dapptools_init() -> Result<Self> {
|
||||||
let mut project = Self::dapptools()?;
|
let mut project = Self::dapptools()?;
|
||||||
let orig_root = PathBuf::from(env!("CARGO_MANIFEST_DIR")).join("test-data/dapp-sample");
|
let orig_root = PathBuf::from(env!("CARGO_MANIFEST_DIR")).join("test-data/dapp-sample");
|
||||||
copy_dir(&orig_root, project.root())?;
|
copy_dir(orig_root, project.root())?;
|
||||||
project.project_mut().paths.remappings = Remapping::find_many(project.root());
|
project.project_mut().paths.remappings = Remapping::find_many(project.root());
|
||||||
|
|
||||||
Ok(project)
|
Ok(project)
|
||||||
|
|
|
@ -217,7 +217,7 @@ impl Remapping {
|
||||||
if let Some(name) = candidate.window_start.file_name().and_then(|s| s.to_str()) {
|
if let Some(name) = candidate.window_start.file_name().and_then(|s| s.to_str()) {
|
||||||
insert_prioritized(
|
insert_prioritized(
|
||||||
&mut all_remappings,
|
&mut all_remappings,
|
||||||
format!("{}/", name),
|
format!("{name}/"),
|
||||||
candidate.source_dir,
|
candidate.source_dir,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -778,7 +778,7 @@ mod tests {
|
||||||
touch(&path).unwrap();
|
touch(&path).unwrap();
|
||||||
} else {
|
} else {
|
||||||
let path = tmp.join(path);
|
let path = tmp.join(path);
|
||||||
std::fs::create_dir_all(&path).unwrap();
|
std::fs::create_dir_all(path).unwrap();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -801,7 +801,7 @@ mod tests {
|
||||||
assert_eq!(remappings.len(), 1);
|
assert_eq!(remappings.len(), 1);
|
||||||
|
|
||||||
assert_eq!(remappings[0].name, "repo1/");
|
assert_eq!(remappings[0].name, "repo1/");
|
||||||
assert_eq!(remappings[0].path, format!("{}/src/", path));
|
assert_eq!(remappings[0].path, format!("{path}/src/"));
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -1015,7 +1015,7 @@ mod tests {
|
||||||
"node_modules/@openzeppelin/contracts/token/ERC20/IERC20.sol",
|
"node_modules/@openzeppelin/contracts/token/ERC20/IERC20.sol",
|
||||||
];
|
];
|
||||||
mkdir_or_touch(tmp_dir.path(), &paths[..]);
|
mkdir_or_touch(tmp_dir.path(), &paths[..]);
|
||||||
let remappings = Remapping::find_many(&tmp_dir_node_modules);
|
let remappings = Remapping::find_many(tmp_dir_node_modules);
|
||||||
let mut paths = ProjectPathsConfig::hardhat(tmp_dir.path()).unwrap();
|
let mut paths = ProjectPathsConfig::hardhat(tmp_dir.path()).unwrap();
|
||||||
paths.remappings = remappings;
|
paths.remappings = remappings;
|
||||||
|
|
||||||
|
@ -1054,7 +1054,7 @@ mod tests {
|
||||||
mkdir_or_touch(tmp_dir_path, &paths[..]);
|
mkdir_or_touch(tmp_dir_path, &paths[..]);
|
||||||
|
|
||||||
let path = tmp_dir_path.display().to_string();
|
let path = tmp_dir_path.display().to_string();
|
||||||
let mut remappings = Remapping::find_many(&path);
|
let mut remappings = Remapping::find_many(path);
|
||||||
remappings.sort_unstable();
|
remappings.sort_unstable();
|
||||||
|
|
||||||
let mut expected = vec![
|
let mut expected = vec![
|
||||||
|
@ -1115,7 +1115,7 @@ mod tests {
|
||||||
touch(&contract2).unwrap();
|
touch(&contract2).unwrap();
|
||||||
|
|
||||||
let path = tmp_dir_path.display().to_string();
|
let path = tmp_dir_path.display().to_string();
|
||||||
let mut remappings = Remapping::find_many(&path);
|
let mut remappings = Remapping::find_many(path);
|
||||||
remappings.sort_unstable();
|
remappings.sort_unstable();
|
||||||
let mut expected = vec![
|
let mut expected = vec![
|
||||||
Remapping {
|
Remapping {
|
||||||
|
@ -1151,7 +1151,7 @@ mod tests {
|
||||||
mkdir_or_touch(tmp_dir_path, &paths[..]);
|
mkdir_or_touch(tmp_dir_path, &paths[..]);
|
||||||
|
|
||||||
let path = tmp_dir_path.display().to_string();
|
let path = tmp_dir_path.display().to_string();
|
||||||
let mut remappings = Remapping::find_many(&path);
|
let mut remappings = Remapping::find_many(path);
|
||||||
remappings.sort_unstable();
|
remappings.sort_unstable();
|
||||||
|
|
||||||
let mut expected = vec![
|
let mut expected = vec![
|
||||||
|
|
|
@ -163,7 +163,7 @@ pub struct BadName {
|
||||||
fn get_file_name(path: impl Into<PathBuf>, v: &Version) -> PathBuf {
|
fn get_file_name(path: impl Into<PathBuf>, v: &Version) -> PathBuf {
|
||||||
let mut path = path.into();
|
let mut path = path.into();
|
||||||
if let Some(stem) = path.file_stem().and_then(|s| s.to_str().map(|s| s.to_string())) {
|
if let Some(stem) = path.file_stem().and_then(|s| s.to_str().map(|s| s.to_string())) {
|
||||||
path.set_file_name(format!("{}.{}.{}.{}.json", stem, v.major, v.minor, v.patch));
|
path.set_file_name(format!("{stem}.{}.{}.{}.json", v.major, v.minor, v.patch));
|
||||||
}
|
}
|
||||||
path
|
path
|
||||||
}
|
}
|
||||||
|
|
|
@ -370,23 +370,23 @@ impl Reporter for BasicStdoutReporter {
|
||||||
) {
|
) {
|
||||||
self.solc_io_report.log_compiler_output(output, version);
|
self.solc_io_report.log_compiler_output(output, version);
|
||||||
println!(
|
println!(
|
||||||
"Solc {}.{}.{} finished in {:.2?}",
|
"Solc {}.{}.{} finished in {duration:.2?}",
|
||||||
version.major, version.minor, version.patch, duration
|
version.major, version.minor, version.patch
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Invoked before a new [`Solc`] bin is installed
|
/// Invoked before a new [`Solc`] bin is installed
|
||||||
fn on_solc_installation_start(&self, version: &Version) {
|
fn on_solc_installation_start(&self, version: &Version) {
|
||||||
println!("installing solc version \"{}\"", version);
|
println!("installing solc version \"{version}\"");
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Invoked before a new [`Solc`] bin was successfully installed
|
/// Invoked before a new [`Solc`] bin was successfully installed
|
||||||
fn on_solc_installation_success(&self, version: &Version) {
|
fn on_solc_installation_success(&self, version: &Version) {
|
||||||
println!("Successfully installed solc {}", version);
|
println!("Successfully installed solc {version}");
|
||||||
}
|
}
|
||||||
|
|
||||||
fn on_solc_installation_error(&self, version: &Version, error: &str) {
|
fn on_solc_installation_error(&self, version: &Version, error: &str) {
|
||||||
eprintln!("Failed to install solc {}: {}", version, error);
|
eprintln!("Failed to install solc {version}: {error}");
|
||||||
}
|
}
|
||||||
|
|
||||||
fn on_unresolved_imports(&self, imports: &[(&Path, &Path)], remappings: &[Remapping]) {
|
fn on_unresolved_imports(&self, imports: &[(&Path, &Path)], remappings: &[Remapping]) {
|
||||||
|
|
|
@ -787,7 +787,7 @@ impl VersionedSources {
|
||||||
} else {
|
} else {
|
||||||
// find installed svm
|
// find installed svm
|
||||||
Solc::find_svm_installed_version(version.to_string())?.ok_or_else(|| {
|
Solc::find_svm_installed_version(version.to_string())?.ok_or_else(|| {
|
||||||
SolcError::msg(format!("solc \"{}\" should have been installed", version))
|
SolcError::msg(format!("solc \"{version}\" should have been installed"))
|
||||||
})?
|
})?
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,7 @@ impl FromStr for Charset {
|
||||||
match s {
|
match s {
|
||||||
"utf8" => Ok(Charset::Utf8),
|
"utf8" => Ok(Charset::Utf8),
|
||||||
"ascii" => Ok(Charset::Ascii),
|
"ascii" => Ok(Charset::Ascii),
|
||||||
s => Err(format!("invalid charset: {}", s)),
|
s => Err(format!("invalid charset: {s}")),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -103,7 +103,7 @@ fn print_node(
|
||||||
if let Some((last_continues, rest)) = levels_continue.split_last() {
|
if let Some((last_continues, rest)) = levels_continue.split_last() {
|
||||||
for continues in rest {
|
for continues in rest {
|
||||||
let c = if *continues { symbols.down } else { " " };
|
let c = if *continues { symbols.down } else { " " };
|
||||||
write!(out, "{} ", c)?;
|
write!(out, "{c} ")?;
|
||||||
}
|
}
|
||||||
|
|
||||||
let c = if *last_continues { symbols.tee } else { symbols.ell };
|
let c = if *last_continues { symbols.tee } else { symbols.ell };
|
||||||
|
@ -117,7 +117,7 @@ fn print_node(
|
||||||
let has_deps = graph.has_outgoing_edges(node_index);
|
let has_deps = graph.has_outgoing_edges(node_index);
|
||||||
let star = if (new_node && !in_cycle) || !has_deps { "" } else { " (*)" };
|
let star = if (new_node && !in_cycle) || !has_deps { "" } else { " (*)" };
|
||||||
|
|
||||||
writeln!(out, "{}{}", graph.display_node(node_index), star)?;
|
writeln!(out, "{}{star}", graph.display_node(node_index))?;
|
||||||
|
|
||||||
if !new_node || in_cycle {
|
if !new_node || in_cycle {
|
||||||
return Ok(())
|
return Ok(())
|
||||||
|
|
|
@ -38,7 +38,7 @@ enum Token<'a> {
|
||||||
impl<'a> fmt::Debug for Token<'a> {
|
impl<'a> fmt::Debug for Token<'a> {
|
||||||
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
||||||
match self {
|
match self {
|
||||||
Token::Number(s) => write!(f, "NUMBER({:?})", s),
|
Token::Number(s) => write!(f, "NUMBER({s:?})"),
|
||||||
Token::Semicolon => write!(f, "SEMICOLON"),
|
Token::Semicolon => write!(f, "SEMICOLON"),
|
||||||
Token::Colon => write!(f, "COLON"),
|
Token::Colon => write!(f, "COLON"),
|
||||||
Token::In => write!(f, "JMP(i)"),
|
Token::In => write!(f, "JMP(i)"),
|
||||||
|
@ -291,7 +291,7 @@ impl SourceElementBuilder {
|
||||||
|
|
||||||
fn set_jmp(&mut self, jmp: Jump, i: usize) -> Option<SyntaxError> {
|
fn set_jmp(&mut self, jmp: Jump, i: usize) -> Option<SyntaxError> {
|
||||||
if self.jump.is_some() {
|
if self.jump.is_some() {
|
||||||
return Some(SyntaxError::new(format!("Jump already set: {}", i)))
|
return Some(SyntaxError::new(format!("Jump already set: {i}")))
|
||||||
}
|
}
|
||||||
self.jump = Some(jmp);
|
self.jump = Some(jmp);
|
||||||
None
|
None
|
||||||
|
@ -299,7 +299,7 @@ impl SourceElementBuilder {
|
||||||
|
|
||||||
fn set_offset(&mut self, offset: usize, i: usize) -> Option<SyntaxError> {
|
fn set_offset(&mut self, offset: usize, i: usize) -> Option<SyntaxError> {
|
||||||
if self.offset.is_some() {
|
if self.offset.is_some() {
|
||||||
return Some(SyntaxError::new(format!("Offset already set: {}", i)))
|
return Some(SyntaxError::new(format!("Offset already set: {i}")))
|
||||||
}
|
}
|
||||||
self.offset = Some(offset);
|
self.offset = Some(offset);
|
||||||
None
|
None
|
||||||
|
@ -307,7 +307,7 @@ impl SourceElementBuilder {
|
||||||
|
|
||||||
fn set_length(&mut self, length: usize, i: usize) -> Option<SyntaxError> {
|
fn set_length(&mut self, length: usize, i: usize) -> Option<SyntaxError> {
|
||||||
if self.length.is_some() {
|
if self.length.is_some() {
|
||||||
return Some(SyntaxError::new(format!("Length already set: {}", i)))
|
return Some(SyntaxError::new(format!("Length already set: {i}")))
|
||||||
}
|
}
|
||||||
self.length = Some(length);
|
self.length = Some(length);
|
||||||
None
|
None
|
||||||
|
@ -315,7 +315,7 @@ impl SourceElementBuilder {
|
||||||
|
|
||||||
fn set_index(&mut self, index: Option<u32>, i: usize) -> Option<SyntaxError> {
|
fn set_index(&mut self, index: Option<u32>, i: usize) -> Option<SyntaxError> {
|
||||||
if self.index.is_some() {
|
if self.index.is_some() {
|
||||||
return Some(SyntaxError::new(format!("Index already set: {}", i)))
|
return Some(SyntaxError::new(format!("Index already set: {i}")))
|
||||||
}
|
}
|
||||||
self.index = Some(index);
|
self.index = Some(index);
|
||||||
None
|
None
|
||||||
|
@ -323,7 +323,7 @@ impl SourceElementBuilder {
|
||||||
|
|
||||||
fn set_modifier(&mut self, modifier_depth: usize, i: usize) -> Option<SyntaxError> {
|
fn set_modifier(&mut self, modifier_depth: usize, i: usize) -> Option<SyntaxError> {
|
||||||
if self.modifier_depth.is_some() {
|
if self.modifier_depth.is_some() {
|
||||||
return Some(SyntaxError::new(format!("Modifier depth already set: {}", i)))
|
return Some(SyntaxError::new(format!("Modifier depth already set: {i}")))
|
||||||
}
|
}
|
||||||
self.modifier_depth = Some(modifier_depth);
|
self.modifier_depth = Some(modifier_depth);
|
||||||
None
|
None
|
||||||
|
@ -486,7 +486,7 @@ impl State {
|
||||||
State::Length => *self = State::Index,
|
State::Length => *self = State::Index,
|
||||||
State::Index => *self = State::Jmp,
|
State::Index => *self = State::Jmp,
|
||||||
State::Jmp => *self = State::Modifier,
|
State::Jmp => *self = State::Modifier,
|
||||||
State::Modifier => return Some(SyntaxError::new(format!("unexpected colon at {}", i))),
|
State::Modifier => return Some(SyntaxError::new(format!("unexpected colon at {i}"))),
|
||||||
}
|
}
|
||||||
None
|
None
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,7 +43,7 @@ pub static RE_THREE_OR_MORE_NEWLINES: Lazy<Regex> = Lazy::new(|| Regex::new("\n{
|
||||||
|
|
||||||
/// Create a regex that matches any library or contract name inside a file
|
/// Create a regex that matches any library or contract name inside a file
|
||||||
pub fn create_contract_or_lib_name_regex(name: &str) -> Regex {
|
pub fn create_contract_or_lib_name_regex(name: &str) -> Regex {
|
||||||
Regex::new(&format!(r#"(?:using\s+(?P<n1>{name})\s+|is\s+(?:\w+\s*,\s*)*(?P<n2>{name})(?:\s*,\s*\w+)*|(?:(?P<ignore>(?:function|error|as)\s+|\n[^\n]*(?:"([^"\n]|\\")*|'([^'\n]|\\')*))|\W+)(?P<n3>{name})(?:\.|\(| ))"#, name = name)).unwrap()
|
Regex::new(&format!(r#"(?:using\s+(?P<n1>{name})\s+|is\s+(?:\w+\s*,\s*)*(?P<n2>{name})(?:\s*,\s*\w+)*|(?:(?P<ignore>(?:function|error|as)\s+|\n[^\n]*(?:"([^"\n]|\\")*|'([^'\n]|\\')*))|\W+)(?P<n3>{name})name.|\(| ))"#)).unwrap()
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Move a range by a specified offset
|
/// Move a range by a specified offset
|
||||||
|
@ -285,7 +285,7 @@ pub fn library_fully_qualified_placeholder(name: impl AsRef<str>) -> String {
|
||||||
pub fn library_hash_placeholder(name: impl AsRef<[u8]>) -> String {
|
pub fn library_hash_placeholder(name: impl AsRef<[u8]>) -> String {
|
||||||
let hash = library_hash(name);
|
let hash = library_hash(name);
|
||||||
let placeholder = hex::encode(hash);
|
let placeholder = hex::encode(hash);
|
||||||
format!("${}$", placeholder)
|
format!("${placeholder}$")
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns the library placeholder for the given name
|
/// Returns the library placeholder for the given name
|
||||||
|
|
|
@ -421,7 +421,7 @@ fn can_compile_dapp_sample_with_cache() {
|
||||||
);
|
);
|
||||||
|
|
||||||
// deleted artifact is not taken from the cache
|
// deleted artifact is not taken from the cache
|
||||||
std::fs::remove_file(&project.paths.sources.join("Dapp.sol")).unwrap();
|
std::fs::remove_file(project.paths.sources.join("Dapp.sol")).unwrap();
|
||||||
let compiled: ProjectCompileOutput<_> = project.compile().unwrap();
|
let compiled: ProjectCompileOutput<_> = project.compile().unwrap();
|
||||||
assert!(compiled.find_first("Dapp").is_none());
|
assert!(compiled.find_first("Dapp").is_none());
|
||||||
}
|
}
|
||||||
|
@ -636,7 +636,7 @@ contract FooBar {}
|
||||||
fn can_flatten_on_solang_failure() {
|
fn can_flatten_on_solang_failure() {
|
||||||
let root =
|
let root =
|
||||||
PathBuf::from(env!("CARGO_MANIFEST_DIR")).join("test-data/test-flatten-solang-failure");
|
PathBuf::from(env!("CARGO_MANIFEST_DIR")).join("test-data/test-flatten-solang-failure");
|
||||||
let paths = ProjectPathsConfig::builder().sources(&root.join("contracts"));
|
let paths = ProjectPathsConfig::builder().sources(root.join("contracts"));
|
||||||
let project = TempProject::<ConfigurableArtifacts>::new(paths).unwrap();
|
let project = TempProject::<ConfigurableArtifacts>::new(paths).unwrap();
|
||||||
|
|
||||||
let target = root.join("contracts/Contract.sol");
|
let target = root.join("contracts/Contract.sol");
|
||||||
|
@ -1231,7 +1231,7 @@ fn can_recompile_with_changes() {
|
||||||
assert!(compiled.is_unchanged());
|
assert!(compiled.is_unchanged());
|
||||||
|
|
||||||
// modify A.sol
|
// modify A.sol
|
||||||
tmp.add_source("A", format!("{}\n", content)).unwrap();
|
tmp.add_source("A", format!("{content}\n")).unwrap();
|
||||||
let compiled = tmp.compile().unwrap();
|
let compiled = tmp.compile().unwrap();
|
||||||
assert!(!compiled.has_compiler_errors());
|
assert!(!compiled.has_compiler_errors());
|
||||||
assert!(!compiled.is_unchanged());
|
assert!(!compiled.is_unchanged());
|
||||||
|
@ -1286,7 +1286,7 @@ fn can_recompile_with_lowercase_names() {
|
||||||
assert!(compiled.is_unchanged());
|
assert!(compiled.is_unchanged());
|
||||||
|
|
||||||
// modify upgradeProxy.sol
|
// modify upgradeProxy.sol
|
||||||
tmp.add_source("upgradeProxy.sol", format!("{}\n", upgrade)).unwrap();
|
tmp.add_source("upgradeProxy.sol", format!("{upgrade}\n")).unwrap();
|
||||||
let compiled = tmp.compile().unwrap();
|
let compiled = tmp.compile().unwrap();
|
||||||
assert!(!compiled.has_compiler_errors());
|
assert!(!compiled.has_compiler_errors());
|
||||||
assert!(!compiled.is_unchanged());
|
assert!(!compiled.is_unchanged());
|
||||||
|
@ -1339,7 +1339,7 @@ fn can_recompile_unchanged_with_empty_files() {
|
||||||
assert!(compiled.is_unchanged());
|
assert!(compiled.is_unchanged());
|
||||||
|
|
||||||
// modify C.sol
|
// modify C.sol
|
||||||
tmp.add_source("C", format!("{}\n", c)).unwrap();
|
tmp.add_source("C", format!("{c}\n")).unwrap();
|
||||||
let compiled = tmp.compile().unwrap();
|
let compiled = tmp.compile().unwrap();
|
||||||
assert!(!compiled.has_compiler_errors());
|
assert!(!compiled.has_compiler_errors());
|
||||||
assert!(!compiled.is_unchanged());
|
assert!(!compiled.is_unchanged());
|
||||||
|
|
|
@ -7,7 +7,7 @@ fn main() -> eyre::Result<()> {
|
||||||
let contract_name = args.next().unwrap_or_else(|| "SimpleStorage".to_owned());
|
let contract_name = args.next().unwrap_or_else(|| "SimpleStorage".to_owned());
|
||||||
let contract: String = args.next().unwrap_or_else(|| "examples/contract.sol".to_owned());
|
let contract: String = args.next().unwrap_or_else(|| "examples/contract.sol".to_owned());
|
||||||
|
|
||||||
println!("Generating bindings for {}\n", contract);
|
println!("Generating bindings for {contract}\n");
|
||||||
|
|
||||||
// compile it
|
// compile it
|
||||||
let abi = if contract.ends_with(".sol") {
|
let abi = if contract.ends_with(".sol") {
|
||||||
|
@ -22,7 +22,7 @@ fn main() -> eyre::Result<()> {
|
||||||
|
|
||||||
// print to stdout if no output arg is given
|
// print to stdout if no output arg is given
|
||||||
if let Some(output_path) = args.next() {
|
if let Some(output_path) = args.next() {
|
||||||
bindings.write_to_file(&output_path)?;
|
bindings.write_to_file(output_path)?;
|
||||||
} else {
|
} else {
|
||||||
bindings.write(std::io::stdout())?;
|
bindings.write(std::io::stdout())?;
|
||||||
}
|
}
|
||||||
|
|
|
@ -67,7 +67,7 @@ async fn main() -> Result<()> {
|
||||||
// 11. get the new value
|
// 11. get the new value
|
||||||
let value = contract.get_value().call().await?;
|
let value = contract.get_value().call().await?;
|
||||||
|
|
||||||
println!("Value: {}. Logs: {}", value, serde_json::to_string(&logs)?);
|
println!("Value: {value}. Logs: {}", serde_json::to_string(&logs)?);
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,7 +56,7 @@ async fn main() -> Result<()> {
|
||||||
// 11. get the new value
|
// 11. get the new value
|
||||||
let value = contract.get_value().call().await?;
|
let value = contract.get_value().call().await?;
|
||||||
|
|
||||||
println!("Value: {}. Logs: {}", value, serde_json::to_string(&logs)?);
|
println!("Value: {value}. Logs: {}", serde_json::to_string(&logs)?);
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,8 +18,8 @@ fn main() -> Result<()> {
|
||||||
let from = path.next().unwrap();
|
let from = path.next().unwrap();
|
||||||
let to = path.next().unwrap();
|
let to = path.next().unwrap();
|
||||||
println!(
|
println!(
|
||||||
"Swapped {} of token {} for {} of token {}",
|
"Swapped {} of token {from} for {} of token {to}",
|
||||||
decoded.amount_in, from, decoded.amount_out_min, to
|
decoded.amount_in, decoded.amount_out_min
|
||||||
);
|
);
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
|
|
|
@ -66,7 +66,7 @@ pub async fn deploy() {
|
||||||
let value = contract.get_value().call().await.unwrap();
|
let value = contract.get_value().call().await.unwrap();
|
||||||
|
|
||||||
console::log_2(
|
console::log_2(
|
||||||
&format!("Value: `{}`. Logs: ", value).into(),
|
&format!("Value: `{value}`. Logs: ").into(),
|
||||||
&serde_wasm_bindgen::to_value(&logs).unwrap(),
|
&serde_wasm_bindgen::to_value(&logs).unwrap(),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,7 +12,7 @@ async fn main() -> Result<()> {
|
||||||
let h: H256 = H256::from_str(tx_hash)?;
|
let h: H256 = H256::from_str(tx_hash)?;
|
||||||
let options: GethDebugTracingOptions = GethDebugTracingOptions::default();
|
let options: GethDebugTracingOptions = GethDebugTracingOptions::default();
|
||||||
let traces = client.debug_trace_transaction(h, options).await?;
|
let traces = client.debug_trace_transaction(h, options).await?;
|
||||||
println!("{:?}", traces);
|
println!("{traces:?}");
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
|
|
|
@ -7,7 +7,7 @@ async fn main() -> eyre::Result<()> {
|
||||||
.await?
|
.await?
|
||||||
.interval(std::time::Duration::from_millis(2000));
|
.interval(std::time::Duration::from_millis(2000));
|
||||||
let block = provider.get_block_number().await?;
|
let block = provider.get_block_number().await?;
|
||||||
println!("Current block: {}", block);
|
println!("Current block: {block}");
|
||||||
let mut stream = provider.watch_blocks().await?.stream();
|
let mut stream = provider.watch_blocks().await?.stream();
|
||||||
while let Some(block) = stream.next().await {
|
while let Some(block) = stream.next().await {
|
||||||
dbg!(block);
|
dbg!(block);
|
||||||
|
|
|
@ -65,7 +65,7 @@ async fn main() -> eyre::Result<()> {
|
||||||
// 11. get the new value
|
// 11. get the new value
|
||||||
let value = contract.get_value().call().await?;
|
let value = contract.get_value().call().await?;
|
||||||
|
|
||||||
println!("Value: {}. Logs: {}", value, serde_json::to_string(&logs)?);
|
println!("Value: {value}. Logs: {}", serde_json::to_string(&logs)?);
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,7 +10,7 @@ async fn main() -> Result<()> {
|
||||||
let client = Arc::new(client);
|
let client = Arc::new(client);
|
||||||
|
|
||||||
let last_block = client.get_block(BlockNumber::Latest).await?.unwrap().number.unwrap();
|
let last_block = client.get_block(BlockNumber::Latest).await?.unwrap().number.unwrap();
|
||||||
println!("last_block: {}", last_block);
|
println!("last_block: {last_block}");
|
||||||
|
|
||||||
let erc20_transfer_filter = Filter::new()
|
let erc20_transfer_filter = Filter::new()
|
||||||
.from_block(last_block - 10000)
|
.from_block(last_block - 10000)
|
||||||
|
|
|
@ -49,12 +49,12 @@ async fn example() -> Result<()> {
|
||||||
|
|
||||||
let (reserve0, reserve1, _) = pair.get_reserves().call().await?;
|
let (reserve0, reserve1, _) = pair.get_reserves().call().await?;
|
||||||
|
|
||||||
println!("Reserves (token A, Token B): ({}, {})", reserve0, reserve1);
|
println!("Reserves (token A, Token B): ({reserve0}, {reserve1})");
|
||||||
|
|
||||||
let price =
|
let price =
|
||||||
if reserve0 > reserve1 { 1000 * reserve0 / reserve1 } else { 1000 * reserve1 / reserve0 } /
|
if reserve0 > reserve1 { 1000 * reserve0 / reserve1 } else { 1000 * reserve1 / reserve0 } /
|
||||||
1000;
|
1000;
|
||||||
println!("token0 / token1 price = {}", price);
|
println!("token0 / token1 price = {price}");
|
||||||
|
|
||||||
let liquidity = 100.into();
|
let liquidity = 100.into();
|
||||||
|
|
||||||
|
@ -62,9 +62,9 @@ async fn example() -> Result<()> {
|
||||||
let receipt =
|
let receipt =
|
||||||
pair.approve(router.address(), liquidity).send().await?.await?.expect("no receipt found");
|
pair.approve(router.address(), liquidity).send().await?.await?.expect("no receipt found");
|
||||||
println!("contract approved succesfully!");
|
println!("contract approved succesfully!");
|
||||||
println!("{:?}", receipt);
|
println!("{receipt:?}");
|
||||||
|
|
||||||
println!("Removing {} liquidity!", liquidity);
|
println!("Removing {liquidity} liquidity!");
|
||||||
|
|
||||||
let token0 = pair.token_0().call().await?;
|
let token0 = pair.token_0().call().await?;
|
||||||
let token1 = pair.token_1().call().await?;
|
let token1 = pair.token_1().call().await?;
|
||||||
|
@ -84,7 +84,7 @@ async fn example() -> Result<()> {
|
||||||
.await?
|
.await?
|
||||||
.expect("no receipt for remove_liquidity");
|
.expect("no receipt for remove_liquidity");
|
||||||
println!("liquidity removed succesfully!");
|
println!("liquidity removed succesfully!");
|
||||||
println!("{:?}", receipt);
|
println!("{receipt:?}");
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,7 +16,7 @@ async fn main() -> Result<()> {
|
||||||
|
|
||||||
// sign message from your wallet and print out signature produced.
|
// sign message from your wallet and print out signature produced.
|
||||||
let signature = wallet.sign_message(message).await?;
|
let signature = wallet.sign_message(message).await?;
|
||||||
println!("Produced signature {}", signature);
|
println!("Produced signature {signature}");
|
||||||
|
|
||||||
// verify the signature produced from your wallet.
|
// verify the signature produced from your wallet.
|
||||||
signature.verify(message, wallet.address()).unwrap();
|
signature.verify(message, wallet.address()).unwrap();
|
||||||
|
|
|
@ -12,7 +12,7 @@ async fn main() -> Result<()> {
|
||||||
let client = Arc::new(client);
|
let client = Arc::new(client);
|
||||||
|
|
||||||
let last_block = client.get_block(BlockNumber::Latest).await?.unwrap().number.unwrap();
|
let last_block = client.get_block(BlockNumber::Latest).await?.unwrap().number.unwrap();
|
||||||
println!("last_block: {}", last_block);
|
println!("last_block: {last_block}");
|
||||||
|
|
||||||
let erc20_transfer_filter = Filter::new()
|
let erc20_transfer_filter = Filter::new()
|
||||||
.from_block(last_block - 25)
|
.from_block(last_block - 25)
|
||||||
|
|
|
@ -30,8 +30,8 @@ async fn main() -> Result<()> {
|
||||||
let balance_after = provider.get_balance(from, None).await?;
|
let balance_after = provider.get_balance(from, None).await?;
|
||||||
assert!(balance_after < balance_before);
|
assert!(balance_after < balance_before);
|
||||||
|
|
||||||
println!("Balance before {}", balance_before);
|
println!("Balance before {balance_before}");
|
||||||
println!("Balance after {}", balance_after);
|
println!("Balance after {balance_after}");
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,9 +24,9 @@ async fn main() -> Result<()> {
|
||||||
|
|
||||||
// getReserves -> get_reserves
|
// getReserves -> get_reserves
|
||||||
let (reserve0, reserve1, _timestamp) = pair.get_reserves().call().await?;
|
let (reserve0, reserve1, _timestamp) = pair.get_reserves().call().await?;
|
||||||
println!("Reserves (ETH, USDT): ({}, {})", reserve0, reserve1);
|
println!("Reserves (ETH, USDT): ({reserve0}, {reserve1})");
|
||||||
|
|
||||||
let mid_price = f64::powi(10.0, 18 - 6) * reserve1 as f64 / reserve0 as f64;
|
let mid_price = f64::powi(10.0, 18 - 6) * reserve1 as f64 / reserve0 as f64;
|
||||||
println!("ETH/USDT price: {:.2}", mid_price);
|
println!("ETH/USDT price: {mid_price:.2}");
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue