pub struct AnalysisSession { /* private fields */ }Expand description
Reusable engine session for one resolved project.
The session owns the resolved config and discovered file set so future consumers can share graph-sensitive inputs without each surface recreating its own partial orchestration.
Implementations§
Source§impl AnalysisSession
impl AnalysisSession
Sourcepub fn load(root: &Path, config_path: Option<&Path>) -> EngineResult<Self>
pub fn load(root: &Path, config_path: Option<&Path>) -> EngineResult<Self>
Load config and discover files for a project root.
§Errors
Returns an error when config loading fails.
Sourcepub fn load_with_config(
root: &Path,
config_path: Option<&Path>,
configure: impl FnOnce(&mut ResolvedConfig),
) -> EngineResult<Self>
pub fn load_with_config( root: &Path, config_path: Option<&Path>, configure: impl FnOnce(&mut ResolvedConfig), ) -> EngineResult<Self>
Load config, apply one caller-supplied config adjustment, then discover files for a project root.
§Errors
Returns an error when config loading fails.
Sourcepub fn load_default(root: &Path) -> Self
pub fn load_default(root: &Path) -> Self
Build a session from built-in defaults, ignoring project config files.
This is intended for editor fallback paths that have already reported a config-load warning but should still surface best-effort diagnostics.
Sourcepub fn from_config(project_config: ProjectConfig) -> Self
pub fn from_config(project_config: ProjectConfig) -> Self
Build a session from a previously resolved config.
Sourcepub fn from_resolved_config(config: ResolvedConfig) -> Self
pub fn from_resolved_config(config: ResolvedConfig) -> Self
Build a session from a resolved config when the caller already owns command-specific config loading.
Sourcepub fn config(&self) -> &ResolvedConfig
pub fn config(&self) -> &ResolvedConfig
Resolved project config.
Sourcepub fn config_path(&self) -> Option<&Path>
pub fn config_path(&self) -> Option<&Path>
Config file path when one was loaded.
Sourcepub fn files(&self) -> &[DiscoveredFile]
pub fn files(&self) -> &[DiscoveredFile]
Discovered files for this session.
Sourcepub fn workspaces(&self) -> &[WorkspaceInfo]
pub fn workspaces(&self) -> &[WorkspaceInfo]
Workspace packages discovered during config/session setup.
Sourcepub fn source_fingerprints(&self) -> FxHashMap<PathBuf, SourceFingerprint>
pub fn source_fingerprints(&self) -> FxHashMap<PathBuf, SourceFingerprint>
Source metadata fingerprints for every discovered source file.
Sourcepub fn changed_files_since(
&self,
git_ref: &str,
) -> Result<FxHashSet<PathBuf>, ChangedFilesError>
pub fn changed_files_since( &self, git_ref: &str, ) -> Result<FxHashSet<PathBuf>, ChangedFilesError>
Resolve files changed since a git ref against this session root.
§Errors
Returns an error when the ref is invalid, git is unavailable, or the root is not part of a repository.
Sourcepub fn workspace_diagnostics(&self) -> &[WorkspaceDiagnostic]
pub fn workspace_diagnostics(&self) -> &[WorkspaceDiagnostic]
Workspace and source-discovery diagnostics captured for this session.
Sourcepub fn into_parts(self) -> AnalysisSessionParts
pub fn into_parts(self) -> AnalysisSessionParts
Consume the session and return the resolved config plus discovery data.
Sourcepub fn into_parsed_parts(
self,
need_complexity: bool,
) -> ParsedAnalysisSessionParts
pub fn into_parsed_parts( self, need_complexity: bool, ) -> ParsedAnalysisSessionParts
Consume the session, load the parser cache, and parse discovered files.
Sourcepub fn parsed_parts(&self, need_complexity: bool) -> ParsedAnalysisSessionParts
pub fn parsed_parts(&self, need_complexity: bool) -> ParsedAnalysisSessionParts
Parse discovered files without consuming the session.
Sourcepub fn parsed_parts_uncached(
&self,
need_complexity: bool,
) -> ParsedAnalysisSessionParts
pub fn parsed_parts_uncached( &self, need_complexity: bool, ) -> ParsedAnalysisSessionParts
Parse discovered files without consuming the session or retaining parser output in the session cache.
Sourcepub fn analyze_dead_code(&self) -> EngineResult<DeadCodeAnalysis>
pub fn analyze_dead_code(&self) -> EngineResult<DeadCodeAnalysis>
Sourcepub fn analyze_dead_code_with_complexity(
&self,
) -> EngineResult<DeadCodeAnalysisOutput>
pub fn analyze_dead_code_with_complexity( &self, ) -> EngineResult<DeadCodeAnalysisOutput>
Run dead-code analysis with retained complexity artifacts.
§Errors
Returns an error if parsing or analysis fails.
Sourcepub fn analyze_dead_code_with_artifacts(
&self,
need_complexity: bool,
retain_graph: bool,
) -> EngineResult<DeadCodeAnalysisArtifacts>
pub fn analyze_dead_code_with_artifacts( &self, need_complexity: bool, retain_graph: bool, ) -> EngineResult<DeadCodeAnalysisArtifacts>
Run dead-code analysis with retained modules, discovered files and graph.
§Errors
Returns an error if parsing or analysis fails.
Sourcepub fn analyze_dead_code_retaining_files(
&self,
need_complexity: bool,
retain_graph: bool,
) -> EngineResult<DeadCodeAnalysisArtifacts>
pub fn analyze_dead_code_retaining_files( &self, need_complexity: bool, retain_graph: bool, ) -> EngineResult<DeadCodeAnalysisArtifacts>
Run dead-code analysis while retaining discovered files for downstream command stages that reuse discovery but do not need parser modules.
§Errors
Returns an error if parsing or analysis fails.
Sourcepub fn analyze_dead_code_with_parsed_modules(
&self,
modules: &[ModuleInfo],
) -> EngineResult<DeadCodeAnalysisArtifacts>
pub fn analyze_dead_code_with_parsed_modules( &self, modules: &[ModuleInfo], ) -> EngineResult<DeadCodeAnalysisArtifacts>
Run dead-code analysis from modules already parsed through this session.
This preserves the session’s resolved config and discovered file set for follow-up analyses that reuse parser output without redoing discovery.
§Errors
Returns an error if graph construction or analysis fails.
Sourcepub fn analyze_dead_code_with_session_artifacts(
&self,
need_complexity: bool,
retain_graph: bool,
changed_files: Option<FxHashSet<PathBuf>>,
) -> EngineResult<AnalysisSessionArtifacts>
pub fn analyze_dead_code_with_session_artifacts( &self, need_complexity: bool, retain_graph: bool, changed_files: Option<FxHashSet<PathBuf>>, ) -> EngineResult<AnalysisSessionArtifacts>
Run dead-code analysis and return the session-scoped reuse artifacts.
Callers pass a changed-file set they have already resolved for the command. The returned value keeps that set beside parser, graph, and source-fingerprint data so downstream runners do not have to rebuild or rediscover the same inputs.
§Errors
Returns an error if parsing or analysis fails.
Sourcepub fn find_duplicates(&self) -> DuplicationReport
pub fn find_duplicates(&self) -> DuplicationReport
Run duplication detection using the session’s discovered files.
Sourcepub fn find_duplicates_with(
&self,
config: &DuplicatesConfig,
) -> DuplicationReport
pub fn find_duplicates_with( &self, config: &DuplicatesConfig, ) -> DuplicationReport
Run duplication detection using custom duplicate options.
Sourcepub fn analyze_project_with(
&self,
duplicates_config: &DuplicatesConfig,
retain_complexity_artifacts: bool,
) -> EngineResult<ProjectAnalysisOutput>
pub fn analyze_project_with( &self, duplicates_config: &DuplicatesConfig, retain_complexity_artifacts: bool, ) -> EngineResult<ProjectAnalysisOutput>
Run dead-code and duplication analysis for this session.
When retain_complexity_artifacts is true, the dead-code result keeps
parser artifacts needed by editor overlays such as inline complexity.
§Errors
Returns an error if dead-code parsing or analysis fails.
Sourcepub fn analyze_project_with_artifacts(
&self,
duplicates_config: &DuplicatesConfig,
options: ProjectAnalysisArtifactOptions,
) -> EngineResult<ProjectAnalysisArtifacts>
pub fn analyze_project_with_artifacts( &self, duplicates_config: &DuplicatesConfig, options: ProjectAnalysisArtifactOptions, ) -> EngineResult<ProjectAnalysisArtifacts>
Run dead-code and duplication analysis with retained session reuse data.
This is the engine-owned project artifact boundary for callers that need to hand one analysis result across audit, decision, editor, or follow-up analysis surfaces without rediscovering session metadata.
§Errors
Returns an error if dead-code parsing or analysis fails.
Sourcepub fn find_duplicates_with_defaults(
&self,
config: &DuplicatesConfig,
cache_dir: Option<&Path>,
) -> DuplicationAnalysis
pub fn find_duplicates_with_defaults( &self, config: &DuplicatesConfig, cache_dir: Option<&Path>, ) -> DuplicationAnalysis
Run duplication detection and return report sidecar metadata.
Sourcepub fn find_duplicates_touching_files_with_defaults(
&self,
config: &DuplicatesConfig,
changed_files: &[PathBuf],
cache_dir: Option<&Path>,
) -> DuplicationAnalysis
pub fn find_duplicates_touching_files_with_defaults( &self, config: &DuplicatesConfig, changed_files: &[PathBuf], cache_dir: Option<&Path>, ) -> DuplicationAnalysis
Run focused duplication detection for a changed-file set.
Trait Implementations§
Auto Trait Implementations§
impl !Freeze for AnalysisSession
impl RefUnwindSafe for AnalysisSession
impl Send for AnalysisSession
impl Sync for AnalysisSession
impl Unpin for AnalysisSession
impl UnsafeUnpin for AnalysisSession
impl UnwindSafe for AnalysisSession
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<D> OwoColorize for D
impl<D> OwoColorize for D
Source§fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>where
C: Color,
fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>where
C: Color,
Source§fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>where
C: Color,
fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>where
C: Color,
Source§fn black(&self) -> FgColorDisplay<'_, Black, Self>
fn black(&self) -> FgColorDisplay<'_, Black, Self>
Source§fn on_black(&self) -> BgColorDisplay<'_, Black, Self>
fn on_black(&self) -> BgColorDisplay<'_, Black, Self>
Source§fn red(&self) -> FgColorDisplay<'_, Red, Self>
fn red(&self) -> FgColorDisplay<'_, Red, Self>
Source§fn on_red(&self) -> BgColorDisplay<'_, Red, Self>
fn on_red(&self) -> BgColorDisplay<'_, Red, Self>
Source§fn green(&self) -> FgColorDisplay<'_, Green, Self>
fn green(&self) -> FgColorDisplay<'_, Green, Self>
Source§fn on_green(&self) -> BgColorDisplay<'_, Green, Self>
fn on_green(&self) -> BgColorDisplay<'_, Green, Self>
Source§fn yellow(&self) -> FgColorDisplay<'_, Yellow, Self>
fn yellow(&self) -> FgColorDisplay<'_, Yellow, Self>
Source§fn on_yellow(&self) -> BgColorDisplay<'_, Yellow, Self>
fn on_yellow(&self) -> BgColorDisplay<'_, Yellow, Self>
Source§fn blue(&self) -> FgColorDisplay<'_, Blue, Self>
fn blue(&self) -> FgColorDisplay<'_, Blue, Self>
Source§fn on_blue(&self) -> BgColorDisplay<'_, Blue, Self>
fn on_blue(&self) -> BgColorDisplay<'_, Blue, Self>
Source§fn magenta(&self) -> FgColorDisplay<'_, Magenta, Self>
fn magenta(&self) -> FgColorDisplay<'_, Magenta, Self>
Source§fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>
fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>
Source§fn purple(&self) -> FgColorDisplay<'_, Magenta, Self>
fn purple(&self) -> FgColorDisplay<'_, Magenta, Self>
Source§fn on_purple(&self) -> BgColorDisplay<'_, Magenta, Self>
fn on_purple(&self) -> BgColorDisplay<'_, Magenta, Self>
Source§fn cyan(&self) -> FgColorDisplay<'_, Cyan, Self>
fn cyan(&self) -> FgColorDisplay<'_, Cyan, Self>
Source§fn on_cyan(&self) -> BgColorDisplay<'_, Cyan, Self>
fn on_cyan(&self) -> BgColorDisplay<'_, Cyan, Self>
Source§fn white(&self) -> FgColorDisplay<'_, White, Self>
fn white(&self) -> FgColorDisplay<'_, White, Self>
Source§fn on_white(&self) -> BgColorDisplay<'_, White, Self>
fn on_white(&self) -> BgColorDisplay<'_, White, Self>
Source§fn default_color(&self) -> FgColorDisplay<'_, Default, Self>
fn default_color(&self) -> FgColorDisplay<'_, Default, Self>
Source§fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>
fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>
Source§fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>
fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>
Source§fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>
fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>
Source§fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>
fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>
Source§fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>
fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>
Source§fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>
fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>
Source§fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>
fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>
Source§fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>
fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>
Source§fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>
fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>
Source§fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>
fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>
Source§fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>
fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>
Source§fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
Source§fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
Source§fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
Source§fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
Source§fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>
fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>
Source§fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>
fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>
Source§fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>
fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>
Source§fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>
fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>
Source§fn bold(&self) -> BoldDisplay<'_, Self>
fn bold(&self) -> BoldDisplay<'_, Self>
Source§fn dimmed(&self) -> DimDisplay<'_, Self>
fn dimmed(&self) -> DimDisplay<'_, Self>
Source§fn italic(&self) -> ItalicDisplay<'_, Self>
fn italic(&self) -> ItalicDisplay<'_, Self>
Source§fn underline(&self) -> UnderlineDisplay<'_, Self>
fn underline(&self) -> UnderlineDisplay<'_, Self>
Source§fn blink(&self) -> BlinkDisplay<'_, Self>
fn blink(&self) -> BlinkDisplay<'_, Self>
Source§fn blink_fast(&self) -> BlinkFastDisplay<'_, Self>
fn blink_fast(&self) -> BlinkFastDisplay<'_, Self>
Source§fn reversed(&self) -> ReversedDisplay<'_, Self>
fn reversed(&self) -> ReversedDisplay<'_, Self>
Source§fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>
fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>
Source§fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
OwoColorize::fg or
a color-specific method, such as OwoColorize::green, Read moreSource§fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
OwoColorize::bg or
a color-specific method, such as OwoColorize::on_yellow, Read more