#ecs #gamedev #component #graph #programming #performance #prototype

froggy

Froggy is a prototype for the Component Graph System programming model. It aims to combine the convenience of composition-style Object-Oriented Programming with the performance close to Entity-Component Systems

9 unstable releases (3 breaking)

Uses old Rust 2015

0.4.4 Oct 25, 2017
0.4.2 Oct 25, 2017
0.4.1 Sep 11, 2017
0.4.0 Aug 28, 2017
0.1.1 Feb 13, 2017

#2098 in Data structures

Download history 69/week @ 2024-03-13 73/week @ 2024-03-20 70/week @ 2024-03-27 249/week @ 2024-04-03 65/week @ 2024-04-10 77/week @ 2024-04-17 77/week @ 2024-04-24 59/week @ 2024-05-01 69/week @ 2024-05-08 59/week @ 2024-05-15 54/week @ 2024-05-22 69/week @ 2024-05-29 56/week @ 2024-06-05 51/week @ 2024-06-12 58/week @ 2024-06-19 40/week @ 2024-06-26

216 downloads per month
Used in 2 crates

MIT/Apache

32KB
596 lines

froggy

Build Status Docs Crates.io Gitter

Froggy is a prototype for Component Graph System. Froggy is not an ECS (it could as well be named "finecs" but then it would have "ecs" in the name... yikes)! Give it a try if:

  • you are open to new paradigms and programming models
  • you are tired of being forced to think in terms of ECS
  • you like simple composable things

Check ecs_bench for performance comparisons with actual ECS systems.

Example

extern crate froggy;

fn main() {
    let mut positions = froggy::Storage::new();
    // create entities
    let entities = vec![
        positions.create(1u8), positions.create(4u8), positions.create(9u8)
    ];
    // update positions
    for e in &entities {
        positions[e] += 1;
    }
}

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~160KB