Skip to main content

Citation

Struct Citation 

Source
pub struct Citation {
    pub id: Option<String>,
    pub note_number: Option<u32>,
    pub mode: CitationMode,
    pub position: Option<Position>,
    pub suppress_author: bool,
    pub prefix: Option<String>,
    pub suffix: Option<String>,
    pub items: Vec<CitationItem>,
    pub grouped: bool,
    pub sentence_start: bool,
}
Expand description

A citation containing one or more references.

Fields§

§id: Option<String>

The citation ID (optional, for tracking).

§note_number: Option<u32>

Note number for footnote/endnote styles. Assigned by the document processor, not the citation processor.

§mode: CitationMode

Citation mode: integral (narrative) vs non-integral (parenthetical). Only relevant for author-date styles.

§position: Option<Position>

Position of this citation in the document flow. Detected automatically by the processor or set explicitly by the caller.

§suppress_author: bool

Suppress the author name across all items in this citation. Used when the author is already named in the prose: “Smith argues (2020)”. Applies uniformly to all items — per-item suppression is not supported because mixed-visibility citations are typographically incoherent.

§prefix: Option<String>

Prefix text before all citation items.

§suffix: Option<String>

Suffix text after all citation items.

§items: Vec<CitationItem>

The citation items (references being cited).

§grouped: bool

If true, the entire citation is a single dynamic compound set.

The first item acts as the head and subsequent items are merged as tails in the bibliography. Ignored for non-numeric (compound-numeric) styles. Item order is preserved and sorting is suppressed when this flag is set.

§sentence_start: bool

Signal that this citation cluster opens a sentence, so its leading character should be capitalized (e.g. “see also …” → “See also …”).

The processor cannot infer sentence context from rendered text; the host (document pipeline, WASM bridge, or editor) supplies this flag explicitly — mirroring LaTeX’s capitalized cite commands (\Citet, \Parencite, \Textcite). When false (the default), no capitalization transform is applied.

Implementations§

Source§

impl Citation

Source

pub fn simple(id: &str) -> Citation

Create a simple single-item citation.

Convenience constructor for a citation with a single reference ID and default settings.

Trait Implementations§

Source§

impl Clone for Citation

Source§

fn clone(&self) -> Citation

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for Citation

Source§

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

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

impl Default for Citation

Source§

fn default() -> Citation

Returns the “default value” for a type. Read more
Source§

impl<'de> Deserialize<'de> for Citation

Source§

fn deserialize<__D>( __deserializer: __D, ) -> Result<Citation, <__D as Deserializer<'de>>::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl From<CitationOccurrence> for Citation

Source§

fn from(occ: CitationOccurrence) -> Self

Converts to this type from the input type.
Source§

impl Serialize for Citation

Source§

fn serialize<__S>( &self, __serializer: __S, ) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more

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<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

Source§

impl<T> ErasedDestructor for T
where T: 'static,

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.