Skip to content

Latest commit

 

History

History
149 lines (112 loc) · 4.3 KB

README.md

File metadata and controls

149 lines (112 loc) · 4.3 KB

Tech Paws Buffer Generator

Overview

Tech Paws Buffer Generator is a code generator for Tech Paws Buffers, a protocol similar to gRPC but designed to replace FFI (Foreign Function Interface). It establishes lightweight yet fast communication between different programming languages, offering a richer type system and signal RPC methods.

Currently, Rust serves as the primary language implementing core features. This allows developers to create functions in Rust and execute them in other languages such as Dart, Swift, or Kotlin.

Project Status

Current Stage: Pre-Alpha

Tech Paws Buffer Generator is currently in the pre-alpha stage of development and is designed for internal use within the Tech.Paws project. Key points to note:

  • The project is in early development and not yet ready for public use.
  • The runtime for Tech Paws Buffer Generator is not yet publicly available.
  • This tool is specifically designed and currently limited to internal use within the Tech.Paws project.
  • The core functionality is under active development.
  • The API and features are subject to change.
  • It may contain bugs and is not suitable for production use outside of its intended internal context.

We are sharing this repository for transparency and to provide insight into our development process. However, please be aware that:

  • External contributions are not being accepted at this time.
  • The project may not be immediately usable or fully functional for those outside the Tech.Paws project.
  • Documentation and support are primarily geared towards internal developers.

We appreciate your interest in the project. As it evolves, we may expand its scope and availability. Please check back for updates on its status and potential future public releases.

Models Example

Tech Paws Buffer Generator supports various data structures and types. Here's an example of the models you can define:

struct BasicTypesModel {
    byte: u8,
    some_integer: i32,
    some_long: i64,
    some_unsiged_integer: u32,
    some_unsiged_long: u32,
    some_float_number: f32,
    some_double_number: f64,
    some_bool: bool,
    some_string: String,
    vector: Vec<String>,
    generic: LinearTable<f32, Test>,
    custom: MyModel,
    optional_string: Option<String>,
    optional_f32: Option<f32>,
}

enum MyEnum {
    #[1] Idle,
    #[2] Move {
        #[1] x: f64,
        #[2] y: f64,
    },
    #[3] Update(#[1] f64, #[2] f64, #[4] String),
}

enum MyEnumWithoutPositions {
    Option1(u64),
    Option2 { name: String },
    Option3,
    Option4,
}

enum MyEnumWithManyArguments {
    Option1(u64, u64, u64),
    Option2 { name: String },
    Option3,
    Option4,
}

enum MyEnumWithNamedArguments {
    Option1 {
        name: String,
        value: f32,
        bytes: Vec<u8>
    },
    Option2(u64, u64, u64),
    Option3,
    Option4,
}

RPC Example

Tech Paws Buffer Generator supports defining RPC methods, providing an efficient alternative to FFI function calls. Here's an example:

#[id = "ee61593c-4ac8-43db-ac01-d5170eb5d1ab"]
#[namespace = "rpc_examples"]

#[rust(use = "crate::rpc_examples::*")]

fn print_hello_world();

fn hello_world() -> String;

fn say_hello(first_name: String, last_name: String) -> String;

fn sum(a: i32, b: f32, c: f64) -> f64;

signal counter_stream -> i32;

Emplace Example

The emplace functionality is designed to significantly reduce GC memory allocations by using a pool of objects. This is particularly useful in real-time contexts. Here's an example of how to use it:

#[id = "7b6d3210-e963-47bd-8c3f-77d6156f49f9"]
#[namespace = "rpc_emplace_examples"]

#[rust(use = "crate::rpc_examples::*")]

#[memory(emplace)]
enum RenderCommand {
    Svg {
        id: u64,
        x: f32,
        y: f32,
        width: f32,
        height: f32,
    },
    DrawLines {
        line_width: f32,
        points: Vec<Position2D>,
    },
}

#[memory(emplace, copy)]
struct Position2D {
    x: f32,
    y: f32,
}

#[memory(emplace)]
signal render_commands -> Vec<RenderCommand>;

Contributing

As this is an internal project for Tech.Paws, we are not accepting external contributions at this time. If you are a member of the Tech.Paws team, please refer to our internal contributing guidelines.

License

Licensed under the Apache License 2.0. (LICENSE or http://www.apache.org/licenses/LICENSE-2.0)