Struct Subcomponent

Source
pub struct Subcomponent<'m> {
    pub value: &'m str,
    pub range: Range<usize>,
}
Expand description

A subcomponent is the smallest unit of data in an HL7 message. It is a string that may contain escape sequences to encode the separators. It is the only type that does not have a separator character. It is always contained within a component.

For parsing performance reasons, the subcomponent does not decode the escape sequences when it is parsed. Instead, the escape sequences are decoded when the subcomponent is displayed. This allows the subcomponent to be parsed without allocating a new string for the decoded value.

Fields§

§value: &'m str

The raw value of the subcomponent, including escape sequences

§range: Range<usize>

The range of the subcomponent in the original message

Implementations§

Source§

impl<'m> Subcomponent<'m>

Source

pub fn display(&'m self, separators: &'m Separators) -> SubcomponentDisplay<'m>

Display the subcomponent value, using the separators to decode escape sequences by default. Note: if you want to display the raw value without decoding escape sequences, use the # flag, e.g. format!("{:#}", subcomponent.display(separators))

§Examples
use hl7_parser::message::{Separators, Subcomponent};
let separators = Separators::default();

let subcomponent = Subcomponent {
    value: r"foo\F\bar",
    range: 0..1, // ignore
};

assert_eq!(format!("{}", subcomponent.display(&separators)), "foo|bar");
assert_eq!(format!("{:#}", subcomponent.display(&separators)), r"foo\F\bar");
Source

pub fn raw_value(&self) -> &'m str

Get the raw value of the subcomponent. This is the value as it appears in the message, without any decoding of escape sequences.

Trait Implementations§

Source§

impl<'m> Clone for Subcomponent<'m>

Source§

fn clone(&self) -> Subcomponent<'m>

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<'m> Debug for Subcomponent<'m>

Source§

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

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

impl<'m> PartialEq for Subcomponent<'m>

Source§

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

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<'m> Eq for Subcomponent<'m>

Source§

impl<'m> StructuralPartialEq for Subcomponent<'m>

Auto Trait Implementations§

§

impl<'m> Freeze for Subcomponent<'m>

§

impl<'m> RefUnwindSafe for Subcomponent<'m>

§

impl<'m> Send for Subcomponent<'m>

§

impl<'m> Sync for Subcomponent<'m>

§

impl<'m> Unpin for Subcomponent<'m>

§

impl<'m> UnwindSafe for Subcomponent<'m>

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