Skip to content
This repository has been archived by the owner on Oct 19, 2024. It is now read-only.

Commit

Permalink
chore(solc): more verbose traces
Browse files Browse the repository at this point in the history
  • Loading branch information
mattsse committed Dec 25, 2021
1 parent 918063d commit 9619a98
Show file tree
Hide file tree
Showing 3 changed files with 56 additions and 19 deletions.
26 changes: 21 additions & 5 deletions ethers-solc/src/cache.rs
Original file line number Diff line number Diff line change
Expand Up @@ -66,26 +66,28 @@ impl SolFilesCache {
tracing::trace!("reading solfiles cache at {}", path.display());
let file = fs::File::open(path).map_err(|err| SolcError::io(err, path))?;
let file = std::io::BufReader::new(file);
let cache = serde_json::from_reader(file)?;
tracing::trace!("done");
let cache: Self = serde_json::from_reader(file)?;
tracing::trace!("read cache \"{}\" with {} entries", cache.format, cache.files.len());
Ok(cache)
}

/// Write the cache to json file
pub fn write(&self, path: impl AsRef<Path>) -> Result<()> {
let path = path.as_ref();
let file = fs::File::create(path).map_err(|err| SolcError::io(err, path))?;
tracing::trace!("writing cache to json file");
tracing::trace!("writing cache to json file: \"{}\"", path.display());
serde_json::to_writer_pretty(file, self)?;
tracing::trace!("cache file located: {}", path.display());
tracing::trace!("cache file located: \"{}\"", path.display());
Ok(())
}

pub fn remove_missing_files(&mut self) {
tracing::trace!("remove non existing files from cache");
self.files.retain(|file, _| Path::new(file).exists())
}

pub fn remove_changed_files(&mut self, changed_files: &Sources) {
tracing::trace!("remove changed files from cache");
self.files.retain(|file, _| !changed_files.contains_key(file))
}

