Skip to main content

Scanner

Struct Scanner 

Source
pub struct Scanner { /* private fields */ }
Expand description

§Scanner: The Rock Star of our Show

BEHOLD! The Scanner itself! This is the main act. It takes the config, the ignore lists, and a path, and it puts on a spectacular show of directory traversal. It’s fast, it’s smart, and it knows all the best moves.

Implementations§

Source§

impl Scanner

Source

pub fn root(&self) -> &Path

Returns the canonicalized root path of the scanner

Source

pub fn quick_scan(&self) -> Result<(Vec<FileNode>, TreeStats)>

Quick scan for basic project analysis - lighter weight than full scan Returns only basic stats and key files for faster integration

Source

pub fn find_recent_files(&self, hours_ago: u64) -> Result<Vec<FileNode>>

Find files modified within a specific time range Useful for finding recent activity in projects

Source

pub fn find_key_files(&self) -> Result<Vec<FileNode>>

Get key project files (build configs, main files, etc.) Returns a filtered list of important files for project analysis

Source

pub fn new(root: &Path, config: ScannerConfig) -> Result<Self>

§Scanner::new - Constructor

Creates a new Scanner instance. This involves:

  1. Storing the provided config and root path.
  2. Loading and compiling .gitignore patterns if config.respect_gitignore is true.
  3. Compiling the DEFAULT_IGNORE_PATTERNS if config.use_default_ignores is true.
  4. Initializing sets of system paths and specific files to always ignore.

This setup prepares the scanner for efficient should_ignore checks during traversal.

Source

pub fn scan_stream(&self, sender: Sender<FileNode>) -> Result<TreeStats>

Stream nodes as they are discovered This version of scan is optimized for the --stream flag. It sends FileNode objects through the sender channel as soon as they are processed. This allows the formatter to start displaying output immediately, which is great for large directories. Returns the final TreeStats once the scan is complete.

Source

pub fn scan(&self) -> Result<(Vec<FileNode>, TreeStats)>

§scan - The Full Scan (Non-Streaming)

Performs a complete directory scan, collecting all FileNodes that meet the criteria (not ignored, or shown if ignored, and pass filters if any). This method first traverses the entire directory structure defined by config.max_depth, creating FileNode objects for each entry. It then performs a second pass if filters are active to ensure that directories are only included if they (or their subdirectories) contain files that match the filters. Returns a tuple: (Vec<FileNode>, TreeStats).

§scan - The “Scan-It-All-Then-Sort-It-Out” Method

This is the classic way to scan. It’s a two-act show:

  1. Act I: Walk through every single file and directory, collecting a huge list of FileNodes.
  2. Act II: If there are filters, go through that huge list and pick out only the ones that match, making sure to keep their parent directories so the tree still makes sense. It’s thorough and great for when you need the whole picture before making decisions.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
Source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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 more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> ErasedDestructor for T
where T: 'static,