mirror of
https://github.com/google/flatbuffers.git
synced 2026-06-05 21:17:25 +00:00
Optionally generate Python type annotations (#7858)
* optionally generate type prefixes and suffixes for python code * fix codegen error when qualified name is empty * WIP: Python typing * more progress towards python typing * Further iterate on Python generated code typing * clang-format * Regenerate code * add documentation for Python type annotations option * generate code with Python type annotations * handle forward references * clang-format
This commit is contained in:
@@ -4,13 +4,16 @@
|
||||
|
||||
import flatbuffers
|
||||
from flatbuffers.compat import import_numpy
|
||||
from typing import Any
|
||||
from flatbuffers.table import Table
|
||||
from typing import Optional
|
||||
np = import_numpy()
|
||||
|
||||
class NestedUnionTest(object):
|
||||
__slots__ = ['_tab']
|
||||
|
||||
@classmethod
|
||||
def GetRootAs(cls, buf, offset=0):
|
||||
def GetRootAs(cls, buf, offset: int = 0):
|
||||
n = flatbuffers.encode.Get(flatbuffers.packer.uoffset, buf, offset)
|
||||
x = NestedUnionTest()
|
||||
x.Init(buf, n + offset)
|
||||
@@ -21,11 +24,11 @@ class NestedUnionTest(object):
|
||||
"""This method is deprecated. Please switch to GetRootAs."""
|
||||
return cls.GetRootAs(buf, offset)
|
||||
# NestedUnionTest
|
||||
def Init(self, buf, pos):
|
||||
def Init(self, buf: bytes, pos: int):
|
||||
self._tab = flatbuffers.table.Table(buf, pos)
|
||||
|
||||
# NestedUnionTest
|
||||
def Name(self):
|
||||
def Name(self) -> Optional[str]:
|
||||
o = flatbuffers.number_types.UOffsetTFlags.py_type(self._tab.Offset(4))
|
||||
if o != 0:
|
||||
return self._tab.String(o + self._tab.Pos)
|
||||
@@ -39,10 +42,9 @@ class NestedUnionTest(object):
|
||||
return 0
|
||||
|
||||
# NestedUnionTest
|
||||
def Data(self):
|
||||
def Data(self) -> Optional[flatbuffers.table.Table]:
|
||||
o = flatbuffers.number_types.UOffsetTFlags.py_type(self._tab.Offset(8))
|
||||
if o != 0:
|
||||
from flatbuffers.table import Table
|
||||
obj = Table(bytearray(), 0)
|
||||
self._tab.Union(obj, o)
|
||||
return obj
|
||||
@@ -55,40 +57,40 @@ class NestedUnionTest(object):
|
||||
return self._tab.Get(flatbuffers.number_types.Int16Flags, o + self._tab.Pos)
|
||||
return 0
|
||||
|
||||
def NestedUnionTestStart(builder):
|
||||
return builder.StartObject(4)
|
||||
def NestedUnionTestStart(builder: flatbuffers.Builder):
|
||||
builder.StartObject(4)
|
||||
|
||||
def Start(builder):
|
||||
return NestedUnionTestStart(builder)
|
||||
def Start(builder: flatbuffers.Builder):
|
||||
NestedUnionTestStart(builder)
|
||||
|
||||
def NestedUnionTestAddName(builder, name):
|
||||
return builder.PrependUOffsetTRelativeSlot(0, flatbuffers.number_types.UOffsetTFlags.py_type(name), 0)
|
||||
def NestedUnionTestAddName(builder: flatbuffers.Builder, name: int):
|
||||
builder.PrependUOffsetTRelativeSlot(0, flatbuffers.number_types.UOffsetTFlags.py_type(name), 0)
|
||||
|
||||
def AddName(builder, name):
|
||||
return NestedUnionTestAddName(builder, name)
|
||||
def AddName(builder: flatbuffers.Builder, name: int):
|
||||
NestedUnionTestAddName(builder, name)
|
||||
|
||||
def NestedUnionTestAddDataType(builder, dataType):
|
||||
return builder.PrependUint8Slot(1, dataType, 0)
|
||||
def NestedUnionTestAddDataType(builder: flatbuffers.Builder, dataType: int):
|
||||
builder.PrependUint8Slot(1, dataType, 0)
|
||||
|
||||
def AddDataType(builder, dataType):
|
||||
return NestedUnionTestAddDataType(builder, dataType)
|
||||
def AddDataType(builder: flatbuffers.Builder, dataType: int):
|
||||
NestedUnionTestAddDataType(builder, dataType)
|
||||
|
||||
def NestedUnionTestAddData(builder, data):
|
||||
return builder.PrependUOffsetTRelativeSlot(2, flatbuffers.number_types.UOffsetTFlags.py_type(data), 0)
|
||||
def NestedUnionTestAddData(builder: flatbuffers.Builder, data: int):
|
||||
builder.PrependUOffsetTRelativeSlot(2, flatbuffers.number_types.UOffsetTFlags.py_type(data), 0)
|
||||
|
||||
def AddData(builder, data):
|
||||
return NestedUnionTestAddData(builder, data)
|
||||
def AddData(builder: flatbuffers.Builder, data: int):
|
||||
NestedUnionTestAddData(builder, data)
|
||||
|
||||
def NestedUnionTestAddId(builder, id):
|
||||
return builder.PrependInt16Slot(3, id, 0)
|
||||
def NestedUnionTestAddId(builder: flatbuffers.Builder, id: int):
|
||||
builder.PrependInt16Slot(3, id, 0)
|
||||
|
||||
def AddId(builder, id):
|
||||
return NestedUnionTestAddId(builder, id)
|
||||
def AddId(builder: flatbuffers.Builder, id: int):
|
||||
NestedUnionTestAddId(builder, id)
|
||||
|
||||
def NestedUnionTestEnd(builder):
|
||||
def NestedUnionTestEnd(builder: flatbuffers.Builder) -> int:
|
||||
return builder.EndObject()
|
||||
|
||||
def End(builder):
|
||||
def End(builder: flatbuffers.Builder) -> int:
|
||||
return NestedUnionTestEnd(builder)
|
||||
|
||||
import MyGame.Example.NestedUnion.Any
|
||||
|
||||
@@ -4,17 +4,18 @@
|
||||
|
||||
import flatbuffers
|
||||
from flatbuffers.compat import import_numpy
|
||||
from typing import Any
|
||||
np = import_numpy()
|
||||
|
||||
class Test(object):
|
||||
__slots__ = ['_tab']
|
||||
|
||||
@classmethod
|
||||
def SizeOf(cls):
|
||||
def SizeOf(cls) -> int:
|
||||
return 4
|
||||
|
||||
# Test
|
||||
def Init(self, buf, pos):
|
||||
def Init(self, buf: bytes, pos: int):
|
||||
self._tab = flatbuffers.table.Table(buf, pos)
|
||||
|
||||
# Test
|
||||
|
||||
@@ -4,13 +4,14 @@
|
||||
|
||||
import flatbuffers
|
||||
from flatbuffers.compat import import_numpy
|
||||
from typing import Any
|
||||
np = import_numpy()
|
||||
|
||||
class TestSimpleTableWithEnum(object):
|
||||
__slots__ = ['_tab']
|
||||
|
||||
@classmethod
|
||||
def GetRootAs(cls, buf, offset=0):
|
||||
def GetRootAs(cls, buf, offset: int = 0):
|
||||
n = flatbuffers.encode.Get(flatbuffers.packer.uoffset, buf, offset)
|
||||
x = TestSimpleTableWithEnum()
|
||||
x.Init(buf, n + offset)
|
||||
@@ -21,7 +22,7 @@ class TestSimpleTableWithEnum(object):
|
||||
"""This method is deprecated. Please switch to GetRootAs."""
|
||||
return cls.GetRootAs(buf, offset)
|
||||
# TestSimpleTableWithEnum
|
||||
def Init(self, buf, pos):
|
||||
def Init(self, buf: bytes, pos: int):
|
||||
self._tab = flatbuffers.table.Table(buf, pos)
|
||||
|
||||
# TestSimpleTableWithEnum
|
||||
@@ -31,22 +32,22 @@ class TestSimpleTableWithEnum(object):
|
||||
return self._tab.Get(flatbuffers.number_types.Uint8Flags, o + self._tab.Pos)
|
||||
return 2
|
||||
|
||||
def TestSimpleTableWithEnumStart(builder):
|
||||
return builder.StartObject(1)
|
||||
def TestSimpleTableWithEnumStart(builder: flatbuffers.Builder):
|
||||
builder.StartObject(1)
|
||||
|
||||
def Start(builder):
|
||||
return TestSimpleTableWithEnumStart(builder)
|
||||
def Start(builder: flatbuffers.Builder):
|
||||
TestSimpleTableWithEnumStart(builder)
|
||||
|
||||
def TestSimpleTableWithEnumAddColor(builder, color):
|
||||
return builder.PrependUint8Slot(0, color, 2)
|
||||
def TestSimpleTableWithEnumAddColor(builder: flatbuffers.Builder, color: int):
|
||||
builder.PrependUint8Slot(0, color, 2)
|
||||
|
||||
def AddColor(builder, color):
|
||||
return TestSimpleTableWithEnumAddColor(builder, color)
|
||||
def AddColor(builder: flatbuffers.Builder, color: int):
|
||||
TestSimpleTableWithEnumAddColor(builder, color)
|
||||
|
||||
def TestSimpleTableWithEnumEnd(builder):
|
||||
def TestSimpleTableWithEnumEnd(builder: flatbuffers.Builder) -> int:
|
||||
return builder.EndObject()
|
||||
|
||||
def End(builder):
|
||||
def End(builder: flatbuffers.Builder) -> int:
|
||||
return TestSimpleTableWithEnumEnd(builder)
|
||||
|
||||
|
||||
|
||||
@@ -4,13 +4,16 @@
|
||||
|
||||
import flatbuffers
|
||||
from flatbuffers.compat import import_numpy
|
||||
from typing import Any
|
||||
from .MyGame.Example.NestedUnion.Test import Test
|
||||
from typing import Optional
|
||||
np = import_numpy()
|
||||
|
||||
class Vec3(object):
|
||||
__slots__ = ['_tab']
|
||||
|
||||
@classmethod
|
||||
def GetRootAs(cls, buf, offset=0):
|
||||
def GetRootAs(cls, buf, offset: int = 0):
|
||||
n = flatbuffers.encode.Get(flatbuffers.packer.uoffset, buf, offset)
|
||||
x = Vec3()
|
||||
x.Init(buf, n + offset)
|
||||
@@ -21,7 +24,7 @@ class Vec3(object):
|
||||
"""This method is deprecated. Please switch to GetRootAs."""
|
||||
return cls.GetRootAs(buf, offset)
|
||||
# Vec3
|
||||
def Init(self, buf, pos):
|
||||
def Init(self, buf: bytes, pos: int):
|
||||
self._tab = flatbuffers.table.Table(buf, pos)
|
||||
|
||||
# Vec3
|
||||
@@ -60,62 +63,61 @@ class Vec3(object):
|
||||
return 0
|
||||
|
||||
# Vec3
|
||||
def Test3(self):
|
||||
def Test3(self) -> Optional[Test]:
|
||||
o = flatbuffers.number_types.UOffsetTFlags.py_type(self._tab.Offset(14))
|
||||
if o != 0:
|
||||
x = o + self._tab.Pos
|
||||
from MyGame.Example.NestedUnion.Test import Test
|
||||
obj = Test()
|
||||
obj.Init(self._tab.Bytes, x)
|
||||
return obj
|
||||
return None
|
||||
|
||||
def Vec3Start(builder):
|
||||
return builder.StartObject(6)
|
||||
def Vec3Start(builder: flatbuffers.Builder):
|
||||
builder.StartObject(6)
|
||||
|
||||
def Start(builder):
|
||||
return Vec3Start(builder)
|
||||
def Start(builder: flatbuffers.Builder):
|
||||
Vec3Start(builder)
|
||||
|
||||
def Vec3AddX(builder, x):
|
||||
return builder.PrependFloat64Slot(0, x, 0.0)
|
||||
def Vec3AddX(builder: flatbuffers.Builder, x: float):
|
||||
builder.PrependFloat64Slot(0, x, 0.0)
|
||||
|
||||
def AddX(builder, x):
|
||||
return Vec3AddX(builder, x)
|
||||
def AddX(builder: flatbuffers.Builder, x: float):
|
||||
Vec3AddX(builder, x)
|
||||
|
||||
def Vec3AddY(builder, y):
|
||||
return builder.PrependFloat64Slot(1, y, 0.0)
|
||||
def Vec3AddY(builder: flatbuffers.Builder, y: float):
|
||||
builder.PrependFloat64Slot(1, y, 0.0)
|
||||
|
||||
def AddY(builder, y):
|
||||
return Vec3AddY(builder, y)
|
||||
def AddY(builder: flatbuffers.Builder, y: float):
|
||||
Vec3AddY(builder, y)
|
||||
|
||||
def Vec3AddZ(builder, z):
|
||||
return builder.PrependFloat64Slot(2, z, 0.0)
|
||||
def Vec3AddZ(builder: flatbuffers.Builder, z: float):
|
||||
builder.PrependFloat64Slot(2, z, 0.0)
|
||||
|
||||
def AddZ(builder, z):
|
||||
return Vec3AddZ(builder, z)
|
||||
def AddZ(builder: flatbuffers.Builder, z: float):
|
||||
Vec3AddZ(builder, z)
|
||||
|
||||
def Vec3AddTest1(builder, test1):
|
||||
return builder.PrependFloat64Slot(3, test1, 0.0)
|
||||
def Vec3AddTest1(builder: flatbuffers.Builder, test1: float):
|
||||
builder.PrependFloat64Slot(3, test1, 0.0)
|
||||
|
||||
def AddTest1(builder, test1):
|
||||
return Vec3AddTest1(builder, test1)
|
||||
def AddTest1(builder: flatbuffers.Builder, test1: float):
|
||||
Vec3AddTest1(builder, test1)
|
||||
|
||||
def Vec3AddTest2(builder, test2):
|
||||
return builder.PrependUint8Slot(4, test2, 0)
|
||||
def Vec3AddTest2(builder: flatbuffers.Builder, test2: int):
|
||||
builder.PrependUint8Slot(4, test2, 0)
|
||||
|
||||
def AddTest2(builder, test2):
|
||||
return Vec3AddTest2(builder, test2)
|
||||
def AddTest2(builder: flatbuffers.Builder, test2: int):
|
||||
Vec3AddTest2(builder, test2)
|
||||
|
||||
def Vec3AddTest3(builder, test3):
|
||||
return builder.PrependStructSlot(5, flatbuffers.number_types.UOffsetTFlags.py_type(test3), 0)
|
||||
def Vec3AddTest3(builder: flatbuffers.Builder, test3: Any):
|
||||
builder.PrependStructSlot(5, flatbuffers.number_types.UOffsetTFlags.py_type(test3), 0)
|
||||
|
||||
def AddTest3(builder, test3):
|
||||
return Vec3AddTest3(builder, test3)
|
||||
def AddTest3(builder: flatbuffers.Builder, test3: Any):
|
||||
Vec3AddTest3(builder, test3)
|
||||
|
||||
def Vec3End(builder):
|
||||
def Vec3End(builder: flatbuffers.Builder) -> int:
|
||||
return builder.EndObject()
|
||||
|
||||
def End(builder):
|
||||
def End(builder: flatbuffers.Builder) -> int:
|
||||
return Vec3End(builder)
|
||||
|
||||
import MyGame.Example.NestedUnion.Test
|
||||
|
||||
Reference in New Issue
Block a user