// automatically generated by the FlatBuffers compiler, do not modify // @generated extern crate alloc; use super::*; pub enum TableAOffset {} #[derive(Copy, Clone, PartialEq)] pub struct TableA<'a> { pub _tab: ::flatbuffers::Table<'a>, } impl<'a> ::flatbuffers::Follow<'a> for TableA<'a> { type Inner = TableA<'a>; #[inline] unsafe fn follow(buf: &'a [u8], loc: usize) -> Self::Inner { Self { _tab: unsafe { ::flatbuffers::Table::new(buf, loc) } } } } impl<'a> TableA<'a> { pub const VT_B: ::flatbuffers::VOffsetT = 4; pub const fn get_fully_qualified_name() -> &'static str { "TableA" } #[inline] pub unsafe fn init_from_table(table: ::flatbuffers::Table<'a>) -> Self { TableA { _tab: table } } #[allow(unused_mut)] pub fn create<'bldr: 'args, 'args: 'mut_bldr, 'mut_bldr, A: ::flatbuffers::Allocator + 'bldr>( _fbb: &'mut_bldr mut ::flatbuffers::FlatBufferBuilder<'bldr, A>, args: &'args TableAArgs<'args> ) -> ::flatbuffers::WIPOffset> { let mut builder = TableABuilder::new(_fbb); if let Some(x) = args.b { builder.add_b(x); } builder.finish() } pub fn unpack(&self) -> TableAT { let b = self.b().map(|x| { alloc::boxed::Box::new(x.unpack()) }); TableAT { b, } } #[inline] pub fn b(&self) -> Option> { // Safety: // Created from valid Table for this object // which contains a valid value in this slot unsafe { self._tab.get::<::flatbuffers::ForwardsUOffset>(TableA::VT_B, None)} } } impl ::flatbuffers::Verifiable for TableA<'_> { #[inline] fn run_verifier( v: &mut ::flatbuffers::Verifier, pos: usize ) -> Result<(), ::flatbuffers::InvalidFlatbuffer> { v.visit_table(pos)? .visit_field::<::flatbuffers::ForwardsUOffset>("b", Self::VT_B, false)? .finish(); Ok(()) } } pub struct TableAArgs<'a> { pub b: Option<::flatbuffers::WIPOffset>>, } impl<'a> Default for TableAArgs<'a> { #[inline] fn default() -> Self { TableAArgs { b: None, } } } pub struct TableABuilder<'a: 'b, 'b, A: ::flatbuffers::Allocator + 'a> { fbb_: &'b mut ::flatbuffers::FlatBufferBuilder<'a, A>, start_: ::flatbuffers::WIPOffset<::flatbuffers::TableUnfinishedWIPOffset>, } impl<'a: 'b, 'b, A: ::flatbuffers::Allocator + 'a> TableABuilder<'a, 'b, A> { #[inline] pub fn add_b(&mut self, b: ::flatbuffers::WIPOffset>) { self.fbb_.push_slot_always::<::flatbuffers::WIPOffset>(TableA::VT_B, b); } #[inline] pub fn new(_fbb: &'b mut ::flatbuffers::FlatBufferBuilder<'a, A>) -> TableABuilder<'a, 'b, A> { let start = _fbb.start_table(); TableABuilder { fbb_: _fbb, start_: start, } } #[inline] pub fn finish(self) -> ::flatbuffers::WIPOffset> { let o = self.fbb_.end_table(self.start_); ::flatbuffers::WIPOffset::new(o.value()) } } impl ::core::fmt::Debug for TableA<'_> { fn fmt(&self, f: &mut ::core::fmt::Formatter<'_>) -> ::core::fmt::Result { let mut ds = f.debug_struct("TableA"); ds.field("b", &self.b()); ds.finish() } } #[non_exhaustive] #[derive(Debug, Clone, PartialEq)] pub struct TableAT { pub b: Option>, } impl Default for TableAT { fn default() -> Self { Self { b: None, } } } impl TableAT { pub fn pack<'b, A: ::flatbuffers::Allocator + 'b>( &self, _fbb: &mut ::flatbuffers::FlatBufferBuilder<'b, A> ) -> ::flatbuffers::WIPOffset> { let b = self.b.as_ref().map(|x|{ x.pack(_fbb) }); TableA::create(_fbb, &TableAArgs{ b, }) } }