Skip to main content

IsrCache

Struct IsrCache 

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

A cache for OS kernel profiles.

Manages the download and extraction of necessary debug symbols.

Implementations§

Source§

impl IsrCache

Source

pub fn new(output_directory: impl Into<PathBuf>) -> Result<Self, Error>

Creates a new IsrCache instance, initializing it with the provided directory. If the directory doesn’t exist, it attempts to create it.

Source

pub fn with_progress( self, f: impl Fn(ProgressEvent<'_>) + Send + Sync + 'static, ) -> Self

Sets a progress callback for download and extraction operations.

Source

pub fn with_offline(self, offline: bool) -> Self

Enables or disables offline mode.

In offline mode the cache only uses already-downloaded artifacts and never reaches out to the network.

Source

pub fn with_ubuntu_downloader( self, ubuntu_downloader: UbuntuSymbolDownloader, ) -> Self

Overrides the default UbuntuSymbolDownloader.

Source

pub fn ubuntu_downloader(&self) -> &UbuntuSymbolDownloader

Returns the UbuntuSymbolDownloader, lazily initializing it.

Source

pub fn with_symbol_downloader(self, symbol_downloader: SymbolDownloader) -> Self

Overrides the default SymbolDownloader.

Source

pub fn symbol_downloader(&self) -> &SymbolDownloader

Returns the SymbolDownloader, lazily initializing it.

Source

pub fn entry_from_linux_banner( &self, linux_banner: &str, ) -> Result<Entry, Error>

Creates or retrieves a cached profile based on a Linux kernel banner.

Parses the banner to determine the kernel version and downloads the necessary debug symbols and system map if not present in the cache. Generates and stores the profile, returning its path.

Source

pub fn download_from_ubuntu_version_signature( &self, version_signature: UbuntuVersionSignature, ) -> Result<UbuntuSymbolPaths, Error>

Downloads and extracts the kernel image, debug symbols, and System.map for the given Ubuntu version signature.

Returns an UbuntuSymbolPaths with the output directory and the per-artifact paths.

Source

pub fn entry_from_codeview(&self, codeview: CodeView) -> Result<Entry, Error>

Creates or retrieves a cached profile from a CodeView debug information structure.

If a profile for the given CodeView information already exists in the cache, its path is returned. Otherwise, the necessary PDB file is downloaded, the profile is generated and stored in the cache, and its path is returned.

Source

pub fn entry_from_pe(&self, path: impl AsRef<Path>) -> Result<Entry, Error>

Creates or retrieves a cached profile from a PE file.

Extracts the CodeView debug information from the PE file and delegates to entry_from_codeview.

Source

pub fn download_from_codeview( &self, codeview: CodeView, ) -> Result<PathBuf, Error>

Downloads or retrieves a cached PDB from its CodeView record.

Source

pub fn download_from_image_signature( &self, image_signature: ImageSignature, ) -> Result<PathBuf, Error>

Downloads or retrieves a cached PE binary from its ImageSignature.

PE binaries are cached at: <cache>/windows/<name>/<timestamp><size_of_image>/<name>

Returns the path to the cached binary.

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> ArchivePointee for T

Source§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
Source§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
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> 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> LayoutRaw for T

Source§

fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>

Returns the layout of the type.
Source§

impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
where T: SharedNiching<N1, N2>, N1: Niching<T>, N2: Niching<T>,

Source§

unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool

Returns whether the given value has been niched. Read more
Source§

fn resolve_niched(out: Place<NichedOption<T, N1>>)

Writes data to out indicating that a T is niched.
Source§

impl<T> Pointee for T

Source§

type Metadata = ()

The metadata type for pointers and references to this type.
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, 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<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