mirror of
https://github.com/ppy/osu.git
synced 2025-01-12 21:52:55 +08:00
Refactor realm migrations to be a touch more legible
This commit is contained in:
parent
777b2cbcc4
commit
7acc4a4708
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user