Cleaned up code

This commit is contained in:
Johann 2022-03-10 12:03:08 -07:00
parent cb595113b6
commit 91a6885a5a
1 changed files with 26 additions and 23 deletions

View File

@ -513,9 +513,11 @@ pub trait ArtifactOutput {
// A Cache to store all of the Yul Contracts // A Cache to store all of the Yul Contracts
// This is becase while we can fetch the Artifact, I was unable to convert it back into a Contract // This is becase while we can fetch the Artifact, I was unable to convert it back into a Contract
// So instead we just save the Contracts for later, as teh Contract Object is easy to modify, then convert into an Artifact // So instead we just save the Contracts for later, as teh Contract Object is easy to modify, then convert into an Artifact
let mut yul_contracts: Vec<Contract> = Vec::<Contract>::new(); // Map that maps the name of an artifact to the Contract object for cheaper access
let mut yul_contracts: HashMap<String, Contract> = HashMap::new();
let mut artifacts = ArtifactsMap::new(); let mut artifacts = ArtifactsMap::new();
for (file, contracts) in contracts.as_ref().iter() { for (file, contracts) in contracts.as_ref().iter() {
let mut entries = BTreeMap::new(); let mut entries = BTreeMap::new();
for (name, versioned_contracts) in contracts { for (name, versioned_contracts) in contracts {
@ -551,8 +553,9 @@ pub trait ArtifactOutput {
); );
} }
if is_yul_artifact(artifact_path.clone()){ if is_yul_artifact(artifact_path.clone()){
let target_file = file.as_str().replace(".abi.sol", ".yul");
// If its just a .yul file save its Contract for later, so that we can add in its ABI later // If its just a .yul file save its Contract for later, so that we can add in its ABI later
yul_contracts.push(contract.contract.clone()); yul_contracts.insert(target_file, contract.contract.clone());
} }
contracts.push(ArtifactFile { contracts.push(ArtifactFile {
artifact, artifact,
@ -567,10 +570,10 @@ pub trait ArtifactOutput {
} }
// Loop through all the Yul Contracts we cached which now need an ABI inserted into them // Loop through all the Yul Contracts we cached which now need an ABI inserted into them
for mut yul_contract in yul_contracts {
// Loop through all the Yul ABIs we found, and see if they match, and then add the ABI to the Yul contract // Loop through all the Yul ABIs we found, and see if they match, and then add the ABI to the Yul contract
// and then convert Yul Contract with ABI into an Artifact, and save the Artifact for our return // and then convert Yul Contract with ABI into an Artifact, and save the Artifact for our return
for (yul_target_path, needed_artifact_fragments) in &yul_abi_targets { for (yul_target_path, needed_artifact_fragments) in &yul_abi_targets {
let mut yul_contract = yul_contracts.get(yul_target_path).unwrap().to_owned();
// Set the (empty) ABI on the Yul Contract to the abi of its matching .abi.sol file // Set the (empty) ABI on the Yul Contract to the abi of its matching .abi.sol file
yul_contract.abi = needed_artifact_fragments.1.clone(); yul_contract.abi = needed_artifact_fragments.1.clone();
@ -595,7 +598,7 @@ pub trait ArtifactOutput {
artifacts.insert(needed_artifact_fragments.0.clone(), entries); artifacts.insert(needed_artifact_fragments.0.clone(), entries);
} }
}
Artifacts(artifacts) Artifacts(artifacts)