File: long_enum_generated.rs

package info (click to toggle)
golang-github-google-flatbuffers 24.3.25-2
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 17,364 kB
  • sloc: cpp: 49,726; python: 6,901; cs: 5,566; java: 4,370; ansic: 2,512; php: 1,460; javascript: 1,053; xml: 1,016; sh: 870; makefile: 13
file content (85 lines) | stat: -rw-r--r-- 2,528 bytes parent folder | download | duplicates (10)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
// automatically generated by the FlatBuffers compiler, do not modify
// @generated
extern crate alloc;
extern crate flatbuffers;
use alloc::boxed::Box;
use alloc::string::{String, ToString};
use alloc::vec::Vec;
use core::mem;
use core::cmp::Ordering;
extern crate serde;
use self::serde::ser::{Serialize, Serializer, SerializeStruct};
use self::flatbuffers::{EndianScalar, Follow};
use super::*;
#[allow(non_upper_case_globals)]
mod bitflags_long_enum {
  flatbuffers::bitflags::bitflags! {
    #[derive(Default)]
    pub struct LongEnum: u64 {
      const LongOne = 2;
      const LongTwo = 4;
      const LongBig = 1099511627776;
    }
  }
}
pub use self::bitflags_long_enum::LongEnum;

impl Serialize for LongEnum {
  fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
  where
    S: Serializer,
  {
    serializer.serialize_u32(self.bits() as u32)
  }
}

impl<'a> flatbuffers::Follow<'a> for LongEnum {
  type Inner = Self;
  #[inline]
  unsafe fn follow(buf: &'a [u8], loc: usize) -> Self::Inner {
    let b = flatbuffers::read_scalar_at::<u64>(buf, loc);
    // Safety:
    // This is safe because we know bitflags is implemented with a repr transparent uint of the correct size.
    // from_bits_unchecked will be replaced by an equivalent but safe from_bits_retain in bitflags 2.0
    // https://github.com/bitflags/bitflags/issues/262
    Self::from_bits_unchecked(b)
  }
}

impl flatbuffers::Push for LongEnum {
    type Output = LongEnum;
    #[inline]
    unsafe fn push(&self, dst: &mut [u8], _written_len: usize) {
        flatbuffers::emplace_scalar::<u64>(dst, self.bits());
    }
}

impl flatbuffers::EndianScalar for LongEnum {
  type Scalar = u64;
  #[inline]
  fn to_little_endian(self) -> u64 {
    self.bits().to_le()
  }
  #[inline]
  #[allow(clippy::wrong_self_convention)]
  fn from_little_endian(v: u64) -> Self {
    let b = u64::from_le(v);
    // Safety:
    // This is safe because we know bitflags is implemented with a repr transparent uint of the correct size.
    // from_bits_unchecked will be replaced by an equivalent but safe from_bits_retain in bitflags 2.0
    // https://github.com/bitflags/bitflags/issues/262
    unsafe { Self::from_bits_unchecked(b) }
  }
}

impl<'a> flatbuffers::Verifiable for LongEnum {
  #[inline]
  fn run_verifier(
    v: &mut flatbuffers::Verifier, pos: usize
  ) -> Result<(), flatbuffers::InvalidFlatbuffer> {
    use self::flatbuffers::Verifiable;
    u64::run_verifier(v, pos)
  }
}

impl flatbuffers::SimpleToVerifyInSlice for LongEnum {}