Skip to main content

A Python module implemented in Rust for serializing and deserializing RLBot's flatbuffers

Project description

rlbot-flatbuffers-py

A Python module implemented in Rust for serializing and deserializing RLBot's flatbuffers

The goal of this project

To provide a fast, safe, and easy to use Python module for serializing and deserializing RLBot's flatbuffers.

A majority of the code is generated in the codegen/ upon first compile and thrown into src/python.

This includes the code generated by flatc (living in src/generated), the Python wrapper binds to the generated Rust code, and the Python type hints (rlbot_flatbuffers.pyi).

Basic usage

All classes and methods should have types hints readable by your IDE, removing the guesswork of common operations.

Creating

import rlbot_flatbuffers as flat

desired_ball = flat.DesiredBallState(
    physics=flat.Physics(
        location=flat.Vector3Partial(z=200),
        velocity=flat.Vector3Partial(x=1500, y=1500),
        angular_velocity=flat.Vector3Partial(),
    ),
)

desired_game_info = flat.DesiredGameInfoState(
    world_gravity_z=-100,
    game_speed=2,
)

desired_game_state = flat.DesiredGameState(
    ball_state=desired_ball,
    game_info_state=desired_game_info,
)

In the above code, we:

  • Set the ball to:
    • Location (0, 0, 200)
    • Velocity (1500, 1500, 0)
    • Angular velocity of (0, 0, 0)
  • Don't set the car states
  • Set the game info state:
    • World gravity to -100
    • Game speed to 2x default
    • Don't set end match or paused
  • Don't set any console commands

All values are optional when creating a class and have the proper defaults.

Reading values

import rlbot_flatbuffers as flat

def handle_packet(packet: flat.GameTickPacket):
    if packet.game_info.game_state_type not in {
        flat.GameStateType.Active,
        flat.GameStateType.Kickoff,
    }:
        # Return early if the game isn't active
        return

    # Print the ball's location
    print(packet.ball.physics.location)

    for car in packet.players:
        # Print the every car's location
        print(car.physics.location)

The goal of the above was to feel familiar to RLBot v4 while providing a more Pythonic interface.

  • All classes (not enums and unions) implement __match_args__ for easy destructuring via the match/case pattern.
    • Enums and unions and can still be used to match against the type, they just can't be destructured.
  • Every class implements __str__, __repr__, and __hash__ methods.
    • All enums also implement __int__ and __eq__.
  • Lists no longer have num_x fields accompanying them, they are just Python lists of the appropriate length.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

rlbot_flatbuffers-0.9.1.tar.gz (3.9 MB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

rlbot_flatbuffers-0.9.1-cp310-abi3-win_amd64.whl (489.5 kB view details)

Uploaded CPython 3.10+Windows x86-64

rlbot_flatbuffers-0.9.1-cp310-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (616.4 kB view details)

Uploaded CPython 3.10+manylinux: glibc 2.17+ x86-64

File details

Details for the file rlbot_flatbuffers-0.9.1.tar.gz.

File metadata

  • Download URL: rlbot_flatbuffers-0.9.1.tar.gz
  • Upload date:
  • Size: 3.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: maturin/1.7.1

File hashes

Hashes for rlbot_flatbuffers-0.9.1.tar.gz
Algorithm Hash digest
SHA256 ef1f7fb560c9aff5cac198a3844f6494ae66c983c7fdf2e8f0d30a2f6ff8696a
MD5 a416e9eaedd170fa3ea492818d96b2ef
BLAKE2b-256 d5cd42aa2c815d0d1b0c2ea26d04ec46050001b33a44bc19c4bc38672b60b636

See more details on using hashes here.

File details

Details for the file rlbot_flatbuffers-0.9.1-cp310-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for rlbot_flatbuffers-0.9.1-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 cbbaffc193594f806285ccaa85fe9df9ae6efef9ac207c3c61483fb7843dbedb
MD5 dc2eac20d50ca962f855a9168604945e
BLAKE2b-256 c40863673d3dac325e4c1c440276d3e6133d2a88b53a6e8798bf33f35975c9e9

See more details on using hashes here.

File details

Details for the file rlbot_flatbuffers-0.9.1-cp310-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for rlbot_flatbuffers-0.9.1-cp310-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 6b3c75c4a5c38893f5b39d0a8b16825eec9c9372ec06f5feb35aae78817e8c4e
MD5 da98f894bcf426f21df8263efd7ba1d1
BLAKE2b-256 72621cf589025015c7c198b3a18078a98f011eee2d8fbfbfae9e4fdb32ad12a6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page