-
Notifications
You must be signed in to change notification settings - Fork 22
/
Copy pathmigration.rs
71 lines (61 loc) · 1.94 KB
/
migration.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
//! this example just shows how you can use serde aliases if you rename fields
//!
//! Guess it's more like a serde crash course than an intro to this crate.
//!
//! And it's also a test to show that aliases do work
use bevy::{log::LogPlugin, prelude::*};
use bevy_pkv::PkvStore;
use serde::{Deserialize, Serialize};
#[derive(Serialize, Deserialize)]
struct UserV1 {
nick: String,
favorite_color: String,
}
#[derive(Serialize, Deserialize)]
struct UserV2 {
#[serde(alias = "nick")]
name: String,
#[serde(default = "existing_user_default_quest")]
quest: Quest,
// notice we no longer care about favorite colors
}
fn existing_user_default_quest() -> Quest {
// Assume existing users have already played the tutorial
// and go straight for the holy grail
Quest::SeekHolyGrail
}
#[derive(Serialize, Deserialize, Debug)]
enum Quest {
Tutorial,
SeekHolyGrail,
}
impl Default for Quest {
fn default() -> Self {
Quest::Tutorial
}
}
fn setup(mut pkv: ResMut<PkvStore>) {
// Let's pretend someone has registered with the UserV1 definition
let user_v1 = UserV1 {
nick: "old bob".to_string(),
favorite_color: "beige".to_string(),
};
pkv.set("user", &user_v1)
.expect("failed to store User struct");
// When we serialize with the updated struct with the serde annotations,
// the renamed fields work, and the new fields are assigned values accordingly
let user_v2 = pkv.get::<UserV2>("user").unwrap();
info!("Welcome back {}", user_v2.name);
info!("Current quest: {:?}", user_v2.quest);
}
fn main() {
// When building for WASM, print panics to the browser console
#[cfg(target_arch = "wasm32")]
console_error_panic_hook::set_once();
App::new()
.insert_resource(PkvStore::new("BevyPkv", "MigrationExample"))
.add_plugins(MinimalPlugins)
.add_plugins(LogPlugin::default())
.add_systems(Startup, setup)
.run();
}