Expand Down Expand Up @@ -157,16 +159,30 @@ impl SolFilesCache {
) -> bool {
if let Some(entry) = self.files.get(file) {
if entry.content_hash.as_bytes() != hash {
tracing::trace!("changed content hash for cached artifact \"{}\"", file.display());
return true
}
if let Some(config) = config {
if config != &entry.solc_config {
tracing::trace!(
"changed solc config for cached artifact \"{}\"",
file.display()
);
return true
}
}

entry.artifacts.iter().any(|name| !T::output_exists(file, name, artifacts_root))
let missing_artifacts =
entry.artifacts.iter().any(|name| !T::output_exists(file, name, artifacts_root));
if missing_artifacts {
tracing::trace!(
"missing linked artifacts for cached artifact \"{}\"",
file.display()
);
}
missing_artifacts
} else {
tracing::trace!("missing cached artifact for \"{}\"", file.display());
true
}
}
Expand Down
48 changes: 34 additions & 14 deletions ethers-solc/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -191,6 +191,11 @@ impl<Artifacts: ArtifactOutput> Project<Artifacts> {
for import in source.parse_imports() {
if let Some(lib) = utils::resolve_library(&self.paths.libraries, import) {
if let Entry::Vacant(entry) = libs.entry(import.into()) {
tracing::trace!(
"resolved library import \"{}\" at \"{}\"",
import,
lib.display()
);
entry.insert((Source::read(&lib)?, lib));
}
}
Expand All @@ -208,10 +213,11 @@ impl<Artifacts: ArtifactOutput> Project<Artifacts> {
#[tracing::instrument(skip_all, name = "compile")]
pub fn compile(&self) -> Result<ProjectCompileOutput<Artifacts>> {
let sources = self.sources()?;
tracing::trace!("found {} sources to compile: {:?}", sources.len(), sources.keys());

#[cfg(all(feature = "svm", feature = "async"))]
if self.auto_detect {
tracing::trace!("using solc auto detection");
tracing::trace!("using solc auto detection to compile sources");
return self.svm_compile(sources)
}

Expand Down Expand Up @@ -264,7 +270,7 @@ impl<Artifacts: ArtifactOutput> Project<Artifacts> {
let entry = sources_by_version.entry(solc).or_insert_with(BTreeMap::new);
entry.insert(path.clone(), source);
}
tracing::trace!("preprocessing finished");
tracing::trace!("solc version preprocessing finished");

tracing::trace!("verifying solc checksums");
for solc in sources_by_version.keys() {
Expand Down Expand Up @@ -313,7 +319,7 @@ impl<Artifacts: ArtifactOutput> Project<Artifacts> {
&self,
sources_by_version: BTreeMap<Solc, BTreeMap<PathBuf, Source>>,
) -> Result<ProjectCompileOutput<Artifacts>> {
tracing::trace!("compiling sources using {} solc jobs", self.solc_jobs);
tracing::trace!("compile sources in parallel using {} solc jobs", self.solc_jobs);
let mut compiled =
ProjectCompileOutput::with_ignored_errors(self.ignored_error_codes.clone());
let mut paths = PathMap::default();
Expand All @@ -329,6 +335,9 @@ impl<Artifacts: ArtifactOutput> Project<Artifacts> {
compiled.extend(ProjectCompileOutput::from_unchanged(artifacts));
}
PreprocessedJob::Items(sources, map, cached_artifacts) => {
tracing::trace!("cached artifacts: \"{:?}\"", cached_artifacts.keys());
tracing::trace!("compile sources: \"{:?}\"", sources.keys());

compiled.extend_artifacts(cached_artifacts);
// replace absolute path with source name to make solc happy
let sources = map.set_source_names(sources);
Expand All @@ -343,19 +352,19 @@ impl<Artifacts: ArtifactOutput> Project<Artifacts> {
}
};
}
tracing::trace!("execute {} compile jobs in parallel", jobs.len());

let outputs = tokio::runtime::Runtime::new()
.unwrap()
.block_on(Solc::compile_many(jobs, self.solc_jobs));

for (res, _, input) in outputs.into_outputs() {
let output = res?;

if !output.has_error() {
if self.cached {
// get all contract names of the files and map them to the disk file
all_artifacts.extend(paths.get_artifacts(&output.contracts));
all_sources.extend(paths.set_disk_paths(input.sources));
all_artifacts.extend(paths.get_artifacts(&output.contracts));
}

if !self.no_artifacts {
Expand Down Expand Up @@ -392,14 +401,22 @@ impl<Artifacts: ArtifactOutput> Project<Artifacts> {
PreprocessedJob::Items(a, b, c) => (a, b, c),
};

tracing::trace!("compiling");
let version = solc.version()?;
tracing::trace!(
"compiling {} files with {}. Using {} cached files",
sources.len(),
version,
cached_artifacts.len()
);
tracing::trace!("cached artifacts: \"{:?}\"", cached_artifacts.keys());
tracing::trace!("compile sources: \"{:?}\"", sources.keys());

// replace absolute path with source name to make solc happy
let sources = paths.set_source_names(sources);

let input = CompilerInput::with_sources(sources)
.settings(self.solc_config.settings.clone())
.normalize_evm_version(&solc.version()?)
.normalize_evm_version(&version)
.with_remappings(self.paths.remappings.clone());

tracing::trace!("calling solc with {} sources", input.sources.len());
Expand Down Expand Up @@ -437,45 +454,48 @@ impl<Artifacts: ArtifactOutput> Project<Artifacts> {
/// Preprocesses the given source files by resolving their libs and check against cache if
/// configured
fn preprocess_sources(&self, mut sources: Sources) -> Result<PreprocessedJob<Artifacts>> {
tracing::trace!("preprocessing sources files");
tracing::trace!("start preprocessing {} sources files", sources.len());

// keeps track of source names / disk paths
let mut paths = PathMap::default();

tracing::trace!("resolving libraries");
tracing::trace!("start resolving libraries");
for (import, (source, path)) in self.resolved_libraries(&sources)? {
// inserting with absolute path here and keep track of the source name <-> path mappings
sources.insert(path.clone(), source);
paths.path_to_source_name.insert(path.clone(), import.clone());
paths.source_name_to_path.insert(import, path);
}
tracing::trace!("resolved libraries");
tracing::trace!("resolved all libraries");

// If there's a cache set, filter to only re-compile the files which were changed
let (sources, cached_artifacts) = if self.cached && self.paths.cache.exists() {
tracing::trace!("reading solfiles cache for incremental compilation");
tracing::trace!("start reading solfiles cache for incremental compilation");
let mut cache = SolFilesCache::read(&self.paths.cache)?;
cache.remove_missing_files();
tracing::trace!("done reading solfiles cache for incremental compilation");
let changed_files = cache.get_changed_or_missing_artifacts_files::<Artifacts>(
sources,
Some(&self.solc_config),
&self.paths.artifacts,
);
tracing::trace!("detected {} changed files", changed_files.len());
cache.remove_changed_files(&changed_files);

let cached_artifacts = if self.paths.artifacts.exists() {
tracing::trace!("reading artifacts from cache..");
let artifacts = cache.read_artifacts::<Artifacts>(&self.paths.artifacts)?;
tracing::trace!("read artifacts from cache");
tracing::trace!("read {} artifacts from cache", artifacts.len());
artifacts
} else {
BTreeMap::default()
};

// if nothing changed and all artifacts still exist
if changed_files.is_empty() {
tracing::trace!("unchanged source files");
tracing::trace!(
"unchanged source files, reusing artifacts {:?}",
cached_artifacts.keys()
);
return Ok(PreprocessedJob::Unchanged(cached_artifacts))
}
// There are changed files and maybe some cached files
Expand Down
1 change: 1 addition & 0 deletions ethers-solc/src/utils.rs
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,7 @@ pub fn is_local_source_name(libs: &[impl AsRef<Path>], source: impl AsRef<Path>)

/// Returns the path to the library if the source path is in fact determined to be a library path,
/// and it exists.
/// Note: this does not handle relative imports or remappings.
pub fn resolve_library(libs: &[impl AsRef<Path>], source: impl AsRef<Path>) -> Option<PathBuf> {
let source = source.as_ref();
let comp = source.components().next()?;
Expand Down

0 comments on commit 9619a98

Please sign in to comment.