mirror of
https://github.com/google/flatbuffers.git
synced 2026-06-11 15:37:27 +00:00
* Refactored Rust Generated code into a module directory. Each symbol will be generated into one file and then imported into a module. This breaks the "out_dir" pattern where some users would generate code in their target/ directory. Also, these objects are best used in their own module. It will be hard for users to share their own module structure with flatbuffers namespaces. There may be solutions to these drawbacks but that should be discussed. I don't want to overengineer here. * shadow error * try fix .bat file * fix .bat 2 * Restore accidentally deleted files * Fixed some DONOTSUBMITs and made Rust outdir pattern use symlinks. * fixed binary files * git clang format * make generated onefiles not public and fix .bat * reduced diff with master in generate_code.sh * fix shadowed variable * add object api flags to .bat * space * Removed extern crate and extra & * use statement * more clippy lints * format * Undo extern crate -> use change, it actually matters to our tests Co-authored-by: Casper Neo <cneo@google.com>
159 lines
5.1 KiB
Rust
159 lines
5.1 KiB
Rust
// automatically generated by the FlatBuffers compiler, do not modify
|
|
extern crate flatbuffers;
|
|
use std::mem;
|
|
use std::cmp::Ordering;
|
|
use self::flatbuffers::{EndianScalar, Follow};
|
|
use super::*;
|
|
pub enum TableInCOffset {}
|
|
#[derive(Copy, Clone, PartialEq)]
|
|
|
|
pub struct TableInC<'a> {
|
|
pub _tab: flatbuffers::Table<'a>,
|
|
}
|
|
|
|
impl<'a> flatbuffers::Follow<'a> for TableInC<'a> {
|
|
type Inner = TableInC<'a>;
|
|
#[inline]
|
|
fn follow(buf: &'a [u8], loc: usize) -> Self::Inner {
|
|
Self { _tab: flatbuffers::Table { buf, loc } }
|
|
}
|
|
}
|
|
|
|
impl<'a> TableInC<'a> {
|
|
pub const fn get_fully_qualified_name() -> &'static str {
|
|
"NamespaceC.TableInC"
|
|
}
|
|
|
|
#[inline]
|
|
pub fn init_from_table(table: flatbuffers::Table<'a>) -> Self {
|
|
TableInC { _tab: table }
|
|
}
|
|
#[allow(unused_mut)]
|
|
pub fn create<'bldr: 'args, 'args: 'mut_bldr, 'mut_bldr>(
|
|
_fbb: &'mut_bldr mut flatbuffers::FlatBufferBuilder<'bldr>,
|
|
args: &'args TableInCArgs<'args>) -> flatbuffers::WIPOffset<TableInC<'bldr>> {
|
|
let mut builder = TableInCBuilder::new(_fbb);
|
|
if let Some(x) = args.refer_to_a2 { builder.add_refer_to_a2(x); }
|
|
if let Some(x) = args.refer_to_a1 { builder.add_refer_to_a1(x); }
|
|
builder.finish()
|
|
}
|
|
|
|
pub fn unpack(&self) -> TableInCT {
|
|
let refer_to_a1 = self.refer_to_a1().map(|x| {
|
|
Box::new(x.unpack())
|
|
});
|
|
let refer_to_a2 = self.refer_to_a2().map(|x| {
|
|
Box::new(x.unpack())
|
|
});
|
|
TableInCT {
|
|
refer_to_a1,
|
|
refer_to_a2,
|
|
}
|
|
}
|
|
pub const VT_REFER_TO_A1: flatbuffers::VOffsetT = 4;
|
|
pub const VT_REFER_TO_A2: flatbuffers::VOffsetT = 6;
|
|
|
|
#[inline]
|
|
pub fn refer_to_a1(&self) -> Option<super::namespace_a::TableInFirstNS<'a>> {
|
|
self._tab.get::<flatbuffers::ForwardsUOffset<super::namespace_a::TableInFirstNS>>(TableInC::VT_REFER_TO_A1, None)
|
|
}
|
|
#[inline]
|
|
pub fn refer_to_a2(&self) -> Option<super::namespace_a::SecondTableInA<'a>> {
|
|
self._tab.get::<flatbuffers::ForwardsUOffset<super::namespace_a::SecondTableInA>>(TableInC::VT_REFER_TO_A2, None)
|
|
}
|
|
}
|
|
|
|
impl flatbuffers::Verifiable for TableInC<'_> {
|
|
#[inline]
|
|
fn run_verifier(
|
|
v: &mut flatbuffers::Verifier, pos: usize
|
|
) -> Result<(), flatbuffers::InvalidFlatbuffer> {
|
|
use self::flatbuffers::Verifiable;
|
|
v.visit_table(pos)?
|
|
.visit_field::<flatbuffers::ForwardsUOffset<super::namespace_a::TableInFirstNS>>("refer_to_a1", Self::VT_REFER_TO_A1, false)?
|
|
.visit_field::<flatbuffers::ForwardsUOffset<super::namespace_a::SecondTableInA>>("refer_to_a2", Self::VT_REFER_TO_A2, false)?
|
|
.finish();
|
|
Ok(())
|
|
}
|
|
}
|
|
pub struct TableInCArgs<'a> {
|
|
pub refer_to_a1: Option<flatbuffers::WIPOffset<super::namespace_a::TableInFirstNS<'a>>>,
|
|
pub refer_to_a2: Option<flatbuffers::WIPOffset<super::namespace_a::SecondTableInA<'a>>>,
|
|
}
|
|
impl<'a> Default for TableInCArgs<'a> {
|
|
#[inline]
|
|
fn default() -> Self {
|
|
TableInCArgs {
|
|
refer_to_a1: None,
|
|
refer_to_a2: None,
|
|
}
|
|
}
|
|
}
|
|
pub struct TableInCBuilder<'a: 'b, 'b> {
|
|
fbb_: &'b mut flatbuffers::FlatBufferBuilder<'a>,
|
|
start_: flatbuffers::WIPOffset<flatbuffers::TableUnfinishedWIPOffset>,
|
|
}
|
|
impl<'a: 'b, 'b> TableInCBuilder<'a, 'b> {
|
|
#[inline]
|
|
pub fn add_refer_to_a1(&mut self, refer_to_a1: flatbuffers::WIPOffset<super::namespace_a::TableInFirstNS<'b >>) {
|
|
self.fbb_.push_slot_always::<flatbuffers::WIPOffset<super::namespace_a::TableInFirstNS>>(TableInC::VT_REFER_TO_A1, refer_to_a1);
|
|
}
|
|
#[inline]
|
|
pub fn add_refer_to_a2(&mut self, refer_to_a2: flatbuffers::WIPOffset<super::namespace_a::SecondTableInA<'b >>) {
|
|
self.fbb_.push_slot_always::<flatbuffers::WIPOffset<super::namespace_a::SecondTableInA>>(TableInC::VT_REFER_TO_A2, refer_to_a2);
|
|
}
|
|
#[inline]
|
|
pub fn new(_fbb: &'b mut flatbuffers::FlatBufferBuilder<'a>) -> TableInCBuilder<'a, 'b> {
|
|
let start = _fbb.start_table();
|
|
TableInCBuilder {
|
|
fbb_: _fbb,
|
|
start_: start,
|
|
}
|
|
}
|
|
#[inline]
|
|
pub fn finish(self) -> flatbuffers::WIPOffset<TableInC<'a>> {
|
|
let o = self.fbb_.end_table(self.start_);
|
|
flatbuffers::WIPOffset::new(o.value())
|
|
}
|
|
}
|
|
|
|
impl std::fmt::Debug for TableInC<'_> {
|
|
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
|
let mut ds = f.debug_struct("TableInC");
|
|
ds.field("refer_to_a1", &self.refer_to_a1());
|
|
ds.field("refer_to_a2", &self.refer_to_a2());
|
|
ds.finish()
|
|
}
|
|
}
|
|
#[non_exhaustive]
|
|
#[derive(Debug, Clone, PartialEq)]
|
|
pub struct TableInCT {
|
|
pub refer_to_a1: Option<Box<super::namespace_a::TableInFirstNST>>,
|
|
pub refer_to_a2: Option<Box<super::namespace_a::SecondTableInAT>>,
|
|
}
|
|
impl Default for TableInCT {
|
|
fn default() -> Self {
|
|
Self {
|
|
refer_to_a1: None,
|
|
refer_to_a2: None,
|
|
}
|
|
}
|
|
}
|
|
impl TableInCT {
|
|
pub fn pack<'b>(
|
|
&self,
|
|
_fbb: &mut flatbuffers::FlatBufferBuilder<'b>
|
|
) -> flatbuffers::WIPOffset<TableInC<'b>> {
|
|
let refer_to_a1 = self.refer_to_a1.as_ref().map(|x|{
|
|
x.pack(_fbb)
|
|
});
|
|
let refer_to_a2 = self.refer_to_a2.as_ref().map(|x|{
|
|
x.pack(_fbb)
|
|
});
|
|
TableInC::create(_fbb, &TableInCArgs{
|
|
refer_to_a1,
|
|
refer_to_a2,
|
|
})
|
|
}
|
|
}
|