pub struct CachingBundle<CB: CacheBackend> { /* private fields */ }
Expand description

A caching bundle that obtains files from some a backend.

This bundle implementation is the key to Tectonic’s ability to download TeX support files on the fly. The cache backend is generally expected to be some kind of network-based resource, and the caching scheme is designed so that a document build can avoid touching the network altogether if no new files need to be downloaded.

Trait Implementations§

source§

impl<CB: CacheBackend> Bundle for CachingBundle<CB>

source§

fn get_digest(&mut self, _status: &mut dyn StatusBackend) -> Result<DigestData>

Get a cryptographic digest summarizing this bundle’s contents. Read more
source§

fn all_files(&mut self, status: &mut dyn StatusBackend) -> Result<Vec<String>>

Enumerate the files in this bundle. Read more
source§

impl<CB: Debug + CacheBackend> Debug for CachingBundle<CB>where CB::FileInfo: Debug,

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<CB: CacheBackend> IoProvider for CachingBundle<CB>

source§

fn input_open_name( &mut self, name: &str, status: &mut dyn StatusBackend ) -> OpenResult<InputHandle>

Open the named file for input.
source§

fn output_open_name(&mut self, _name: &str) -> OpenResult<OutputHandle>

Open the named file for output.
source§

fn output_open_stdout(&mut self) -> OpenResult<OutputHandle>

Open the standard output stream.
source§

fn input_open_name_with_abspath( &mut self, name: &str, status: &mut dyn StatusBackend ) -> OpenResult<(InputHandle, Option<PathBuf>)>

Open the named file for input and return filesystem path information. Read more
source§

fn input_open_primary( &mut self, _status: &mut dyn StatusBackend ) -> OpenResult<InputHandle>

Open the “primary” input file, which in the context of TeX is the main input that it’s given. When the build is being done using the filesystem and the input is a file on the filesystem, this function isn’t necesssarily that important, but those conditions don’t always hold.
source§

fn input_open_primary_with_abspath( &mut self, status: &mut dyn StatusBackend ) -> OpenResult<(InputHandle, Option<PathBuf>)>

Open the primary input and return filesystem path information. Read more
source§

fn input_open_format( &mut self, name: &str, status: &mut dyn StatusBackend ) -> OpenResult<InputHandle>

Open a format file with the specified name. Format files have a specialized entry point because IOProviders may wish to handle them specially: namely, to munge the filename to one that includes the current version of the Tectonic engine, since the format contents depend sensitively on the engine internals.
source§

fn write_format( &mut self, _name: &str, _data: &[u8], _status: &mut dyn StatusBackend ) -> Result<(), Error>

Save an a format dump in some way that this provider may be able to recover in the future. This awkward interface is needed to write formats with their special munged file names.

Auto Trait Implementations§

§

impl<CB> RefUnwindSafe for CachingBundle<CB>where CB: RefUnwindSafe, <CB as CacheBackend>::FileInfo: RefUnwindSafe,

§

impl<CB> Send for CachingBundle<CB>where CB: Send, <CB as CacheBackend>::FileInfo: Send,

§

impl<CB> Sync for CachingBundle<CB>where CB: Sync, <CB as CacheBackend>::FileInfo: Sync,

§

impl<CB> Unpin for CachingBundle<CB>where CB: Unpin, <CB as CacheBackend>::FileInfo: Unpin,

§

impl<CB> UnwindSafe for CachingBundle<CB>where CB: UnwindSafe, <CB as CacheBackend>::FileInfo: UnwindSafe,

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> AsIoProviderMut for Twhere T: IoProvider,

source§

fn as_ioprovider_mut(&mut self) -> &mut dyn IoProvider

Represent this value as an IoProvider trait object.
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere 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 Twhere 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> Same<T> for T

§

type Output = T

Should always be Self
source§

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

§

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 Twhere U: TryFrom<T>,

§

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