pub struct ElementDefinitionSlicing {
pub id: Option<String>,
pub extension: Option<Vec<Box<Extension>>>,
pub discriminator: Option<Vec<ElementDefinitionSlicingDiscriminator>>,
pub description: Option<Box<FHIRString>>,
pub ordered: Option<Box<FHIRBoolean>>,
pub rules: Box<ResourceSlicingRules>,
}Expand description
Indicates that the element is sliced into a set of alternative definitions (i.e. in a structure definition, there are multiple different constraints on a single element in the base resource). Slicing can be used in any resource that has cardinality ..* on the base resource, or any resource with a choice of types. The set of slices is any elements that come after this in the element sequence that have the same path, until a shorter path occurs (the shorter path terminates the set).
Fields§
§id: Option<String>Unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.
extension: Option<Vec<Box<Extension>>>May be used to represent additional information that is not part of the basic definition of the element. To make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer can define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.
discriminator: Option<Vec<ElementDefinitionSlicingDiscriminator>>Designates which child elements are used to discriminate between the slices when processing an instance. If one or more discriminators are provided, the value of the child elements in the instance data SHALL completely distinguish which slice the element in the resource matches based on the allowed values for those elements in each of the slices.
description: Option<Box<FHIRString>>A human-readable text description of how the slicing works. If there is no discriminator, this is required to be present to provide whatever information is possible about how the slices can be differentiated.
ordered: Option<Box<FHIRBoolean>>If the matching elements have to occur in the same order as defined in the profile.
rules: Box<ResourceSlicingRules>Whether additional slices are allowed or not. When the slices are ordered, profile authors can also say that additional slices are only allowed at the end.
Trait Implementations§
Source§impl Clone for ElementDefinitionSlicing
impl Clone for ElementDefinitionSlicing
Source§fn clone(&self) -> ElementDefinitionSlicing
fn clone(&self) -> ElementDefinitionSlicing
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for ElementDefinitionSlicing
impl Debug for ElementDefinitionSlicing
Source§impl Default for ElementDefinitionSlicing
impl Default for ElementDefinitionSlicing
Source§fn default() -> ElementDefinitionSlicing
fn default() -> ElementDefinitionSlicing
Source§impl FHIRJSONDeserializer for ElementDefinitionSlicing
impl FHIRJSONDeserializer for ElementDefinitionSlicing
fn from_json_str(s: &str) -> Result<Self, DeserializeError>
fn from_serde_value( obj: &Value, context: Context<'_>, ) -> Result<Self, DeserializeError>
Source§impl FHIRJSONSerializer for ElementDefinitionSlicing
impl FHIRJSONSerializer for ElementDefinitionSlicing
fn serialize_value( &self, writer: &mut dyn Write, ) -> Result<bool, SerializeError>
fn serialize_extension( &self, writer: &mut dyn Write, ) -> Result<bool, SerializeError>
fn serialize_field( &self, field: &str, writer: &mut dyn Write, ) -> Result<bool, SerializeError>
fn is_fp_primitive(&self) -> bool
Source§impl MetaValue for ElementDefinitionSlicing
impl MetaValue for ElementDefinitionSlicing
fn fields(&self) -> Vec<&'static str>
fn get_field<'a>(&'a self, field: &str) -> Option<&'a dyn MetaValue>
fn get_field_mut<'a>(&'a mut self, field: &str) -> Option<&'a mut dyn MetaValue>
fn get_index_mut<'a>( &'a mut self, index: usize, ) -> Option<&'a mut dyn MetaValue>
fn get_index<'a>(&'a self, _index: usize) -> Option<&'a dyn MetaValue>
fn typename(&self) -> &'static str
fn as_any(&self) -> &dyn Any
fn flatten(&self) -> Vec<&dyn MetaValue>
Auto Trait Implementations§
impl Freeze for ElementDefinitionSlicing
impl RefUnwindSafe for ElementDefinitionSlicing
impl Send for ElementDefinitionSlicing
impl Sync for ElementDefinitionSlicing
impl Unpin for ElementDefinitionSlicing
impl UnwindSafe for ElementDefinitionSlicing
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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