"Fossies" - the Fresh Open Source Software Archive

Member "flatbuffers-23.1.21/tests/more_defaults/abc_generated.rs" (21 Jan 2023, 2725 Bytes) of package /linux/misc/flatbuffers-23.1.21.tar.gz:


As a special service "Fossies" has tried to format the requested source page into HTML format using (guessed) Rust source code syntax highlighting (style: standard) with prefixed line numbers and code folding option. Alternatively you can here view or download the uninterpreted source code file.

    1 // automatically generated by the FlatBuffers compiler, do not modify
    2 // @generated
    3 extern crate alloc;
    4 extern crate flatbuffers;
    5 use alloc::boxed::Box;
    6 use alloc::string::{String, ToString};
    7 use alloc::vec::Vec;
    8 use core::mem;
    9 use core::cmp::Ordering;
   10 use self::flatbuffers::{EndianScalar, Follow};
   11 use super::*;
   12 #[deprecated(since = "2.0.0", note = "Use associated constants instead. This will no longer be generated in 2021.")]
   13 pub const ENUM_MIN_ABC: i32 = 0;
   14 #[deprecated(since = "2.0.0", note = "Use associated constants instead. This will no longer be generated in 2021.")]
   15 pub const ENUM_MAX_ABC: i32 = 2;
   16 #[deprecated(since = "2.0.0", note = "Use associated constants instead. This will no longer be generated in 2021.")]
   17 #[allow(non_camel_case_types)]
   18 pub const ENUM_VALUES_ABC: [ABC; 3] = [
   19   ABC::A,
   20   ABC::B,
   21   ABC::C,
   22 ];
   23 
   24 #[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash, Default)]
   25 #[repr(transparent)]
   26 pub struct ABC(pub i32);
   27 #[allow(non_upper_case_globals)]
   28 impl ABC {
   29   pub const A: Self = Self(0);
   30   pub const B: Self = Self(1);
   31   pub const C: Self = Self(2);
   32 
   33   pub const ENUM_MIN: i32 = 0;
   34   pub const ENUM_MAX: i32 = 2;
   35   pub const ENUM_VALUES: &'static [Self] = &[
   36     Self::A,
   37     Self::B,
   38     Self::C,
   39   ];
   40   /// Returns the variant's name or "" if unknown.
   41   pub fn variant_name(self) -> Option<&'static str> {
   42     match self {
   43       Self::A => Some("A"),
   44       Self::B => Some("B"),
   45       Self::C => Some("C"),
   46       _ => None,
   47     }
   48   }
   49 }
   50 impl core::fmt::Debug for ABC {
   51   fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
   52     if let Some(name) = self.variant_name() {
   53       f.write_str(name)
   54     } else {
   55       f.write_fmt(format_args!("<UNKNOWN {:?}>", self.0))
   56     }
   57   }
   58 }
   59 impl<'a> flatbuffers::Follow<'a> for ABC {
   60   type Inner = Self;
   61   #[inline]
   62   unsafe fn follow(buf: &'a [u8], loc: usize) -> Self::Inner {
   63     let b = flatbuffers::read_scalar_at::<i32>(buf, loc);
   64     Self(b)
   65   }
   66 }
   67 
   68 impl flatbuffers::Push for ABC {
   69     type Output = ABC;
   70     #[inline]
   71     unsafe fn push(&self, dst: &mut [u8], _written_len: usize) {
   72         flatbuffers::emplace_scalar::<i32>(dst, self.0);
   73     }
   74 }
   75 
   76 impl flatbuffers::EndianScalar for ABC {
   77   type Scalar = i32;
   78   #[inline]
   79   fn to_little_endian(self) -> i32 {
   80     self.0.to_le()
   81   }
   82   #[inline]
   83   #[allow(clippy::wrong_self_convention)]
   84   fn from_little_endian(v: i32) -> Self {
   85     let b = i32::from_le(v);
   86     Self(b)
   87   }
   88 }
   89 
   90 impl<'a> flatbuffers::Verifiable for ABC {
   91   #[inline]
   92   fn run_verifier(
   93     v: &mut flatbuffers::Verifier, pos: usize
   94   ) -> Result<(), flatbuffers::InvalidFlatbuffer> {
   95     use self::flatbuffers::Verifiable;
   96     i32::run_verifier(v, pos)
   97   }
   98 }
   99 
  100 impl flatbuffers::SimpleToVerifyInSlice for ABC {}