9 releases

0.0.17-dev Oct 24, 2024
0.0.16 Oct 22, 2024
0.0.13-dev Sep 23, 2024

#2455 in Game dev

MIT license

78KB
966 lines

Nimble

Crates.io Documentation

Welcome to the nimble-rust crate! This combined crate brings together the core components of the Nimble ecosystem for building deterministic networked game simulations.

Nimble intentionally has no built in support for authentication, encryption, verify datagrams or provide rate limiting. The reason is that most game platform and relay service already provide that, e.g. Steam Datagram Relay.

🎮 What’s Inside?

  • nimble-client: The nimble client for receiving game state updates, sending steps and receiving authoritative steps.
  • nimble-host: The nimble host for authoritative game state management and authoritative steps.

Transport layers

If you are on a transport layer that is lacking in hash-verification or do not provide challenge-response, or you just need it for testing purposes, you can use:

  • datagram-connections: Challenge response connections. Can be good for testing locally over UDP or similar.

  • connection-layer: Verify hash on each datagram. Can be good if you have a transport (relay service), but that transport does not have a connection-layer or that connection-layer may may cache or reuse previous connections.

Internet Simulator

  • hazy-transport: It is strongly recommended that you test your game using a internet simulator. This is a basic, but very useful one. Supports varying latency, packet drops and reordering.

📦 Installation

To include nimble-rust in your project, add the following to your Cargo.toml:

[dependencies]
nimble-rust = "0.0.17-dev"

License

This project is licensed under the MIT License - see the LICENSE file for details.

Dependencies

~595KB
~10K SLoC