1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-12 18:23:04 +08:00

Refactor realm migrations to be a touch more legible

This commit is contained in:
Dean Herbert 2021-11-04 18:39:23 +09:00
parent 777b2cbcc4
commit 7acc4a4708

View File

@ -152,73 +152,82 @@ namespace osu.Game.Database
private void onMigration(Migration migration, ulong lastSchemaVersion) private void onMigration(Migration migration, ulong lastSchemaVersion)
{ {
if (lastSchemaVersion < 9) for (ulong i = lastSchemaVersion; i <= schema_version; i++)
applyMigrationsForVersion(migration, i);
}
private void applyMigrationsForVersion(Migration migration, ulong version)
{
switch (version)
{ {
// Pretty pointless to do this as beatmaps aren't really loaded via realm yet, but oh well. case 7:
string className = nameof(RealmBeatmapMetadata).Replace(@"Realm", string.Empty); convertOnlineIDs<RealmBeatmap>();
convertOnlineIDs<RealmBeatmapSet>();
convertOnlineIDs<RealmRuleset>();
var oldItems = migration.OldRealm.DynamicApi.All(className); void convertOnlineIDs<T>() where T : RealmObject
var newItems = migration.NewRealm.All<RealmBeatmapMetadata>();
int itemCount = newItems.Count();
for (int i = 0; i < itemCount; i++)
{
dynamic? oldItem = oldItems.ElementAt(i);
var newItem = newItems.ElementAt(i);
string username = oldItem.Author;
newItem.Author = new RealmUser
{ {
Username = username string className = typeof(T).Name.Replace(@"Realm", string.Empty);
};
}
}
if (lastSchemaVersion < 8) // version was not bumped when the beatmap/ruleset models were added
{ // therefore we must manually check for their presence to avoid throwing on the `DynamicApi` calls.
// Ctrl -/+ now adjusts UI scale so let's clear any bindings which overlap these combinations. if (!migration.OldRealm.Schema.TryFindObjectSchema(className, out _))
// New defaults will be populated by the key store afterwards. return;
var keyBindings = migration.NewRealm.All<RealmKeyBinding>();
var increaseSpeedBinding = keyBindings.FirstOrDefault(k => k.ActionInt == (int)GlobalAction.IncreaseScrollSpeed); var oldItems = migration.OldRealm.DynamicApi.All(className);
if (increaseSpeedBinding != null && increaseSpeedBinding.KeyCombination.Keys.SequenceEqual(new[] { InputKey.Control, InputKey.Plus })) var newItems = migration.NewRealm.DynamicApi.All(className);
migration.NewRealm.Remove(increaseSpeedBinding);
var decreaseSpeedBinding = keyBindings.FirstOrDefault(k => k.ActionInt == (int)GlobalAction.DecreaseScrollSpeed); int itemCount = newItems.Count();
if (decreaseSpeedBinding != null && decreaseSpeedBinding.KeyCombination.Keys.SequenceEqual(new[] { InputKey.Control, InputKey.Minus }))
migration.NewRealm.Remove(decreaseSpeedBinding);
}
if (lastSchemaVersion < 7) for (int i = 0; i < itemCount; i++)
{ {
convertOnlineIDs<RealmBeatmap>(); dynamic? oldItem = oldItems.ElementAt(i);
convertOnlineIDs<RealmBeatmapSet>(); dynamic? newItem = newItems.ElementAt(i);
convertOnlineIDs<RealmRuleset>();
void convertOnlineIDs<T>() where T : RealmObject long? nullableOnlineID = oldItem?.OnlineID;
{ newItem.OnlineID = (int)(nullableOnlineID ?? -1);
string className = typeof(T).Name.Replace(@"Realm", string.Empty); }
}
// version was not bumped when the beatmap/ruleset models were added break;
// therefore we must manually check for their presence to avoid throwing on the `DynamicApi` calls.
if (!migration.OldRealm.Schema.TryFindObjectSchema(className, out _)) case 8:
return; // Ctrl -/+ now adjusts UI scale so let's clear any bindings which overlap these combinations.
// New defaults will be populated by the key store afterwards.
var keyBindings = migration.NewRealm.All<RealmKeyBinding>();
var increaseSpeedBinding = keyBindings.FirstOrDefault(k => k.ActionInt == (int)GlobalAction.IncreaseScrollSpeed);
if (increaseSpeedBinding != null && increaseSpeedBinding.KeyCombination.Keys.SequenceEqual(new[] { InputKey.Control, InputKey.Plus }))
migration.NewRealm.Remove(increaseSpeedBinding);
var decreaseSpeedBinding = keyBindings.FirstOrDefault(k => k.ActionInt == (int)GlobalAction.DecreaseScrollSpeed);
if (decreaseSpeedBinding != null && decreaseSpeedBinding.KeyCombination.Keys.SequenceEqual(new[] { InputKey.Control, InputKey.Minus }))
migration.NewRealm.Remove(decreaseSpeedBinding);
break;
case 9:
// Pretty pointless to do this as beatmaps aren't really loaded via realm yet, but oh well.
string className = nameof(RealmBeatmapMetadata).Replace(@"Realm", string.Empty);
var oldItems = migration.OldRealm.DynamicApi.All(className); var oldItems = migration.OldRealm.DynamicApi.All(className);
var newItems = migration.NewRealm.DynamicApi.All(className); var newItems = migration.NewRealm.All<RealmBeatmapMetadata>();
int itemCount = newItems.Count(); int itemCount = newItems.Count();
for (int i = 0; i < itemCount; i++) for (int i = 0; i < itemCount; i++)
{ {
dynamic? oldItem = oldItems.ElementAt(i); dynamic? oldItem = oldItems.ElementAt(i);
dynamic? newItem = newItems.ElementAt(i); var newItem = newItems.ElementAt(i);
long? nullableOnlineID = oldItem?.OnlineID; string username = oldItem.Author;
newItem.OnlineID = (int)(nullableOnlineID ?? -1); newItem.Author = new RealmUser
{
Username = username
};
} }
}
break;
} }
} }