Struct MessageBuilder

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

A builder for constructing HL7 messages.

Implementations§

Source§

impl MessageBuilder

Source

pub fn new(separators: Separators) -> Self

Create a new message builder with the given separators. No segments are added.

Source

pub fn push_segment(&mut self, segment: SegmentBuilder)

Append a segment to the message. Segments will be output in the order they are added.

Source

pub fn separators(&self) -> &Separators

Get the separators used by the message.

Source

pub fn segments(&self) -> &[SegmentBuilder]

Get the segments in the message.

Source

pub fn segments_mut(&mut self) -> &mut Vec<SegmentBuilder>

Get a mutable reference to the segments in the message.

Source

pub fn segment(&self, index: usize) -> Option<&SegmentBuilder>

Get a segment by index (0-based).

Source

pub fn segment_mut(&mut self, index: usize) -> Option<&mut SegmentBuilder>

Get a mutable reference to a segment by index (0-based).

Source

pub fn remove_segment(&mut self, index: usize) -> Option<SegmentBuilder>

Remove a segment by index (0-based).

Source

pub fn segment_named<S: AsRef<str>>(&self, name: S) -> Option<&SegmentBuilder>

Get the first segment with the given name.

Source

pub fn segment_named_mut<S: AsRef<str>>( &mut self, name: S, ) -> Option<&mut SegmentBuilder>

Get a mutable reference to the first segment with the given name.

Source

pub fn remove_segment_named<S: AsRef<str>>( &mut self, name: S, ) -> Option<SegmentBuilder>

Remove the first segment with the given name.

Source

pub fn segment_n<S: AsRef<str>>( &self, name: S, n: usize, ) -> Option<&SegmentBuilder>

Get the nth segment with the given name (1-based).

Source

pub fn segment_n_mut<S: AsRef<str>>( &mut self, name: S, n: usize, ) -> Option<&mut SegmentBuilder>

Get a mutable reference to the nth segment with the given name (1-based).

Source

pub fn remove_segment_n<S: AsRef<str>>( &mut self, name: S, n: usize, ) -> Option<SegmentBuilder>

Remove the nth segment with the given name (1-based).

Source

pub fn is_empty(&self) -> bool

Check if the message is empty (i.e. has no segments).

Source

pub fn clear(&mut self)

Clear all segments from the message.

Source

pub fn set_separators(&mut self, separators: Separators)

Set the separators used by the message.

Source

pub fn with_segment(self, segment: SegmentBuilder) -> Self

Add a segment to the message.

Source

pub fn render_with_newlines(&self) -> MessageBuilderDisplay<'_>

Display the message with the default line endings for the current platform.

On Windows, this will use \r\n as the line ending. On other platforms, it will use \n.

Source

pub fn render_with_segment_separators<'a>( &'a self, line_endings: &'a str, ) -> MessageBuilderDisplay<'a>

Display the message with the given line endings.

Trait Implementations§

Source§

impl Clone for MessageBuilder

Source§

fn clone(&self) -> MessageBuilder

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 MessageBuilder

Source§

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

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

impl Default for MessageBuilder

Source§

fn default() -> MessageBuilder

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

impl<'de> Deserialize<'de> for MessageBuilder

Source§

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

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

impl Display for MessageBuilder

Render the message using the proper \r segment separators.

Source§

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

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

impl<'m> From<&'m Message<'m>> for MessageBuilder

Convert a message into a message builder.

Source§

fn from(message: &'m Message<'_>) -> Self

Converts to this type from the input type.
Source§

impl PartialEq for MessageBuilder

Source§

fn eq(&self, other: &MessageBuilder) -> 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 Serialize for MessageBuilder

Source§

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

Serialize this value into the given Serde serializer. Read more
Source§

impl Eq for MessageBuilder

Source§

impl StructuralPartialEq for MessageBuilder

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> 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> 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> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. 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> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,