bevy_pkv
bevy_pkv is a cross-platform persistent key value store for rust apps.
Use it for storing things like settings, save games etc.
Currently, the Bevy dependency is optional, so it may be used in other games/apps as well.
Usage with Bevy
Add a store resource to your app
#
This will create or load a store in the appropriate location for your system, and make it available to bevy systems:
Using Custom Types
You can also store and retrieve your own types that implement serde::Serialize and Deserialize:
Persistent Resources
For resources that should automatically persist when they change, use the convenient init_persistent_resource API:
use *;
use *;
use ;
new
.add_plugins
.insert_resource
.
.run;
This automatically loads the resource from storage on startup and saves it whenever it changes!
See the examples for further usage
Usage without Bevy
Disable the default features when adding the dependency:
= { = "0.9", = false}
Implementation details
Native
redb and rmp_serde (MessagePack) is used for storage. It's creating a bevy_pkv.redb db in the appropriate application data directory for your system.
Alternatively, disable default-features and enable the rocksdb feature to use a RocksDB-based implementation or sled feature to use sled db.
Wasm
Window.localStorage and serde_json is used for storage. Perhaps IndexedDb and something else would have been a better choice, but its API is complicated, and I wanted a simple implementation and a simple synchronous API.
Bevy version support
The main branch targets the latest bevy release.
| bevy | bevy_pkv |
|---|---|
| 0.17 | 0.14, main |
| 0.16 | 0.13 |
| 0.15 | 0.12 |
| 0.14 | 0.11 |
| 0.13 | 0.10 |
| 0.12 | 0.9 |
| 0.11 | 0.8 |
| 0.10 | 0.7 |
| 0.9 | 0.6 |
| 0.8 | 0.5 |
| 0.7 | 0.2, 0.3, 0.4 |
| 0.6 | 0.1 |
License
MIT or Apache-2.0