pub struct RecursivePathSource<'gctx> {
source_id: SourceId,
path: PathBuf,
loaded: bool,
packages: HashMap<PackageId, Vec<Package>>,
warned_duplicate: HashSet<PackageId>,
gctx: &'gctx GlobalContext,
}
Expand description
A source that represents one or multiple packages gathered from a given root path on the filesystem.
Fields§
§source_id: SourceId
The unique identifier of this source.
path: PathBuf
The root path of this source.
loaded: bool
Whether this source has loaded all package information it may contain.
packages: HashMap<PackageId, Vec<Package>>
Packages that this sources has discovered.
Tracking all packages for a given ID to warn on-demand for unused packages
warned_duplicate: HashSet<PackageId>
Avoid redundant unused package warnings
gctx: &'gctx GlobalContext
Implementations§
Source§impl<'gctx> RecursivePathSource<'gctx>
impl<'gctx> RecursivePathSource<'gctx>
Sourcepub fn new(root: &Path, source_id: SourceId, gctx: &'gctx GlobalContext) -> Self
pub fn new(root: &Path, source_id: SourceId, gctx: &'gctx GlobalContext) -> Self
Creates a new source which is walked recursively to discover packages.
This is similar to the PathSource::new
method except that instead
of requiring a valid package to be present at root
the folder is
walked entirely to crawl for packages.
Note that this should be used with care and likely shouldn’t be chosen by default!
Sourcepub fn read_packages(&mut self) -> CargoResult<Vec<Package>>
pub fn read_packages(&mut self) -> CargoResult<Vec<Package>>
Returns the packages discovered by this source. It may walk the filesystem if package information haven’t yet loaded.
Sourcepub fn list_files(&self, pkg: &Package) -> CargoResult<Vec<PathBuf>>
pub fn list_files(&self, pkg: &Package) -> CargoResult<Vec<PathBuf>>
List all files relevant to building this package inside this source.
This function will use the appropriate methods to determine the
set of files underneath this source’s directory which are relevant for
building pkg
.
The basic assumption of this method is that all files in the directory
are relevant for building this package, but it also contains logic to
use other methods like .gitignore
, package.include
, or
package.exclude
to filter the list of files.
Sourcefn last_modified_file(&self, pkg: &Package) -> CargoResult<(FileTime, PathBuf)>
fn last_modified_file(&self, pkg: &Package) -> CargoResult<(FileTime, PathBuf)>
Gets the last modified file in a package.
Sourcepub fn load(&mut self) -> CargoResult<()>
pub fn load(&mut self) -> CargoResult<()>
Discovers packages inside this source if it hasn’t yet done.
Trait Implementations§
Source§impl<'gctx> Debug for RecursivePathSource<'gctx>
impl<'gctx> Debug for RecursivePathSource<'gctx>
Source§impl<'gctx> Source for RecursivePathSource<'gctx>
impl<'gctx> Source for RecursivePathSource<'gctx>
Source§fn query(
&mut self,
dep: &Dependency,
kind: QueryKind,
f: &mut dyn FnMut(IndexSummary),
) -> Poll<CargoResult<()>>
fn query( &mut self, dep: &Dependency, kind: QueryKind, f: &mut dyn FnMut(IndexSummary), ) -> Poll<CargoResult<()>>
Source§fn supports_checksums(&self) -> bool
fn supports_checksums(&self) -> bool
IndexSummary
items with
checksums listed.Source§fn requires_precise(&self) -> bool
fn requires_precise(&self) -> bool
IndexSummary
items with
the precise
field in the SourceId
listed.Source§fn download(&mut self, id: PackageId) -> CargoResult<MaybePackage>
fn download(&mut self, id: PackageId) -> CargoResult<MaybePackage>
Source§fn finish_download(
&mut self,
_id: PackageId,
_data: Vec<u8>,
) -> CargoResult<Package>
fn finish_download( &mut self, _id: PackageId, _data: Vec<u8>, ) -> CargoResult<Package>
.crate
file. Read moreSource§fn fingerprint(&self, pkg: &Package) -> CargoResult<String>
fn fingerprint(&self, pkg: &Package) -> CargoResult<String>
Source§fn describe(&self) -> String
fn describe(&self) -> String
Source§fn add_to_yanked_whitelist(&mut self, _pkgs: &[PackageId])
fn add_to_yanked_whitelist(&mut self, _pkgs: &[PackageId])
Source§fn is_yanked(&mut self, _pkg: PackageId) -> Poll<CargoResult<bool>>
fn is_yanked(&mut self, _pkg: PackageId) -> Poll<CargoResult<bool>>
Source§fn block_until_ready(&mut self) -> CargoResult<()>
fn block_until_ready(&mut self) -> CargoResult<()>
Source§fn invalidate_cache(&mut self)
fn invalidate_cache(&mut self)
Source§fn set_quiet(&mut self, _quiet: bool)
fn set_quiet(&mut self, _quiet: bool)
Source§fn replaced_source_id(&self) -> SourceId
fn replaced_source_id(&self) -> SourceId
SourceId
corresponding to this source.Source§fn query_vec(
&mut self,
dep: &Dependency,
kind: QueryKind,
) -> Poll<CargoResult<Vec<IndexSummary>>>
fn query_vec( &mut self, dep: &Dependency, kind: QueryKind, ) -> Poll<CargoResult<Vec<IndexSummary>>>
Source::query
as a list of IndexSummary
items
when they become available.Source§fn download_now(
self: Box<Self>,
package: PackageId,
gctx: &GlobalContext,
) -> CargoResult<Package>where
Self: Sized,
fn download_now(
self: Box<Self>,
package: PackageId,
gctx: &GlobalContext,
) -> CargoResult<Package>where
Self: Sized,
Source§fn verify(&self, _pkg: PackageId) -> CargoResult<()>
fn verify(&self, _pkg: PackageId) -> CargoResult<()>
Source§fn is_replaced(&self) -> bool
fn is_replaced(&self) -> bool
Auto Trait Implementations§
impl<'gctx> Freeze for RecursivePathSource<'gctx>
impl<'gctx> !RefUnwindSafe for RecursivePathSource<'gctx>
impl<'gctx> !Send for RecursivePathSource<'gctx>
impl<'gctx> !Sync for RecursivePathSource<'gctx>
impl<'gctx> Unpin for RecursivePathSource<'gctx>
impl<'gctx> !UnwindSafe for RecursivePathSource<'gctx>
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
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where
S: Into<Dispatch>,
§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 144 bytes