NavPoint

Struct NavPoint 

Source
pub struct NavPoint {
    pub label: String,
    pub content: Option<PathBuf>,
    pub children: Vec<NavPoint>,
    pub play_order: Option<usize>,
}
Expand description

Represents a navigation point in an EPUB document’s table of contents

The NavPoint structure represents a single entry in the hierarchical table of contents of an EPUB publication. Each navigation point corresponds to a section or chapter in the publication and may contain nested child navigation points to represent sub-sections.

§Builder Methods

When the builder feature is enabled, this struct provides convenient builder methods:

use lib_epub::types::NavPoint;

let nav_point = NavPoint::new("Chapter 1")
    .with_content("chapter1.xhtml")
    .append_child(
        NavPoint::new("Section 1.1")
            .with_content("section1_1.xhtml")
            .build()
    )
    .build();

Fields§

§label: String

The display label/title of this navigation point

This is the text that should be displayed to users in the table of contents.

§content: Option<PathBuf>

The content document path this navigation point references

Can be None for navigation points that no relevant information was provided in the original data.

§children: Vec<NavPoint>

Child navigation points (sub-sections)

§play_order: Option<usize>

The reading order position of this navigation point

It can be None for navigation points that no relevant information was provided in the original data.

Implementations§

Source§

impl NavPoint

Source

pub fn new(label: &str) -> Self

Creates a new navigation point with the given label

Requires the builder feature.

§Parameters
  • label - The display label for this navigation point
Source

pub fn with_content(&mut self, content: &str) -> &mut Self

Sets the content path for this navigation point

Requires the builder feature.

§Parameters
  • content - The path to the content document
Source

pub fn append_child(&mut self, child: NavPoint) -> &mut Self

Appends a child navigation point

Requires the builder feature.

§Parameters
  • child - The child navigation point to add
Source

pub fn set_children(&mut self, children: Vec<NavPoint>) -> &mut Self

Sets all child navigation points

Requires the builder feature.

§Parameters
  • children - Vector of child navigation points
Source

pub fn build(&self) -> Self

Builds the final navigation point

Requires the builder feature.

Trait Implementations§

Source§

impl Clone for NavPoint

Source§

fn clone(&self) -> NavPoint

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for NavPoint

Source§

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

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

impl Ord for NavPoint

Source§

fn cmp(&self, other: &Self) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl PartialEq for NavPoint

Source§

fn eq(&self, other: &Self) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialOrd for NavPoint

Source§

fn partial_cmp(&self, other: &Self) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl Eq for NavPoint

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<Q, K> Comparable<K> for Q
where Q: Ord + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn compare(&self, key: &K) -> Ordering

Compare self to key and return their ordering.
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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.