Skip to content

Latest commit

 

History

History
40 lines (30 loc) · 1.88 KB

README.md

File metadata and controls

40 lines (30 loc) · 1.88 KB

Tachibana

A work-in-progress 2D game framework purely written in the Rust programming language.

It adopts a model similar to osu!framework and Flutter, where widgets parent other widgets to build user interfaces. It also uses layout rules inspired from Godot.

A few noteworthy features:

  • Lazy layout and sizing
  • Separate threads for game logic and rendering
  • No sweeping garbage collector
  • Absolute memory safety
  • Short compile times (3-5 seconds on a modern Linux machine)

Current state

For graphics, Tachibana utilises Skia with Vulkan. Only Immediate present mode works well for now, Mailbox/Fifo introduces a very noticeable delay and a fix is unplanned.

Audio is a work-in-progress effort, entirely based on GStreamer.

The repository currently contains both a binary and a library. The binary crate is the example code for now. To run it, execute cargo run --release.

Compiling

This project depends on SDL2 and GStreamer. When all these build dependencies are in place, compiling is simply cargo build --release.

Linux

Any nightly Rust toolchain should work. Run the following command on Debian-based systems to install SDL2 & GStreamer.

$ apt-get install libsdl2-dev libgstreamer1.0-dev \
      libgstreamer-plugins-base1.0-dev gstreamer1.0-plugins-base \
      gstreamer1.0-plugins-good gstreamer1.0-plugins-bad \
      gstreamer1.0-plugins-ugly gstreamer1.0-libav libgstrtspserver-1.0-dev

When shipping your applications, remember to include the SDL2 and GStreamer dynamic libraries.

Windows

Nightly MSVC toolchain is required. Follow the sdl2 and gstreamer crates' instructions on how to install dependencies.

License

This project is unencumbered into the public domain. See LICENSE for more details.

Contributing

This repository is actively reviewing and accepting pull requests & issues, especially those that improve performance and code quality.