Struct foundry_compilers::resolver::Graph
source · pub struct Graph<D = SolData> { /* private fields */ }Expand description
Represents a fully-resolved solidity dependency graph. Each node in the graph is a file and edges represent dependencies between them. See also https://docs.soliditylang.org/en/latest/layout-of-source-files.html?highlight=import#importing-other-source-files
Implementations§
source§impl<D: ParsedSource> Graph<D>
impl<D: ParsedSource> Graph<D>
sourcepub fn print_with_options(&self, opts: TreeOptions)
pub fn print_with_options(&self, opts: TreeOptions)
Print the graph to StdOut using the provided TreeOptions
sourcepub fn imported_nodes(&self, from: usize) -> &[usize]
pub fn imported_nodes(&self, from: usize) -> &[usize]
Returns a list of nodes the given node index points to for the given kind.
sourcepub fn all_imported_nodes(
&self,
from: usize,
) -> impl Iterator<Item = usize> + '_
pub fn all_imported_nodes( &self, from: usize, ) -> impl Iterator<Item = usize> + '_
Returns an iterator that yields all imports of a node and all their imports
sourcepub fn files(&self) -> &HashMap<PathBuf, usize>
pub fn files(&self) -> &HashMap<PathBuf, usize>
Returns all the resolved files and their index in the graph
sourcepub fn node_ids(&self, start: usize) -> impl Iterator<Item = usize> + '_
pub fn node_ids(&self, start: usize) -> impl Iterator<Item = usize> + '_
Returns an iterator that yields all nodes of the dependency tree that the given node id spans, starting with the node itself.
§Panics
if the start node id is not included in the graph
sourcepub fn nodes(&self, start: usize) -> impl Iterator<Item = &Node<D>> + '_
pub fn nodes(&self, start: usize) -> impl Iterator<Item = &Node<D>> + '_
Same as Self::node_ids but returns the actual Node
sourcepub fn into_sources(self) -> (Sources, GraphEdges<D>)
pub fn into_sources(self) -> (Sources, GraphEdges<D>)
Consumes the Graph, effectively splitting the nodes and the GraphEdges off and
returning the nodes converted to Sources
sourcepub fn input_nodes(&self) -> impl Iterator<Item = &Node<D>>
pub fn input_nodes(&self) -> impl Iterator<Item = &Node<D>>
Returns an iterator that yields only those nodes that represent input files.
See Self::resolve_sources
This won’t yield any resolved library nodes
sourcepub fn imports(&self, path: &Path) -> HashSet<&PathBuf>
pub fn imports(&self, path: &Path) -> HashSet<&PathBuf>
Returns all files imported by the given file
sourcepub fn resolve_sources(
paths: &ProjectPathsConfig<D::Language>,
sources: Sources,
) -> Result<Self>
pub fn resolve_sources( paths: &ProjectPathsConfig<D::Language>, sources: Sources, ) -> Result<Self>
Resolves a number of sources within the given config
sourcepub fn resolve(paths: &ProjectPathsConfig<D::Language>) -> Result<Self>
pub fn resolve(paths: &ProjectPathsConfig<D::Language>) -> Result<Self>
Resolves the dependencies of a project’s source contracts
source§impl<L: Language, D: ParsedSource<Language = L>> Graph<D>
impl<L: Language, D: ParsedSource<Language = L>> Graph<D>
sourcepub fn into_sources_by_version<C: Compiler<ParsedSource = D, Language = L>>(
self,
offline: bool,
locked_versions: &HashMap<L, Version>,
compiler: &C,
) -> Result<(HashMap<C::Language, HashMap<Version, Sources>>, GraphEdges<D>)>
pub fn into_sources_by_version<C: Compiler<ParsedSource = D, Language = L>>( self, offline: bool, locked_versions: &HashMap<L, Version>, compiler: &C, ) -> Result<(HashMap<C::Language, HashMap<Version, Sources>>, GraphEdges<D>)>
Consumes the nodes of the graph and returns all input files together with their appropriate version and the edges of the graph
First we determine the compatible version for each input file (from sources and test folder,
see Self::resolve) and then we add all resolved library imports.
Trait Implementations§
Auto Trait Implementations§
impl<D> Freeze for Graph<D>
impl<D> RefUnwindSafe for Graph<D>where
D: RefUnwindSafe,
impl<D> Send for Graph<D>where
D: Send,
impl<D> Sync for Graph<D>where
D: Sync,
impl<D> Unpin for Graph<D>where
D: Unpin,
impl<D> UnwindSafe for Graph<D>where
D: 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> 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);