Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(deps): Move to Alloy ABI encoding/decoding & alloy types #5986

Merged
merged 83 commits into from
Oct 25, 2023
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
Show all changes
83 commits
Select commit Hold shift + click to select a range
ee18e87
feat: find and replace all ethers_solc mentions outside anvil
Evalir Oct 5, 2023
6c6aa4e
chore: keep resolving errors as fuzz is getting migrated
Evalir Oct 5, 2023
f33e414
feat: fuzz/trace changes
Evalir Oct 6, 2023
a8bb5b0
feat: partial trace migration
Evalir Oct 6, 2023
adc2786
chore: use temporal sol! macro in diff file for decode migration
Evalir Oct 17, 2023
8bc67d2
feat: use proptest traits instead of custom impl
Evalir Oct 17, 2023
65f0918
chore: address comments
Evalir Oct 17, 2023
a54005a
chore: remove alloy console bindings
Evalir Oct 17, 2023
2c70bd9
feat: introduce foundry-block-explorers
Evalir Oct 17, 2023
55ad9bf
chore: partial common abi helpers migration
Evalir Oct 17, 2023
94fb974
feat: partial decode migration
Evalir Oct 18, 2023
b3935cc
feat: re-introduce block-explorers
Evalir Oct 18, 2023
8737a52
feat: fix compiler errors
Evalir Oct 18, 2023
988e756
chore
Evalir Oct 18, 2023
5b8c207
chore: tentative inspector migration
Evalir Oct 18, 2023
bd2fbb3
Merge branch 'master' into evalir/introduce-foundry-compilers
Evalir Oct 18, 2023
3c3b35c
feat: switch to using static decoder to decode errors
Evalir Oct 18, 2023
7484d3b
chore: clippy
Evalir Oct 18, 2023
3adebd5
feat: migrate trace types temporarily
Evalir Oct 19, 2023
c44e796
chore: replace ethers tracing types for local tracing types
Evalir Oct 19, 2023
b51f741
chore: rebase
Evalir Oct 19, 2023
bb68371
fix: handle decoding with static decoder, tests
Evalir Oct 19, 2023
079c879
chore: use JsonAbi for console/hardhat/hevm abis
Evalir Oct 19, 2023
d9207b2
chore: add todo
Evalir Oct 19, 2023
efd0323
chore: replace types downstream and remove glue
Evalir Oct 19, 2023
de459d4
feat: fix last evm issues, start fixing downstream type issues
Evalir Oct 20, 2023
8356303
chore: cargo
Evalir Oct 20, 2023
bcb57a2
chore: more downstream error fixes
Evalir Oct 20, 2023
4d4255b
chore: fix test files
Evalir Oct 20, 2023
5f145b7
chore: more downstream fixes
Evalir Oct 20, 2023
90d5b05
chore: fmt
Evalir Oct 20, 2023
3ea011c
feat: migrate unit utils, replace
Evalir Oct 20, 2023
48832e5
chore: fix tests, fmt
Evalir Oct 20, 2023
2cefb6f
compiles
Evalir Oct 22, 2023
6bef6ad
clippy
Evalir Oct 22, 2023
170f5e6
chore: clippy
Evalir Oct 22, 2023
d8e54b9
Merge branch 'master' into evalir/introduce-foundry-compilers
Evalir Oct 22, 2023
5b404e0
chore: last fixes
Evalir Oct 22, 2023
2dbe680
chore: update block explorers
Evalir Oct 22, 2023
ea9b980
chore: actually coerce values correctly
Evalir Oct 23, 2023
a1b7442
chore: fix broken test
Evalir Oct 23, 2023
23e281d
chore: fix estimation test, parse values as alloy nums
Evalir Oct 23, 2023
bdc95bb
chore: fix abi parsing
Evalir Oct 23, 2023
8507f92
chore: selector tests
Evalir Oct 23, 2023
e42aeba
chore: fix more tests, remove more glue
Evalir Oct 23, 2023
dc05ee5
chore: properly decode logs
Evalir Oct 23, 2023
944174a
chore: use selector_type to handle tuples correctly
Evalir Oct 23, 2023
4b2f0ea
chore: clippy and fix another test
Evalir Oct 23, 2023
f297ace
chore: fix remaining abi tests
Evalir Oct 23, 2023
403de57
chore: use proptest traits for fuzzer
Evalir Oct 23, 2023
ffcb558
more test fixes ongod
Evalir Oct 23, 2023
2c64c3d
clippy
Evalir Oct 23, 2023
ef21ace
chore: use abigen for console logs for now
Evalir Oct 23, 2023
99c228d
fix: generate valid values in fuzzer
Evalir Oct 23, 2023
ebf9523
chore: clippy
Evalir Oct 23, 2023
92c6b5a
chore: readd settings
Evalir Oct 23, 2023
e3dfa8b
chore: various fixes
Evalir Oct 23, 2023
da9b483
chore: fix script arguments decoding
Evalir Oct 24, 2023
adc940a
chore: fix more tests
Evalir Oct 24, 2023
b1f5ff7
chore: last ots fixes
Evalir Oct 24, 2023
0dbcf71
fix: decoding
Evalir Oct 24, 2023
0e2c954
chore: clippy
Evalir Oct 24, 2023
4d9ea34
chore: fmt
Evalir Oct 24, 2023
9b5c45c
chore: fix deny check
Evalir Oct 24, 2023
1d1dc01
chore: deny fixes
Evalir Oct 24, 2023
e50cc48
chore: force default features off
Evalir Oct 24, 2023
5ce86fe
Merge branch 'master' into evalir/introduce-foundry-compilers
Evalir Oct 24, 2023
5c37c4b
chore: update block-explorers
Evalir Oct 24, 2023
30b2295
chore: doc fixes
Evalir Oct 24, 2023
cd25d3b
chore: ignore invariant storage test due to flakyness
Evalir Oct 24, 2023
6c88473
chore: update foundry-block-explorers
Evalir Oct 24, 2023
fb7bd39
chore: cleanup, config migration
Evalir Oct 24, 2023
5500c14
chore: resolve comments, more cleanup, remove unwraps
Evalir Oct 24, 2023
e4e347a
chore: remove last mentions of ethers::etherscan
Evalir Oct 24, 2023
823a6e3
chore: remove ethers-solc feat
Evalir Oct 24, 2023
27f107a
Merge branch 'master' into evalir/introduce-foundry-compilers
Evalir Oct 24, 2023
cf7fdce
chore: use alloy master again
Evalir Oct 24, 2023
371e817
chore: readd NameOrAddress
Evalir Oct 24, 2023
4e4e4c1
chore: clippy/fmt
Evalir Oct 24, 2023
bcd565f
chore: readd support on storage
Evalir Oct 24, 2023
bd3e506
fix: add remappings on settings
Evalir Oct 25, 2023
f958758
chore: address comments (remove create2, noop map, remove eyre from d…
Evalir Oct 25, 2023
963234d
chore: use NameOrAddress
Evalir Oct 25, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
52 changes: 50 additions & 2 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

5 changes: 5 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -158,6 +158,9 @@ alloy-dyn-abi = { version = "0.4", default-features = false }
alloy-json-abi = { version = "0.4", default-features = false }
alloy-sol-types = { version = "0.4", default-features = false }

# solc utils
foundry-compilers = { version = "0.1", default-features = false}

solang-parser = "=0.3.2"

## misc
Expand Down Expand Up @@ -191,6 +194,8 @@ ethers-middleware = { git = "https://github.com/gakonst/ethers-rs" }
ethers-etherscan = { git = "https://github.com/gakonst/ethers-rs" }
ethers-solc = { git = "https://github.com/gakonst/ethers-rs" }

foundry-compilers = {git = "https://github.com/foundry-rs/compilers"}

revm = { git = "https://github.com/bluealloy/revm/", branch = "main" }
revm-interpreter = { git = "https://github.com/bluealloy/revm/", branch = "main" }
revm-precompile = { git = "https://github.com/bluealloy/revm/", branch = "main" }
Expand Down
1 change: 1 addition & 0 deletions crates/abi/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -22,3 +22,4 @@ foundry-macros.workspace = true
ethers-core.workspace = true
ethers-contract = { workspace = true, features = ["abigen", "providers"] }
ethers-providers.workspace = true
alloy-sol-types.workspace = true
28 changes: 28 additions & 0 deletions crates/abi/src/bindings/alloy_console.rs

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions crates/abi/src/bindings/mod.rs

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion crates/abi/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,4 +6,4 @@

mod bindings;

pub use bindings::{console, hardhat_console, hevm};
pub use bindings::{console, alloy_console, hardhat_console, hevm};
6 changes: 2 additions & 4 deletions crates/cast/bin/cmd/call.rs
Original file line number Diff line number Diff line change
@@ -1,15 +1,13 @@
use cast::{Cast, TxBuilder};
use clap::Parser;
use ethers::{
solc::EvmVersion,
types::{BlockId, NameOrAddress, U256},
};
use ethers::types::{BlockId, NameOrAddress, U256};
use eyre::{Result, WrapErr};
use foundry_cli::{
opts::{EthereumOpts, TransactionOpts},
utils::{self, handle_traces, parse_ether_value, TraceResult},
};
use foundry_common::runtime_client::RuntimeClient;
use foundry_compilers::EvmVersion;
use foundry_config::{find_project_root_path, Config};
use foundry_evm::{executor::opts::EvmOpts, trace::TracingExecutor};
use foundry_utils::types::ToAlloy;
Expand Down
3 changes: 2 additions & 1 deletion crates/cast/bin/cmd/run.rs
Original file line number Diff line number Diff line change
@@ -1,12 +1,13 @@
use clap::Parser;
use ethers::{prelude::Middleware, solc::EvmVersion, types::H160};
use ethers::{prelude::Middleware, types::H160};
use eyre::{Result, WrapErr};
use foundry_cli::{
init_progress,
opts::RpcOpts,
update_progress, utils,
utils::{handle_traces, TraceResult},
};
use foundry_compilers::EvmVersion;
use foundry_config::{find_project_root_path, Config};
use foundry_evm::{
executor::{inspector::cheatcodes::util::configure_tx_env, opts::EvmOpts, EvmError},
Expand Down
6 changes: 2 additions & 4 deletions crates/cast/bin/cmd/storage.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,7 @@ use crate::opts::parse_slot;
use cast::Cast;
use clap::Parser;
use comfy_table::{presets::ASCII_MARKDOWN, Table};
use ethers::{
abi::ethabi::ethereum_types::BigEndianHash, etherscan::Client, prelude::*,
solc::artifacts::StorageLayout,
};
use ethers::{abi::ethabi::ethereum_types::BigEndianHash, etherscan::Client, prelude::*};
use eyre::Result;
use foundry_cli::{
opts::{CoreBuildArgs, EtherscanOpts, RpcOpts},
Expand All @@ -16,6 +13,7 @@ use foundry_common::{
compile::{compile, etherscan_project, suppress_compile},
RetryProvider,
};
use foundry_compilers::artifacts::StorageLayout;
use foundry_config::{
figment::{self, value::Dict, Metadata, Profile},
impl_figment_convert_cast, Config,
Expand Down
2 changes: 1 addition & 1 deletion crates/cast/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1944,7 +1944,7 @@ impl SimpleCast {
eyre::bail!("Number of leading zeroes must not be greater than 4");
}
if optimize == 0 {
let selector = HumanReadableParser::parse_function(signature)?.short_signature();
let selector = HumanReadableParser::parse_function(signature)?.selector();
return Ok((hex::encode_prefixed(selector), String::from(signature)))
}
let Some((name, params)) = signature.split_once('(') else {
Expand Down
2 changes: 1 addition & 1 deletion crates/chisel/benches/session_source.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
use chisel::session_source::{SessionSource, SessionSourceConfig};
use criterion::{criterion_group, Criterion};
use ethers_solc::Solc;
use foundry_compilers::Solc;
use foundry_config::Config;
use foundry_evm::executor::opts::EvmOpts;
use once_cell::sync::Lazy;
Expand Down
4 changes: 2 additions & 2 deletions crates/chisel/src/executor.rs
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,8 @@ use alloy_dyn_abi::{DynSolType, DynSolValue};
use alloy_json_abi::EventParam;
use alloy_primitives::{hex, Address, U256};
use core::fmt::Debug;
use ethers_solc::Artifact;
use eyre::{Result, WrapErr};
use foundry_compilers::Artifact;
use foundry_evm::{
decode::decode_console_logs,
executor::{inspector::CheatsConfig, Backend, ExecutorBuilder},
Expand Down Expand Up @@ -1362,7 +1362,7 @@ impl<'a> Iterator for InstructionIter<'a> {
#[cfg(test)]
mod tests {
use super::*;
use ethers_solc::{error::SolcError, Solc};
use foundry_compilers::{error::SolcError, Solc};
use std::sync::Mutex;

#[test]
Expand Down
8 changes: 4 additions & 4 deletions crates/chisel/src/session_source.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,12 +4,12 @@
//! the REPL contract's source code. It provides simple compilation, parsing, and
//! execution helpers.

use ethers_solc::{
use eyre::Result;
use forge_fmt::solang_ext::SafeUnwrap;
use foundry_compilers::{
artifacts::{Source, Sources},
CompilerInput, CompilerOutput, EvmVersion, Solc,
};
use eyre::Result;
use forge_fmt::solang_ext::SafeUnwrap;
use foundry_config::{Config, SolcReq};
use foundry_evm::executor::{opts::EvmOpts, Backend};
use semver::Version;
Expand Down Expand Up @@ -304,7 +304,7 @@ impl SessionSource {
self
}

/// Generates and ethers_solc::CompilerInput from the source
/// Generates and foundry_compilers::CompilerInput from the source
///
/// ### Returns
///
Expand Down
2 changes: 1 addition & 1 deletion crates/chisel/tests/cache.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use chisel::session::ChiselSession;
use ethers_solc::EvmVersion;
use foundry_compilers::EvmVersion;
use foundry_config::Config;
use foundry_evm::executor::opts::EvmOpts;
use serial_test::serial;
Expand Down
4 changes: 2 additions & 2 deletions crates/cli/src/opts/build/core.rs
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
use super::ProjectPathsArgs;
use crate::{opts::CompilerArgs, utils::LoadConfig};
use clap::{Parser, ValueHint};
use ethers::solc::{
use eyre::Result;
use foundry_compilers::{
artifacts::RevertStrings, remappings::Remapping, utils::canonicalized, Project,
};
use eyre::Result;
use foundry_config::{
figment,
figment::{
Expand Down
2 changes: 1 addition & 1 deletion crates/cli/src/opts/build/mod.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use clap::Parser;
use ethers::solc::{artifacts::output_selection::ContractOutputSelection, EvmVersion};
use foundry_compilers::{artifacts::output_selection::ContractOutputSelection, EvmVersion};
use serde::Serialize;

mod core;
Expand Down
2 changes: 1 addition & 1 deletion crates/cli/src/opts/build/paths.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
use clap::{Parser, ValueHint};
use ethers::solc::remappings::Remapping;
use eyre::Result;
use foundry_compilers::remappings::Remapping;
use foundry_config::{
figment,
figment::{
Expand Down
2 changes: 1 addition & 1 deletion crates/cli/src/opts/dependency.rs
Original file line number Diff line number Diff line change
Expand Up @@ -139,7 +139,7 @@ impl Dependency {
#[cfg(test)]
mod tests {
use super::*;
use ethers::solc::info::ContractInfo;
use foundry_compilers::info::ContractInfo;

#[test]
fn parses_dependencies() {
Expand Down
19 changes: 8 additions & 11 deletions crates/cli/src/utils/cmd.rs
Original file line number Diff line number Diff line change
@@ -1,16 +1,13 @@
use ethers::{
abi::Abi,
core::types::Chain,
solc::{
artifacts::{CompactBytecode, CompactDeployedBytecode},
cache::{CacheEntry, SolFilesCache},
info::ContractInfo,
utils::read_json_file,
Artifact, ProjectCompileOutput,
},
};
use ethers::{abi::Abi, core::types::Chain};
use eyre::{Result, WrapErr};
use foundry_common::{cli_warn, fs, TestFunctionExt};
use foundry_compilers::{
artifacts::{CompactBytecode, CompactDeployedBytecode},
cache::{CacheEntry, SolFilesCache},
info::ContractInfo,
utils::read_json_file,
Artifact, ProjectCompileOutput,
};
use foundry_config::{error::ExtractConfigError, figment::Figment, Chain as ConfigChain, Config};
use foundry_debugger::DebuggerArgs;
use foundry_evm::{
Expand Down
6 changes: 5 additions & 1 deletion crates/common/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -16,11 +16,15 @@ foundry-macros.workspace = true

# eth
ethers-core.workspace = true
ethers-solc.workspace = true
ethers-providers = { workspace = true, features = ["ws", "ipc"] }
ethers-middleware.workspace = true
ethers-etherscan = { workspace = true, features = ["ethers-solc"] }

# alloy
alloy-primitives = { workspace = true, features = ["serde", "getrandom", "arbitrary", "rlp"] }
alloy-dyn-abi = { workspace = true, features = ["arbitrary"] }
alloy-json-abi.workspace = true
foundry-compilers.workspace = true
# io
reqwest = { version = "0.11", default-features = false }

Expand Down
Loading