pub struct CacheEntry<S = Settings> {
pub last_modification_date: u64,
pub content_hash: String,
pub source_name: PathBuf,
pub compiler_settings: S,
pub imports: BTreeSet<PathBuf>,
pub version_requirement: Option<String>,
pub artifacts: BTreeMap<String, BTreeMap<Version, CachedArtifact>>,
pub seen_by_compiler: bool,
}Expand description
A CacheEntry in the cache file represents a solidity file
A solidity file can contain several contracts, for every contract a separate Artifact is
emitted. so the CacheEntry tracks the artifacts by name. A file can be compiled with multiple
solc versions generating version specific artifacts.
Fields§
§last_modification_date: u64the last modification time of this file
content_hash: Stringhash to identify whether the content of the file changed
source_name: PathBufidentifier name see foundry_compilers_core::utils::source_name()
compiler_settings: Swhat config was set when compiling this file
imports: BTreeSet<PathBuf>fully resolved imports of the file
all paths start relative from the project’s root: src/importedFile.sol
version_requirement: Option<String>The solidity version pragma
artifacts: BTreeMap<String, BTreeMap<Version, CachedArtifact>>all artifacts produced for this file
In theory a file can be compiled by different solc versions:
A(<=0.8.10) imports C(>0.4.0) and B(0.8.11) imports C(>0.4.0)
file C would be compiled twice, with 0.8.10 and 0.8.11, producing two different
artifacts.
This map tracks the artifacts by name -> (Version -> PathBuf).
This mimics the default artifacts directory structure
seen_by_compiler: boolWhether this file was compiled at least once.
If this is true and artifacts are empty, it means that given version of the file does
not produce any artifacts and it should not be compiled again.
If this is false, then artifacts are definitely empty and it should be compiled if we may need artifacts.
Implementations§
source§impl<S> CacheEntry<S>
impl<S> CacheEntry<S>
sourcepub fn last_modified(&self) -> Duration
pub fn last_modified(&self) -> Duration
Returns the last modified timestamp Duration
sourcepub fn find_artifact_path(&self, contract_name: &str) -> Option<&Path>
pub fn find_artifact_path(&self, contract_name: &str) -> Option<&Path>
Returns the artifact path for the contract name.
§Examples
use foundry_compilers::cache::CacheEntry;
let entry: CacheEntry = ...;
entry.find_artifact_path("Greeter");sourcepub fn read_last_modification_date(file: &Path) -> Result<u64>
pub fn read_last_modification_date(file: &Path) -> Result<u64>
Reads the last modification date from the file’s metadata
sourcepub fn contains_version(&self, version: &Version) -> bool
pub fn contains_version(&self, version: &Version) -> bool
Returns true if the artifacts set contains the given version
sourcepub fn artifacts_versions(
&self,
) -> impl Iterator<Item = (&Version, &CachedArtifact)>
pub fn artifacts_versions( &self, ) -> impl Iterator<Item = (&Version, &CachedArtifact)>
Iterator that yields all artifact files and their version
sourcepub fn find_artifact(
&self,
contract: &str,
version: &Version,
) -> Option<&CachedArtifact>
pub fn find_artifact( &self, contract: &str, version: &Version, ) -> Option<&CachedArtifact>
Returns the artifact file for the contract and version pair
sourcepub fn artifacts_for_version<'a>(
&'a self,
version: &'a Version,
) -> impl Iterator<Item = &'a CachedArtifact> + 'a
pub fn artifacts_for_version<'a>( &'a self, version: &'a Version, ) -> impl Iterator<Item = &'a CachedArtifact> + 'a
Iterator that yields all artifact files and their version
sourcepub fn artifacts(&self) -> impl Iterator<Item = &CachedArtifact>
pub fn artifacts(&self) -> impl Iterator<Item = &CachedArtifact>
Iterator that yields all artifact files
sourcepub fn artifacts_mut(&mut self) -> impl Iterator<Item = &mut CachedArtifact>
pub fn artifacts_mut(&mut self) -> impl Iterator<Item = &mut CachedArtifact>
Mutable iterator over all artifact files
sourcepub fn all_artifacts_exist(&self) -> bool
pub fn all_artifacts_exist(&self) -> bool
Checks if all artifact files exist
sourcepub fn join_artifacts_files(&mut self, base: &Path)
pub fn join_artifacts_files(&mut self, base: &Path)
Sets the artifact’s paths to base adjoined to the artifact’s path.
sourcepub fn strip_artifact_files_prefixes(&mut self, base: &Path)
pub fn strip_artifact_files_prefixes(&mut self, base: &Path)
Removes base from the artifact’s path
Trait Implementations§
source§impl<S: Clone> Clone for CacheEntry<S>
impl<S: Clone> Clone for CacheEntry<S>
source§fn clone(&self) -> CacheEntry<S>
fn clone(&self) -> CacheEntry<S>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moresource§impl<S: Debug> Debug for CacheEntry<S>
impl<S: Debug> Debug for CacheEntry<S>
source§impl<'de, S> Deserialize<'de> for CacheEntry<S>where
S: Deserialize<'de>,
impl<'de, S> Deserialize<'de> for CacheEntry<S>where
S: Deserialize<'de>,
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
source§impl<S: PartialEq> PartialEq for CacheEntry<S>
impl<S: PartialEq> PartialEq for CacheEntry<S>
source§impl<S> Serialize for CacheEntry<S>where
S: Serialize,
impl<S> Serialize for CacheEntry<S>where
S: Serialize,
impl<S: Eq> Eq for CacheEntry<S>
impl<S> StructuralPartialEq for CacheEntry<S>
Auto Trait Implementations§
impl<S> Freeze for CacheEntry<S>where
S: Freeze,
impl<S> RefUnwindSafe for CacheEntry<S>where
S: RefUnwindSafe,
impl<S> Send for CacheEntry<S>where
S: Send,
impl<S> Sync for CacheEntry<S>where
S: Sync,
impl<S> Unpin for CacheEntry<S>where
S: Unpin,
impl<S> UnwindSafe for CacheEntry<S>where
S: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit)source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moresource§impl<T> Paint for Twhere
T: ?Sized,
impl<T> Paint for Twhere
T: ?Sized,
source§fn fg(&self, value: Color) -> Painted<&T>
fn fg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the foreground set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like red() and
green(), which have the same functionality but are
pithier.
§Example
Set foreground color to white using fg():
use yansi::{Paint, Color};
painted.fg(Color::White);Set foreground color to white using white().
use yansi::Paint;
painted.white();source§fn bright_black(&self) -> Painted<&T>
fn bright_black(&self) -> Painted<&T>
Returns self with the
fg()
set to
Color::BrightBlack.
§Example
println!("{}", value.bright_black());source§fn bright_red(&self) -> Painted<&T>
fn bright_red(&self) -> Painted<&T>
source§fn bright_green(&self) -> Painted<&T>
fn bright_green(&self) -> Painted<&T>
Returns self with the
fg()
set to
Color::BrightGreen.
§Example
println!("{}", value.bright_green());source§fn bright_yellow(&self) -> Painted<&T>
fn bright_yellow(&self) -> Painted<&T>
Returns self with the
fg()
set to
Color::BrightYellow.
§Example
println!("{}", value.bright_yellow());source§fn bright_blue(&self) -> Painted<&T>
fn bright_blue(&self) -> Painted<&T>
source§fn bright_magenta(&self) -> Painted<&T>
fn bright_magenta(&self) -> Painted<&T>
Returns self with the
fg()
set to
Color::BrightMagenta.
§Example
println!("{}", value.bright_magenta());source§fn bright_cyan(&self) -> Painted<&T>
fn bright_cyan(&self) -> Painted<&T>
source§fn bright_white(&self) -> Painted<&T>
fn bright_white(&self) -> Painted<&T>
Returns self with the
fg()
set to
Color::BrightWhite.
§Example
println!("{}", value.bright_white());source§fn bg(&self, value: Color) -> Painted<&T>
fn bg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the background set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like on_red() and
on_green(), which have the same functionality but
are pithier.
§Example
Set background color to red using fg():
use yansi::{Paint, Color};
painted.bg(Color::Red);Set background color to red using on_red().
use yansi::Paint;
painted.on_red();source§fn on_primary(&self) -> Painted<&T>
fn on_primary(&self) -> Painted<&T>
source§fn on_magenta(&self) -> Painted<&T>
fn on_magenta(&self) -> Painted<&T>
source§fn on_bright_black(&self) -> Painted<&T>
fn on_bright_black(&self) -> Painted<&T>
Returns self with the
bg()
set to
Color::BrightBlack.
§Example
println!("{}", value.on_bright_black());source§fn on_bright_red(&self) -> Painted<&T>
fn on_bright_red(&self) -> Painted<&T>
source§fn on_bright_green(&self) -> Painted<&T>
fn on_bright_green(&self) -> Painted<&T>
Returns self with the
bg()
set to
Color::BrightGreen.
§Example
println!("{}", value.on_bright_green());source§fn on_bright_yellow(&self) -> Painted<&T>
fn on_bright_yellow(&self) -> Painted<&T>
Returns self with the
bg()
set to
Color::BrightYellow.
§Example
println!("{}", value.on_bright_yellow());source§fn on_bright_blue(&self) -> Painted<&T>
fn on_bright_blue(&self) -> Painted<&T>
Returns self with the
bg()
set to
Color::BrightBlue.
§Example
println!("{}", value.on_bright_blue());source§fn on_bright_magenta(&self) -> Painted<&T>
fn on_bright_magenta(&self) -> Painted<&T>
Returns self with the
bg()
set to
Color::BrightMagenta.
§Example
println!("{}", value.on_bright_magenta());source§fn on_bright_cyan(&self) -> Painted<&T>
fn on_bright_cyan(&self) -> Painted<&T>
Returns self with the
bg()
set to
Color::BrightCyan.
§Example
println!("{}", value.on_bright_cyan());source§fn on_bright_white(&self) -> Painted<&T>
fn on_bright_white(&self) -> Painted<&T>
Returns self with the
bg()
set to
Color::BrightWhite.
§Example
println!("{}", value.on_bright_white());source§fn attr(&self, value: Attribute) -> Painted<&T>
fn attr(&self, value: Attribute) -> Painted<&T>
Enables the styling Attribute value.
This method should be used rarely. Instead, prefer to use
attribute-specific builder methods like bold() and
underline(), which have the same functionality
but are pithier.
§Example
Make text bold using attr():
use yansi::{Paint, Attribute};
painted.attr(Attribute::Bold);Make text bold using using bold().
use yansi::Paint;
painted.bold();source§fn underline(&self) -> Painted<&T>
fn underline(&self) -> Painted<&T>
Returns self with the
attr()
set to
Attribute::Underline.
§Example
println!("{}", value.underline());source§fn rapid_blink(&self) -> Painted<&T>
fn rapid_blink(&self) -> Painted<&T>
Returns self with the
attr()
set to
Attribute::RapidBlink.
§Example
println!("{}", value.rapid_blink());source§fn quirk(&self, value: Quirk) -> Painted<&T>
fn quirk(&self, value: Quirk) -> Painted<&T>
Enables the yansi Quirk value.
This method should be used rarely. Instead, prefer to use quirk-specific
builder methods like mask() and
wrap(), which have the same functionality but are
pithier.
§Example
Enable wrapping using .quirk():
use yansi::{Paint, Quirk};
painted.quirk(Quirk::Wrap);Enable wrapping using wrap().
use yansi::Paint;
painted.wrap();source§fn clear(&self) -> Painted<&T>
👎Deprecated since 1.0.1: renamed to resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.
fn clear(&self) -> Painted<&T>
resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.source§fn whenever(&self, value: Condition) -> Painted<&T>
fn whenever(&self, value: Condition) -> Painted<&T>
Conditionally enable styling based on whether the Condition value
applies. Replaces any previous condition.
See the crate level docs for more details.
§Example
Enable styling painted only when both stdout and stderr are TTYs:
use yansi::{Paint, Condition};
painted.red().on_yellow().whenever(Condition::STDOUTERR_ARE_TTY);