Skip to main content

Html5Document

Struct Html5Document 

Source
pub struct Html5Document {
    pub(super) base: HtmlBase,
}
Expand description

HTML document backed by the html5ever spec-compliant parser.

Handles HTML entities, void elements (<br>, <img>), and implicitly- closed block tags correctly per the HTML5 spec. Node offsets are synthetic (not byte positions in the source), so this type is not suitable for persisting reading positions to disk. Use it for ephemeral rendering such as the dictionary view.

For documents where offset accuracy matters (EPUB spine chapters, standalone HTML files) use HtmlDocument instead.

Fields§

§base: HtmlBase

Shared rendering state (tree, engine, page cache, stylesheets).

Implementations§

Source§

impl Html5Document

Source

pub fn new_from_memory(text: &str) -> Html5Document

Parses an in-memory HTML string using html5ever and returns a ready-to-render document.

Defaults to the dictionary viewer and user stylesheets; call set_viewer_stylesheet and set_user_stylesheet to override them.

Source

pub fn update(&mut self, text: &str)

Replaces the document content with a freshly parsed version of text and clears the page cache.

Source

pub fn set_viewer_stylesheet<P: AsRef<Path>>(&mut self, path: P)

Overrides the viewer stylesheet path. Clears the page cache.

Source

pub fn set_user_stylesheet<P: AsRef<Path>>(&mut self, path: P)

Overrides the user stylesheet path. Clears the page cache.

Trait Implementations§

Source§

impl Document for Html5Document

Source§

fn dims(&self, _index: usize) -> Option<(f32, f32)>

Returns the current page dimensions in pixels as (width, height).

Source§

fn pages_count(&self) -> usize

Returns the byte length of the source content as a proxy for page count.

Source§

fn toc(&mut self) -> Option<Vec<TocEntry>>

Always returns None; the dictionary has no table of contents.

Source§

fn chapter<'a>( &mut self, _offset: usize, _toc: &'a [TocEntry], ) -> Option<(&'a TocEntry, f32)>

Always returns None; chapter metadata is not applicable.

Source§

fn chapter_relative<'a>( &mut self, _offset: usize, _dir: CycleDir, _toc: &'a [TocEntry], ) -> Option<&'a TocEntry>

Always returns None; chapter-relative navigation is not applicable.

Source§

fn lines(&mut self, _loc: Location) -> Option<(Vec<BoundedText>, usize)>

Always returns None; line-level layout is not exposed.

Source§

fn title(&self) -> Option<String>

Always returns None; the dictionary does not expose a title.

Source§

fn author(&self) -> Option<String>

Always returns None; the dictionary does not expose an author.

Source§

fn save(&self, _path: &str) -> Result<(), Error>

No-op; Html5Document is always constructed from memory and has no file path to save to.

Source§

fn resolve_location(&mut self, loc: Location) -> Option<usize>

Source§

fn words(&mut self, loc: Location) -> Option<(Vec<BoundedText>, usize)>

Source§

fn images(&mut self, loc: Location) -> Option<(Vec<Boundary>, usize)>

Source§

fn pixmap( &mut self, loc: Location, scale: f32, samples: usize, ) -> Option<(Pixmap, usize)>

Source§

fn layout(&mut self, width: u32, height: u32, font_size: f32, dpi: u16)

Source§

fn set_text_align(&mut self, text_align: TextAlign)

Source§

fn set_font_family(&mut self, family_name: &str, search_path: &str)

Source§

fn set_margin_width(&mut self, width: i32)

Source§

fn set_line_height(&mut self, line_height: f32)

Source§

fn set_hyphen_penalty(&mut self, hyphen_penalty: i32)

Source§

fn set_stretch_tolerance(&mut self, stretch_tolerance: f32)

Source§

fn set_ignore_document_css(&mut self, ignore: bool)

Source§

fn metadata(&self, key: &str) -> Option<String>

Source§

fn is_reflowable(&self) -> bool

Source§

fn has_synthetic_page_numbers(&self) -> bool

Source§

fn preview_pixmap( &mut self, width: f32, height: f32, samples: usize, ) -> Option<Pixmap>

Source§

impl Send for Html5Document

Source§

impl Sync for Html5Document

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
§

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

§

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

Converts Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.
§

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

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

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

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

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

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

impl<T> DowncastSend for T
where T: Any + Send,

§

fn into_any_send(self: Box<T>) -> Box<dyn Any + Send>

Converts Box<Trait> (where Trait: DowncastSend) to Box<dyn Any + Send>, which can then be downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

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

§

fn into_any_sync(self: Box<T>) -> Box<dyn Any + Sync + Send>

Converts Box<Trait> (where Trait: DowncastSync) to Box<dyn Any + Send + Sync>, which can then be downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

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

Converts Arc<Trait> (where Trait: DowncastSync) to Arc<Any>, which can then be 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.

§

impl<T> Instrument for T

§

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

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

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
§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

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

Initializes a with the given initializer. Read more
§

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

Dereferences the given pointer. Read more
§

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

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

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

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

§

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
§

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.
§

impl<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

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