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: impl AsRef<Path>) -> HashSet<&PathBuf>
pub fn imports(&self, path: impl AsRef<Path>) -> HashSet<&PathBuf>
Returns all files imported by the given file
sourcepub fn resolve_sources(
paths: &ProjectPathsConfig<D::Language>,
sources: Sources,
) -> Result<Graph<D>>
pub fn resolve_sources( paths: &ProjectPathsConfig<D::Language>, sources: Sources, ) -> Result<Graph<D>>
Resolves a number of sources within the given config
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);