matrix_sdk_base::ruma::events::room::message

Struct ImageMessageEventContent

Source
#[non_exhaustive]
pub struct ImageMessageEventContent { pub body: String, pub formatted: Option<FormattedBody>, pub filename: Option<String>, pub source: MediaSource, pub info: Option<Box<ImageInfo>>, }
Expand description

The payload for an image message.

Fields (Non-exhaustive)§

This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.
§body: String

A textual representation of the image.

If the filename field is not set or has the same value, this is the filename of the uploaded file. Otherwise, this should be interpreted as a user-written media caption.

§formatted: Option<FormattedBody>

Formatted form of the message body.

This should only be set if the body represents a caption.

§filename: Option<String>

The original filename of the uploaded file as deserialized from the event.

It is recommended to use the filename method to get the filename which automatically falls back to the body field when the filename field is not set.

§source: MediaSource

The source of the image.

§info: Option<Box<ImageInfo>>

Metadata about the image referred to in source.

Implementations§

Source§

impl ImageMessageEventContent

Source

pub fn new(body: String, source: MediaSource) -> ImageMessageEventContent

Creates a new ImageMessageEventContent with the given body and source.

Source

pub fn plain(body: String, url: OwnedMxcUri) -> ImageMessageEventContent

Creates a new non-encrypted ImageMessageEventContent with the given body and url.

Source

pub fn encrypted(body: String, file: EncryptedFile) -> ImageMessageEventContent

Creates a new encrypted ImageMessageEventContent with the given body and encrypted file.

Source

pub fn info( self, info: impl Into<Option<Box<ImageInfo>>>, ) -> ImageMessageEventContent

Creates a new ImageMessageEventContent from self with the info field set to the given value.

Since the field is public, you can also assign to it directly. This method merely acts as a shorthand for that, because it is very common to set this field.

Source

pub fn filename(&self) -> &str

Computes the filename of the image as defined by the spec.

This differs from the filename field as this method falls back to the body field when the filename field is not set.

Source

pub fn caption(&self) -> Option<&str>

Returns the caption for the image as defined by the spec.

In short, this is the body field if the filename field exists and has a different value, otherwise the media file does not have a caption.

Source

pub fn formatted_caption(&self) -> Option<&FormattedBody>

Returns the formatted caption for the image as defined by the spec.

This is the same as caption, but returns the formatted body instead of the plain body.

Trait Implementations§

Source§

impl Clone for ImageMessageEventContent

Source§

fn clone(&self) -> ImageMessageEventContent

Returns a copy 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 ImageMessageEventContent

Source§

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

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

impl<'de> Deserialize<'de> for ImageMessageEventContent

Source§

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

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

impl MediaEventContent for ImageMessageEventContent

Source§

fn source(&self) -> Option<MediaSource>

Get the source of the file for Self. Read more
Source§

fn thumbnail_source(&self) -> Option<MediaSource>

Get the source of the thumbnail for Self. Read more
Source§

impl Serialize for ImageMessageEventContent

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, dst: *mut u8)

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

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, W> HasTypeWitness<W> for T
where W: MakeTypeWitness<Arg = T>, T: ?Sized,

Source§

const WITNESS: W = W::MAKE

A constant of the type witness
Source§

impl<T> Identity for T
where T: ?Sized,

Source§

const TYPE_EQ: TypeEq<T, <T as Identity>::Type> = TypeEq::NEW

Proof that Self is the same type as Self::Type, provides methods for casting between Self and Self::Type.
Source§

type Type = T

The same type as Self, used to emulate type equality bounds (T == U) with associated type equality constraints (T: Identity<Type = U>).
Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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
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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> AsyncTraitDeps for T

Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

Source§

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

Source§

impl<T> MaybeSendSync for T

Source§

impl<T> SendOutsideWasm for T
where T: Send,

Source§

impl<T> SyncOutsideWasm for T
where T: Sync,