Enum DeviceType
pub enum DeviceType {
Desktop,
Mobile,
Tablet,
VR,
TV,
Unknown,
}
Expand description
Enumeration for the different types of device.
Firefox Accounts and the broader Sync universe separates devices into broad categories for various purposes, such as distinguishing a desktop PC from a mobile phone.
A special variant in this enum, DeviceType::Unknown
is used to capture
the string values we don’t recognise. It also has a custom serde serializer and deserializer
which implements the following semantics:
- deserializing a
DeviceType
which uses a string value we don’t recognise or null will returnDeviceType::Unknown
rather than returning an error. - serializing
DeviceType::Unknown
will serializenull
.
This has a few important implications:
- In general,
Option<DeviceType>
should be avoided, and a plainDeviceType
used instead, because in that case,None
would be semantically identical toDeviceType::Unknown
and as mentioned above,null
already deserializes asDeviceType::Unknown
. - Any unknown device types can not be round-tripped via this enum - eg, if you deserialize
a struct holding a
DeviceType
string value we don’t recognize, then re-serialize it, the original string value is lost. We don’t consider this a problem because in practice, we only upload records with this device’s type, not the type of other devices, and it’s reasonable to assume that this module knows about all valid device types for the device type it is deployed on.
Variants§
Trait Implementations§
§impl Clone for DeviceType
impl Clone for DeviceType
§fn clone(&self) -> DeviceType
fn clone(&self) -> DeviceType
Returns a copy of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read more§impl<UT> ConvertError<UT> for DeviceType
impl<UT> ConvertError<UT> for DeviceType
fn try_convert_unexpected_callback_error( e: UnexpectedUniFFICallbackError, ) -> Result<DeviceType, Error>
§impl Debug for DeviceType
impl Debug for DeviceType
§impl Default for DeviceType
impl Default for DeviceType
§fn default() -> DeviceType
fn default() -> DeviceType
Returns the “default value” for a type. Read more
§impl<'de> Deserialize<'de> for DeviceType
impl<'de> Deserialize<'de> for DeviceType
§fn deserialize<D>(
deserializer: D,
) -> Result<DeviceType, <D as Deserializer<'de>>::Error>where
D: Deserializer<'de>,
fn deserialize<D>(
deserializer: D,
) -> Result<DeviceType, <D as Deserializer<'de>>::Error>where
D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
§impl<UT> FfiConverter<UT> for DeviceType
impl<UT> FfiConverter<UT> for DeviceType
§const TYPE_ID_META: MetadataBuffer = _
const TYPE_ID_META: MetadataBuffer = _
Type ID metadata, serialized into a [MetadataBuffer].
§type FfiType = RustBuffer
type FfiType = RustBuffer
The low-level type used for passing values of this type over the FFI. Read more
§fn lower(v: DeviceType) -> RustBuffer
fn lower(v: DeviceType) -> RustBuffer
Lower a rust value of the target type, into an FFI value of type Self::FfiType. Read more
§fn try_lift(buf: RustBuffer) -> Result<DeviceType, Error>
fn try_lift(buf: RustBuffer) -> Result<DeviceType, Error>
Lift a rust value of the target type, from an FFI value of type Self::FfiType. Read more
§impl Hash for DeviceType
impl Hash for DeviceType
§impl<UT> Lift<UT> for DeviceType
impl<UT> Lift<UT> for DeviceType
type FfiType = <DeviceType as FfiConverter<UT>>::FfiType
fn try_lift(v: <DeviceType as Lift<UT>>::FfiType) -> Result<DeviceType, Error>
fn try_read(buf: &mut &[u8]) -> Result<DeviceType, Error>
§fn try_lift_from_rust_buffer(v: RustBuffer) -> Result<Self, Error>
fn try_lift_from_rust_buffer(v: RustBuffer) -> Result<Self, Error>
Convenience method
§impl<UT> LiftRef<UT> for DeviceType
impl<UT> LiftRef<UT> for DeviceType
type LiftType = DeviceType
§impl<UT> LiftReturn<UT> for DeviceType
impl<UT> LiftReturn<UT> for DeviceType
§type ReturnType = <DeviceType as Lift<UT>>::FfiType
type ReturnType = <DeviceType as Lift<UT>>::FfiType
FFI return type for trait interfaces
§fn try_lift_successful_return(
v: <DeviceType as LiftReturn<UT>>::ReturnType,
) -> Result<DeviceType, Error>
fn try_lift_successful_return( v: <DeviceType as LiftReturn<UT>>::ReturnType, ) -> Result<DeviceType, Error>
Lift a successfully returned value from a trait interface
§fn lift_foreign_return(
ffi_return: Self::ReturnType,
call_status: RustCallStatus,
) -> Self
fn lift_foreign_return( ffi_return: Self::ReturnType, call_status: RustCallStatus, ) -> Self
Lift a foreign returned value from a trait interface Read more
§fn lift_error(_buf: RustBuffer) -> Self
fn lift_error(_buf: RustBuffer) -> Self
Lift a Rust value for a callback interface method error result Read more
§fn handle_callback_unexpected_error(e: UnexpectedUniFFICallbackError) -> Self
fn handle_callback_unexpected_error(e: UnexpectedUniFFICallbackError) -> Self
Lift a Rust value for an unexpected callback interface error Read more
§impl<UT> Lower<UT> for DeviceType
impl<UT> Lower<UT> for DeviceType
type FfiType = <DeviceType as FfiConverter<UT>>::FfiType
fn lower(obj: DeviceType) -> <DeviceType as Lower<UT>>::FfiType
fn write(obj: DeviceType, buf: &mut Vec<u8>)
§fn lower_into_rust_buffer(obj: Self) -> RustBuffer
fn lower_into_rust_buffer(obj: Self) -> RustBuffer
Convenience method
§impl<UT> LowerError<UT> for DeviceType
impl<UT> LowerError<UT> for DeviceType
§fn lower_error(obj: DeviceType) -> RustBuffer
fn lower_error(obj: DeviceType) -> RustBuffer
Lower this value for scaffolding function return Read more
§impl<UT> LowerReturn<UT> for DeviceType
impl<UT> LowerReturn<UT> for DeviceType
§type ReturnType = <DeviceType as Lower<UT>>::FfiType
type ReturnType = <DeviceType as Lower<UT>>::FfiType
The type that should be returned by scaffolding functions for this type. Read more
§fn lower_return(
v: DeviceType,
) -> Result<<DeviceType as LowerReturn<UT>>::ReturnType, RustCallError>
fn lower_return( v: DeviceType, ) -> Result<<DeviceType as LowerReturn<UT>>::ReturnType, RustCallError>
Lower the return value from an scaffolding call Read more
§fn handle_failed_lift(
error: LiftArgsError,
) -> Result<Self::ReturnType, RustCallError>
fn handle_failed_lift( error: LiftArgsError, ) -> Result<Self::ReturnType, RustCallError>
Lower the return value for failed argument lifts Read more
§impl PartialEq for DeviceType
impl PartialEq for DeviceType
§impl Serialize for DeviceType
impl Serialize for DeviceType
§fn serialize<S>(
&self,
s: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
S: Serializer,
fn serialize<S>(
&self,
s: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
S: Serializer,
Serialize this value into the given Serde serializer. Read more
§impl<UT> TypeId<UT> for DeviceType
impl<UT> TypeId<UT> for DeviceType
const TYPE_ID_META: MetadataBuffer = _
impl Copy for DeviceType
impl Eq for DeviceType
impl StructuralPartialEq for DeviceType
Auto Trait Implementations§
impl Freeze for DeviceType
impl RefUnwindSafe for DeviceType
impl Send for DeviceType
impl Sync for DeviceType
impl Unpin for DeviceType
impl UnwindSafe for DeviceType
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
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Checks if this value is equivalent to the given key. Read more
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.§impl<T, UT> HandleAlloc<UT> for T
impl<T, UT> HandleAlloc<UT> for T
§fn new_handle(value: Arc<T>) -> Handle
fn new_handle(value: Arc<T>) -> Handle
Create a new handle for an Arc value Read more
§unsafe fn clone_handle(handle: Handle) -> Handle
unsafe fn clone_handle(handle: Handle) -> Handle
Clone a handle Read more
§unsafe fn consume_handle(handle: Handle) -> Arc<T>
unsafe fn consume_handle(handle: Handle) -> Arc<T>
Consume a handle, getting back the initial
Arc<>
Read more