use std::any::Any;
#[cfg(feature = "bytes")]
use bytes::Bytes;
use super::*;
#[cfg(feature = "bytes")]
use crate::chars::Chars;
pub trait ProtobufValue: Any + 'static {
fn as_ref(&self) -> ReflectValueRef;
fn as_any(&self) -> &dyn Any {
unimplemented!()
}
fn is_non_zero(&self) -> bool {
self.as_ref().is_non_zero()
}
fn as_ref_copy(&self) -> ReflectValueRef<'static>
{
match self.as_ref() {
ReflectValueRef::Bool(v) => ReflectValueRef::Bool(v),
ReflectValueRef::U32(v) => ReflectValueRef::U32(v),
ReflectValueRef::U64(v) => ReflectValueRef::U64(v),
ReflectValueRef::I32(v) => ReflectValueRef::I32(v),
ReflectValueRef::I64(v) => ReflectValueRef::I64(v),
ReflectValueRef::F32(v) => ReflectValueRef::F32(v),
ReflectValueRef::F64(v) => ReflectValueRef::F64(v),
ReflectValueRef::Enum(v) => ReflectValueRef::Enum(v),
ReflectValueRef::String(..)
| ReflectValueRef::Bytes(..)
| ReflectValueRef::Message(..) => unreachable!(),
}
}
}
impl ProtobufValue for u32 {
fn as_ref(&self) -> ReflectValueRef {
ReflectValueRef::U32(*self)
}
}
impl ProtobufValue for u64 {
fn as_ref(&self) -> ReflectValueRef {
ReflectValueRef::U64(*self)
}
}
impl ProtobufValue for i32 {
fn as_ref(&self) -> ReflectValueRef {
ReflectValueRef::I32(*self)
}
}
impl ProtobufValue for i64 {
fn as_ref(&self) -> ReflectValueRef {
ReflectValueRef::I64(*self)
}
}
impl ProtobufValue for f32 {
fn as_ref(&self) -> ReflectValueRef {
ReflectValueRef::F32(*self)
}
}
impl ProtobufValue for f64 {
fn as_ref(&self) -> ReflectValueRef {
ReflectValueRef::F64(*self)
}
}
impl ProtobufValue for bool {
fn as_ref(&self) -> ReflectValueRef {
ReflectValueRef::Bool(*self)
}
}
impl ProtobufValue for String {
fn as_ref(&self) -> ReflectValueRef {
ReflectValueRef::String(*&self)
}
}
impl ProtobufValue for str {
fn as_ref(&self) -> ReflectValueRef {
ReflectValueRef::String(self)
}
}
impl ProtobufValue for Vec<u8> {
fn as_ref(&self) -> ReflectValueRef {
ReflectValueRef::Bytes(*&self)
}
}
#[cfg(feature = "bytes")]
impl ProtobufValue for Bytes {
fn as_ref(&self) -> ReflectValueRef {
ReflectValueRef::Bytes(&*self)
}
}
#[cfg(feature = "bytes")]
impl ProtobufValue for Chars {
fn as_ref(&self) -> ReflectValueRef {
ReflectValueRef::String(&*self)
}
}
#[derive(Debug)]
pub enum ReflectValueRef<'a> {
U32(u32),
U64(u64),
I32(i32),
I64(i64),
F32(f32),
F64(f64),
Bool(bool),
String(&'a str),
Bytes(&'a [u8]),
Enum(&'static EnumValueDescriptor),
Message(&'a dyn Message),
}
impl<'a> ReflectValueRef<'a> {
#[doc(hidden)]
pub fn is_non_zero(&self) -> bool {
match *self {
ReflectValueRef::U32(v) => v != 0,
ReflectValueRef::U64(v) => v != 0,
ReflectValueRef::I32(v) => v != 0,
ReflectValueRef::I64(v) => v != 0,
ReflectValueRef::F32(v) => v != 0.,
ReflectValueRef::F64(v) => v != 0.,
ReflectValueRef::Bool(v) => v,
ReflectValueRef::String(v) => !v.is_empty(),
ReflectValueRef::Bytes(v) => !v.is_empty(),
ReflectValueRef::Enum(v) => v.value() != 0,
ReflectValueRef::Message(_) => true,
}
}
}