From 18dda9aa8322b22b9ae6d7e4fc61d1813923413d Mon Sep 17 00:00:00 2001 From: Connor Mendenhall Date: Sat, 2 Apr 2022 17:37:38 -0400 Subject: [PATCH] feat(solc): pass compile time to reporter (#1098) * Pass compile time to solc_success/on_solc_success * Update changelog --- CHANGELOG.md | 1 + ethers-solc/src/compile/project.rs | 8 +++++--- ethers-solc/src/report/mod.rs | 19 ++++++++++++++++--- 3 files changed, 22 insertions(+), 6 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 41dbefae7..edba032be 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,7 @@ ### Unreleased +- Pass compilation time as additional argument to `Reporter::on_solc_success` [1098](https://github.com/gakonst/ethers-rs/pull/1098) - Fix aws signer bug which maps un-normalized signature to error if no normalization occurs (in `aws::utils::decode_signature`) - `Transaction::from` will default to `Address::zero()`. Add `recover_from` and `recover_from_mut` methods for recovering the sender from signature, and also diff --git a/ethers-solc/src/compile/project.rs b/ethers-solc/src/compile/project.rs index ff64c6d59..7169582cb 100644 --- a/ethers-solc/src/compile/project.rs +++ b/ethers-solc/src/compile/project.rs @@ -115,7 +115,7 @@ use crate::{ use rayon::prelude::*; use crate::filter::SparseOutputFileFilter; -use std::{collections::btree_map::BTreeMap, path::PathBuf}; +use std::{collections::btree_map::BTreeMap, path::PathBuf, time::Instant}; #[derive(Debug)] pub struct ProjectCompiler<'a, T: ArtifactOutput> { @@ -457,9 +457,10 @@ fn compile_sequential( input.sources.keys() ); + let start = Instant::now(); report::solc_spawn(&solc, &version, &input, &actually_dirty); let output = solc.compile_exact(&input)?; - report::solc_success(&solc, &version, &output); + report::solc_success(&solc, &version, &output, &start.elapsed()); tracing::trace!("compiled input, output has error: {}", output.has_error()); tracing::trace!("received compiler output: {:?}", output.contracts.keys()); aggregated.extend(version.clone(), output); @@ -542,9 +543,10 @@ fn compile_parallel( input.sources.len(), input.sources.keys() ); + let start = Instant::now(); report::solc_spawn(&solc, &version, &input, &actually_dirty); solc.compile(&input).map(move |output| { - report::solc_success(&solc, &version, &output); + report::solc_success(&solc, &version, &output, &start.elapsed()); (version, output) }) }) diff --git a/ethers-solc/src/report/mod.rs b/ethers-solc/src/report/mod.rs index d4c224a2a..79c4dd44c 100644 --- a/ethers-solc/src/report/mod.rs +++ b/ethers-solc/src/report/mod.rs @@ -27,6 +27,7 @@ use std::{ atomic::{AtomicBool, AtomicUsize, Ordering}, Arc, }, + time::Duration, }; mod compiler; @@ -115,7 +116,14 @@ pub trait Reporter: 'static { } /// Invoked with the `CompilerOutput` if [`Solc::compile()`] was successful - fn on_solc_success(&self, _solc: &Solc, _version: &Version, _output: &CompilerOutput) {} + fn on_solc_success( + &self, + _solc: &Solc, + _version: &Version, + _output: &CompilerOutput, + _duration: &Duration, + ) { + } /// Invoked before a new [`Solc`] bin is installed fn on_solc_installation_start(&self, _version: &Version) {} @@ -181,8 +189,13 @@ pub(crate) fn solc_spawn( get_default(|r| r.reporter.on_solc_spawn(solc, version, input, dirty_files)); } -pub(crate) fn solc_success(solc: &Solc, version: &Version, output: &CompilerOutput) { - get_default(|r| r.reporter.on_solc_success(solc, version, output)); +pub(crate) fn solc_success( + solc: &Solc, + version: &Version, + output: &CompilerOutput, + duration: &Duration, +) { + get_default(|r| r.reporter.on_solc_success(solc, version, output, duration)); } #[allow(unused)]