use core::mem;
use core::cmp::Ordering;
extern crate flatbuffers;
use self::flatbuffers::{EndianScalar, Follow};
#[deprecated(since = "2.0.0", note = "Use associated constants instead. This will no longer be generated in 2021.")]
pub const ENUM_MIN_TERRAIN_DATA_SOURCE: i8 = 0;
#[deprecated(since = "2.0.0", note = "Use associated constants instead. This will no longer be generated in 2021.")]
pub const ENUM_MAX_TERRAIN_DATA_SOURCE: i8 = 7;
#[deprecated(since = "2.0.0", note = "Use associated constants instead. This will no longer be generated in 2021.")]
#[allow(non_camel_case_types)]
pub const ENUM_VALUES_TERRAIN_DATA_SOURCE: [TerrainDataSource; 8] = [
TerrainDataSource::SRTM,
TerrainDataSource::ASTER,
TerrainDataSource::DTED_0,
TerrainDataSource::DTED_1,
TerrainDataSource::DTED_2,
TerrainDataSource::NED,
TerrainDataSource::LIDAR,
TerrainDataSource::CUSTOM,
];
#[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash, Default)]
#[repr(transparent)]
pub struct TerrainDataSource(pub i8);
#[allow(non_upper_case_globals)]
impl TerrainDataSource {
pub const SRTM: Self = Self(0);
pub const ASTER: Self = Self(1);
pub const DTED_0: Self = Self(2);
pub const DTED_1: Self = Self(3);
pub const DTED_2: Self = Self(4);
pub const NED: Self = Self(5);
pub const LIDAR: Self = Self(6);
pub const CUSTOM: Self = Self(7);
pub const ENUM_MIN: i8 = 0;
pub const ENUM_MAX: i8 = 7;
pub const ENUM_VALUES: &'static [Self] = &[
Self::SRTM,
Self::ASTER,
Self::DTED_0,
Self::DTED_1,
Self::DTED_2,
Self::NED,
Self::LIDAR,
Self::CUSTOM,
];
pub fn variant_name(self) -> Option<&'static str> {
match self {
Self::SRTM => Some("SRTM"),
Self::ASTER => Some("ASTER"),
Self::DTED_0 => Some("DTED_0"),
Self::DTED_1 => Some("DTED_1"),
Self::DTED_2 => Some("DTED_2"),
Self::NED => Some("NED"),
Self::LIDAR => Some("LIDAR"),
Self::CUSTOM => Some("CUSTOM"),
_ => None,
}
}
}
impl core::fmt::Debug for TerrainDataSource {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
if let Some(name) = self.variant_name() {
f.write_str(name)
} else {
f.write_fmt(format_args!("<UNKNOWN {:?}>", self.0))
}
}
}
impl<'a> flatbuffers::Follow<'a> for TerrainDataSource {
type Inner = Self;
#[inline]
unsafe fn follow(buf: &'a [u8], loc: usize) -> Self::Inner {
let b = flatbuffers::read_scalar_at::<i8>(buf, loc);
Self(b)
}
}
impl flatbuffers::Push for TerrainDataSource {
type Output = TerrainDataSource;
#[inline]
unsafe fn push(&self, dst: &mut [u8], _written_len: usize) {
flatbuffers::emplace_scalar::<i8>(dst, self.0);
}
}
impl flatbuffers::EndianScalar for TerrainDataSource {
type Scalar = i8;
#[inline]
fn to_little_endian(self) -> i8 {
self.0.to_le()
}
#[inline]
#[allow(clippy::wrong_self_convention)]
fn from_little_endian(v: i8) -> Self {
let b = i8::from_le(v);
Self(b)
}
}
impl<'a> flatbuffers::Verifiable for TerrainDataSource {
#[inline]
fn run_verifier(
v: &mut flatbuffers::Verifier, pos: usize
) -> Result<(), flatbuffers::InvalidFlatbuffer> {
use self::flatbuffers::Verifiable;
i8::run_verifier(v, pos)
}
}
impl flatbuffers::SimpleToVerifyInSlice for TerrainDataSource {}
#[deprecated(since = "2.0.0", note = "Use associated constants instead. This will no longer be generated in 2021.")]
pub const ENUM_MIN_LAND_COVER_TYPE: i8 = 0;
#[deprecated(since = "2.0.0", note = "Use associated constants instead. This will no longer be generated in 2021.")]
pub const ENUM_MAX_LAND_COVER_TYPE: i8 = 16;
#[deprecated(since = "2.0.0", note = "Use associated constants instead. This will no longer be generated in 2021.")]
#[allow(non_camel_case_types)]
pub const ENUM_VALUES_LAND_COVER_TYPE: [LandCoverType; 17] = [
LandCoverType::WATER,
LandCoverType::URBAN,
LandCoverType::SUBURBAN,
LandCoverType::FOREST_DECIDUOUS,
LandCoverType::FOREST_CONIFEROUS,
LandCoverType::FOREST_MIXED,
LandCoverType::GRASSLAND,
LandCoverType::SHRUBLAND,
LandCoverType::CROPLAND,
LandCoverType::BARREN,
LandCoverType::WETLAND,
LandCoverType::SNOW_ICE,
LandCoverType::DESERT,
LandCoverType::ROCK,
LandCoverType::ROAD,
LandCoverType::RUNWAY,
LandCoverType::BUILDING,
];
#[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash, Default)]
#[repr(transparent)]
pub struct LandCoverType(pub i8);
#[allow(non_upper_case_globals)]
impl LandCoverType {
pub const WATER: Self = Self(0);
pub const URBAN: Self = Self(1);
pub const SUBURBAN: Self = Self(2);
pub const FOREST_DECIDUOUS: Self = Self(3);
pub const FOREST_CONIFEROUS: Self = Self(4);
pub const FOREST_MIXED: Self = Self(5);
pub const GRASSLAND: Self = Self(6);
pub const SHRUBLAND: Self = Self(7);
pub const CROPLAND: Self = Self(8);
pub const BARREN: Self = Self(9);
pub const WETLAND: Self = Self(10);
pub const SNOW_ICE: Self = Self(11);
pub const DESERT: Self = Self(12);
pub const ROCK: Self = Self(13);
pub const ROAD: Self = Self(14);
pub const RUNWAY: Self = Self(15);
pub const BUILDING: Self = Self(16);
pub const ENUM_MIN: i8 = 0;
pub const ENUM_MAX: i8 = 16;
pub const ENUM_VALUES: &'static [Self] = &[
Self::WATER,
Self::URBAN,
Self::SUBURBAN,
Self::FOREST_DECIDUOUS,
Self::FOREST_CONIFEROUS,
Self::FOREST_MIXED,
Self::GRASSLAND,
Self::SHRUBLAND,
Self::CROPLAND,
Self::BARREN,
Self::WETLAND,
Self::SNOW_ICE,
Self::DESERT,
Self::ROCK,
Self::ROAD,
Self::RUNWAY,
Self::BUILDING,
];
pub fn variant_name(self) -> Option<&'static str> {
match self {
Self::WATER => Some("WATER"),
Self::URBAN => Some("URBAN"),
Self::SUBURBAN => Some("SUBURBAN"),
Self::FOREST_DECIDUOUS => Some("FOREST_DECIDUOUS"),
Self::FOREST_CONIFEROUS => Some("FOREST_CONIFEROUS"),
Self::FOREST_MIXED => Some("FOREST_MIXED"),
Self::GRASSLAND => Some("GRASSLAND"),
Self::SHRUBLAND => Some("SHRUBLAND"),
Self::CROPLAND => Some("CROPLAND"),
Self::BARREN => Some("BARREN"),
Self::WETLAND => Some("WETLAND"),
Self::SNOW_ICE => Some("SNOW_ICE"),
Self::DESERT => Some("DESERT"),
Self::ROCK => Some("ROCK"),
Self::ROAD => Some("ROAD"),
Self::RUNWAY => Some("RUNWAY"),
Self::BUILDING => Some("BUILDING"),
_ => None,
}
}
}
impl core::fmt::Debug for LandCoverType {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
if let Some(name) = self.variant_name() {
f.write_str(name)
} else {
f.write_fmt(format_args!("<UNKNOWN {:?}>", self.0))
}
}
}
impl<'a> flatbuffers::Follow<'a> for LandCoverType {
type Inner = Self;
#[inline]
unsafe fn follow(buf: &'a [u8], loc: usize) -> Self::Inner {
let b = flatbuffers::read_scalar_at::<i8>(buf, loc);
Self(b)
}
}
impl flatbuffers::Push for LandCoverType {
type Output = LandCoverType;
#[inline]
unsafe fn push(&self, dst: &mut [u8], _written_len: usize) {
flatbuffers::emplace_scalar::<i8>(dst, self.0);
}
}
impl flatbuffers::EndianScalar for LandCoverType {
type Scalar = i8;
#[inline]
fn to_little_endian(self) -> i8 {
self.0.to_le()
}
#[inline]
#[allow(clippy::wrong_self_convention)]
fn from_little_endian(v: i8) -> Self {
let b = i8::from_le(v);
Self(b)
}
}
impl<'a> flatbuffers::Verifiable for LandCoverType {
#[inline]
fn run_verifier(
v: &mut flatbuffers::Verifier, pos: usize
) -> Result<(), flatbuffers::InvalidFlatbuffer> {
use self::flatbuffers::Verifiable;
i8::run_verifier(v, pos)
}
}
impl flatbuffers::SimpleToVerifyInSlice for LandCoverType {}
#[deprecated(since = "2.0.0", note = "Use associated constants instead. This will no longer be generated in 2021.")]
pub const ENUM_MIN_TERRAIN_INTERPOLATION: i8 = 0;
#[deprecated(since = "2.0.0", note = "Use associated constants instead. This will no longer be generated in 2021.")]
pub const ENUM_MAX_TERRAIN_INTERPOLATION: i8 = 3;
#[deprecated(since = "2.0.0", note = "Use associated constants instead. This will no longer be generated in 2021.")]
#[allow(non_camel_case_types)]
pub const ENUM_VALUES_TERRAIN_INTERPOLATION: [TerrainInterpolation; 4] = [
TerrainInterpolation::NEAREST,
TerrainInterpolation::BILINEAR,
TerrainInterpolation::BICUBIC,
TerrainInterpolation::KRIGING,
];
#[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash, Default)]
#[repr(transparent)]
pub struct TerrainInterpolation(pub i8);
#[allow(non_upper_case_globals)]
impl TerrainInterpolation {
pub const NEAREST: Self = Self(0);
pub const BILINEAR: Self = Self(1);
pub const BICUBIC: Self = Self(2);
pub const KRIGING: Self = Self(3);
pub const ENUM_MIN: i8 = 0;
pub const ENUM_MAX: i8 = 3;
pub const ENUM_VALUES: &'static [Self] = &[
Self::NEAREST,
Self::BILINEAR,
Self::BICUBIC,
Self::KRIGING,
];
pub fn variant_name(self) -> Option<&'static str> {
match self {
Self::NEAREST => Some("NEAREST"),
Self::BILINEAR => Some("BILINEAR"),
Self::BICUBIC => Some("BICUBIC"),
Self::KRIGING => Some("KRIGING"),
_ => None,
}
}
}
impl core::fmt::Debug for TerrainInterpolation {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
if let Some(name) = self.variant_name() {
f.write_str(name)
} else {
f.write_fmt(format_args!("<UNKNOWN {:?}>", self.0))
}
}
}
impl<'a> flatbuffers::Follow<'a> for TerrainInterpolation {
type Inner = Self;
#[inline]
unsafe fn follow(buf: &'a [u8], loc: usize) -> Self::Inner {
let b = flatbuffers::read_scalar_at::<i8>(buf, loc);
Self(b)
}
}
impl flatbuffers::Push for TerrainInterpolation {
type Output = TerrainInterpolation;
#[inline]
unsafe fn push(&self, dst: &mut [u8], _written_len: usize) {
flatbuffers::emplace_scalar::<i8>(dst, self.0);
}
}
impl flatbuffers::EndianScalar for TerrainInterpolation {
type Scalar = i8;
#[inline]
fn to_little_endian(self) -> i8 {
self.0.to_le()
}
#[inline]
#[allow(clippy::wrong_self_convention)]
fn from_little_endian(v: i8) -> Self {
let b = i8::from_le(v);
Self(b)
}
}
impl<'a> flatbuffers::Verifiable for TerrainInterpolation {
#[inline]
fn run_verifier(
v: &mut flatbuffers::Verifier, pos: usize
) -> Result<(), flatbuffers::InvalidFlatbuffer> {
use self::flatbuffers::Verifiable;
i8::run_verifier(v, pos)
}
}
impl flatbuffers::SimpleToVerifyInSlice for TerrainInterpolation {}
pub enum TRNOffset {}
#[derive(Copy, Clone, PartialEq)]
pub struct TRN<'a> {
pub _tab: flatbuffers::Table<'a>,
}
impl<'a> flatbuffers::Follow<'a> for TRN<'a> {
type Inner = TRN<'a>;
#[inline]
unsafe fn follow(buf: &'a [u8], loc: usize) -> Self::Inner {
Self { _tab: flatbuffers::Table::new(buf, loc) }
}
}
impl<'a> TRN<'a> {
pub const VT_SOURCES: flatbuffers::VOffsetT = 4;
pub const VT_INTERPOLATION: flatbuffers::VOffsetT = 6;
pub const VT_CACHE_ENABLED: flatbuffers::VOffsetT = 8;
pub const VT_MAX_CACHE_TILES: flatbuffers::VOffsetT = 10;
pub const VT_VERTICAL_EXAGGERATION: flatbuffers::VOffsetT = 12;
#[inline]
pub unsafe fn init_from_table(table: flatbuffers::Table<'a>) -> Self {
TRN { _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 TRNArgs<'args>
) -> flatbuffers::WIPOffset<TRN<'bldr>> {
let mut builder = TRNBuilder::new(_fbb);
builder.add_VERTICAL_EXAGGERATION(args.VERTICAL_EXAGGERATION);
if let Some(x) = args.SOURCES { builder.add_SOURCES(x); }
builder.add_MAX_CACHE_TILES(args.MAX_CACHE_TILES);
builder.add_CACHE_ENABLED(args.CACHE_ENABLED);
builder.add_INTERPOLATION(args.INTERPOLATION);
builder.finish()
}
pub fn unpack(&self) -> TRNT {
let SOURCES = self.SOURCES().map(|x| {
x.into_iter().collect()
});
let INTERPOLATION = self.INTERPOLATION();
let CACHE_ENABLED = self.CACHE_ENABLED();
let MAX_CACHE_TILES = self.MAX_CACHE_TILES();
let VERTICAL_EXAGGERATION = self.VERTICAL_EXAGGERATION();
TRNT {
SOURCES,
INTERPOLATION,
CACHE_ENABLED,
MAX_CACHE_TILES,
VERTICAL_EXAGGERATION,
}
}
#[inline]
pub fn SOURCES(&self) -> Option<flatbuffers::Vector<'a, TerrainDataSource>> {
unsafe { self._tab.get::<flatbuffers::ForwardsUOffset<flatbuffers::Vector<'a, TerrainDataSource>>>(TRN::VT_SOURCES, None)}
}
#[inline]
pub fn INTERPOLATION(&self) -> TerrainInterpolation {
unsafe { self._tab.get::<TerrainInterpolation>(TRN::VT_INTERPOLATION, Some(TerrainInterpolation::BILINEAR)).unwrap()}
}
#[inline]
pub fn CACHE_ENABLED(&self) -> bool {
unsafe { self._tab.get::<bool>(TRN::VT_CACHE_ENABLED, Some(true)).unwrap()}
}
#[inline]
pub fn MAX_CACHE_TILES(&self) -> u16 {
unsafe { self._tab.get::<u16>(TRN::VT_MAX_CACHE_TILES, Some(100)).unwrap()}
}
#[inline]
pub fn VERTICAL_EXAGGERATION(&self) -> f64 {
unsafe { self._tab.get::<f64>(TRN::VT_VERTICAL_EXAGGERATION, Some(1.0)).unwrap()}
}
}
impl flatbuffers::Verifiable for TRN<'_> {
#[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<flatbuffers::Vector<'_, TerrainDataSource>>>("SOURCES", Self::VT_SOURCES, false)?
.visit_field::<TerrainInterpolation>("INTERPOLATION", Self::VT_INTERPOLATION, false)?
.visit_field::<bool>("CACHE_ENABLED", Self::VT_CACHE_ENABLED, false)?
.visit_field::<u16>("MAX_CACHE_TILES", Self::VT_MAX_CACHE_TILES, false)?
.visit_field::<f64>("VERTICAL_EXAGGERATION", Self::VT_VERTICAL_EXAGGERATION, false)?
.finish();
Ok(())
}
}
pub struct TRNArgs<'a> {
pub SOURCES: Option<flatbuffers::WIPOffset<flatbuffers::Vector<'a, TerrainDataSource>>>,
pub INTERPOLATION: TerrainInterpolation,
pub CACHE_ENABLED: bool,
pub MAX_CACHE_TILES: u16,
pub VERTICAL_EXAGGERATION: f64,
}
impl<'a> Default for TRNArgs<'a> {
#[inline]
fn default() -> Self {
TRNArgs {
SOURCES: None,
INTERPOLATION: TerrainInterpolation::BILINEAR,
CACHE_ENABLED: true,
MAX_CACHE_TILES: 100,
VERTICAL_EXAGGERATION: 1.0,
}
}
}
pub struct TRNBuilder<'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> TRNBuilder<'a, 'b, A> {
#[inline]
pub fn add_SOURCES(&mut self, SOURCES: flatbuffers::WIPOffset<flatbuffers::Vector<'b , TerrainDataSource>>) {
self.fbb_.push_slot_always::<flatbuffers::WIPOffset<_>>(TRN::VT_SOURCES, SOURCES);
}
#[inline]
pub fn add_INTERPOLATION(&mut self, INTERPOLATION: TerrainInterpolation) {
self.fbb_.push_slot::<TerrainInterpolation>(TRN::VT_INTERPOLATION, INTERPOLATION, TerrainInterpolation::BILINEAR);
}
#[inline]
pub fn add_CACHE_ENABLED(&mut self, CACHE_ENABLED: bool) {
self.fbb_.push_slot::<bool>(TRN::VT_CACHE_ENABLED, CACHE_ENABLED, true);
}
#[inline]
pub fn add_MAX_CACHE_TILES(&mut self, MAX_CACHE_TILES: u16) {
self.fbb_.push_slot::<u16>(TRN::VT_MAX_CACHE_TILES, MAX_CACHE_TILES, 100);
}
#[inline]
pub fn add_VERTICAL_EXAGGERATION(&mut self, VERTICAL_EXAGGERATION: f64) {
self.fbb_.push_slot::<f64>(TRN::VT_VERTICAL_EXAGGERATION, VERTICAL_EXAGGERATION, 1.0);
}
#[inline]
pub fn new(_fbb: &'b mut flatbuffers::FlatBufferBuilder<'a, A>) -> TRNBuilder<'a, 'b, A> {
let start = _fbb.start_table();
TRNBuilder {
fbb_: _fbb,
start_: start,
}
}
#[inline]
pub fn finish(self) -> flatbuffers::WIPOffset<TRN<'a>> {
let o = self.fbb_.end_table(self.start_);
flatbuffers::WIPOffset::new(o.value())
}
}
impl core::fmt::Debug for TRN<'_> {
fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
let mut ds = f.debug_struct("TRN");
ds.field("SOURCES", &self.SOURCES());
ds.field("INTERPOLATION", &self.INTERPOLATION());
ds.field("CACHE_ENABLED", &self.CACHE_ENABLED());
ds.field("MAX_CACHE_TILES", &self.MAX_CACHE_TILES());
ds.field("VERTICAL_EXAGGERATION", &self.VERTICAL_EXAGGERATION());
ds.finish()
}
}
#[non_exhaustive]
#[derive(Debug, Clone, PartialEq)]
pub struct TRNT {
pub SOURCES: Option<Vec<TerrainDataSource>>,
pub INTERPOLATION: TerrainInterpolation,
pub CACHE_ENABLED: bool,
pub MAX_CACHE_TILES: u16,
pub VERTICAL_EXAGGERATION: f64,
}
impl Default for TRNT {
fn default() -> Self {
Self {
SOURCES: None,
INTERPOLATION: TerrainInterpolation::BILINEAR,
CACHE_ENABLED: true,
MAX_CACHE_TILES: 100,
VERTICAL_EXAGGERATION: 1.0,
}
}
}
impl TRNT {
pub fn pack<'b, A: flatbuffers::Allocator + 'b>(
&self,
_fbb: &mut flatbuffers::FlatBufferBuilder<'b, A>
) -> flatbuffers::WIPOffset<TRN<'b>> {
let SOURCES = self.SOURCES.as_ref().map(|x|{
_fbb.create_vector(x)
});
let INTERPOLATION = self.INTERPOLATION;
let CACHE_ENABLED = self.CACHE_ENABLED;
let MAX_CACHE_TILES = self.MAX_CACHE_TILES;
let VERTICAL_EXAGGERATION = self.VERTICAL_EXAGGERATION;
TRN::create(_fbb, &TRNArgs{
SOURCES,
INTERPOLATION,
CACHE_ENABLED,
MAX_CACHE_TILES,
VERTICAL_EXAGGERATION,
})
}
}
#[inline]
pub fn root_as_TRN(buf: &[u8]) -> Result<TRN, flatbuffers::InvalidFlatbuffer> {
flatbuffers::root::<TRN>(buf)
}
#[inline]
pub fn size_prefixed_root_as_TRN(buf: &[u8]) -> Result<TRN, flatbuffers::InvalidFlatbuffer> {
flatbuffers::size_prefixed_root::<TRN>(buf)
}
#[inline]
pub fn root_as_TRN_with_opts<'b, 'o>(
opts: &'o flatbuffers::VerifierOptions,
buf: &'b [u8],
) -> Result<TRN<'b>, flatbuffers::InvalidFlatbuffer> {
flatbuffers::root_with_opts::<TRN<'b>>(opts, buf)
}
#[inline]
pub fn size_prefixed_root_as_TRN_with_opts<'b, 'o>(
opts: &'o flatbuffers::VerifierOptions,
buf: &'b [u8],
) -> Result<TRN<'b>, flatbuffers::InvalidFlatbuffer> {
flatbuffers::size_prefixed_root_with_opts::<TRN<'b>>(opts, buf)
}
#[inline]
pub unsafe fn root_as_TRN_unchecked(buf: &[u8]) -> TRN {
flatbuffers::root_unchecked::<TRN>(buf)
}
#[inline]
pub unsafe fn size_prefixed_root_as_TRN_unchecked(buf: &[u8]) -> TRN {
flatbuffers::size_prefixed_root_unchecked::<TRN>(buf)
}
pub const TRN_IDENTIFIER: &str = "$TRN";
#[inline]
pub fn TRN_buffer_has_identifier(buf: &[u8]) -> bool {
flatbuffers::buffer_has_identifier(buf, TRN_IDENTIFIER, false)
}
#[inline]
pub fn TRN_size_prefixed_buffer_has_identifier(buf: &[u8]) -> bool {
flatbuffers::buffer_has_identifier(buf, TRN_IDENTIFIER, true)
}
#[inline]
pub fn finish_TRN_buffer<'a, 'b, A: flatbuffers::Allocator + 'a>(
fbb: &'b mut flatbuffers::FlatBufferBuilder<'a, A>,
root: flatbuffers::WIPOffset<TRN<'a>>) {
fbb.finish(root, Some(TRN_IDENTIFIER));
}
#[inline]
pub fn finish_size_prefixed_TRN_buffer<'a, 'b, A: flatbuffers::Allocator + 'a>(fbb: &'b mut flatbuffers::FlatBufferBuilder<'a, A>, root: flatbuffers::WIPOffset<TRN<'a>>) {
fbb.finish_size_prefixed(root, Some(TRN_IDENTIFIER));
}