1
0
mirror of https://github.com/ppy/osu.git synced 2024-09-22 16:07:25 +08:00
osu-lazer/osu.Game/Input/KeyBindingStore.cs

79 lines
3.0 KiB
C#
Raw Normal View History

2017-08-09 14:15:41 +08:00
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
using System;
using System.Collections.Generic;
using System.Linq;
2017-10-05 03:52:12 +08:00
using Microsoft.EntityFrameworkCore;
using osu.Framework.Input.Bindings;
using osu.Framework.Platform;
using osu.Game.Database;
2017-08-11 15:11:46 +08:00
using osu.Game.Input.Bindings;
using osu.Game.Rulesets;
namespace osu.Game.Input
{
public class KeyBindingStore : DatabaseBackedStore
{
2017-10-05 03:52:12 +08:00
public KeyBindingStore(OsuDbContext connection, RulesetStore rulesets, Storage storage = null)
: base(connection, storage)
{
2017-08-20 04:07:03 +08:00
foreach (var info in rulesets.AllRulesets)
{
var ruleset = info.CreateInstance();
foreach (var variant in ruleset.AvailableVariants)
2017-10-14 13:28:25 +08:00
insertDefaults(ruleset.GetDefaultKeyBindings(variant), info.ID, variant);
}
}
2017-08-16 16:34:49 +08:00
public void Register(KeyBindingInputManager manager) => insertDefaults(manager.DefaultKeyBindings);
protected override void Prepare(bool reset = false)
{
2017-10-05 03:52:12 +08:00
Connection.Database.ExecuteSqlCommand("DELETE FROM KeyBinding");
}
private void insertDefaults(IEnumerable<KeyBinding> defaults, int? rulesetId = null, int? variant = null)
{
// compare counts in database vs defaults
foreach (var group in defaults.GroupBy(k => k.Action))
{
int count;
2017-10-05 03:52:12 +08:00
while (group.Count() > (count = Query(rulesetId, variant).Count(k => (int)k.Action == (int)group.Key)))
{
var insertable = group.Skip(count).First();
// insert any defaults which are missing.
2017-10-05 03:52:12 +08:00
Connection.DatabasedKeyBinding.Add(new DatabasedKeyBinding
{
KeyCombination = insertable.KeyCombination,
2017-08-16 16:27:09 +08:00
Action = insertable.Action,
2017-10-14 13:28:25 +08:00
RulesetID = rulesetId,
Variant = variant
});
2017-10-05 03:52:12 +08:00
Connection.SaveChanges();
}
}
}
protected override Type[] ValidTypes => new[]
{
typeof(DatabasedKeyBinding)
};
2017-10-05 03:52:12 +08:00
public List<KeyBinding> Query(int? rulesetId = null, int? variant = null) =>
2017-10-14 13:28:25 +08:00
new List<KeyBinding>(Connection.DatabasedKeyBinding.Where(b => b.RulesetID == rulesetId && b.Variant == variant));
2017-10-05 03:52:12 +08:00
public void Update(KeyBinding keyBinding)
{
var dbKeyBinding = Connection.DatabasedKeyBinding.FirstOrDefault(kb => kb.ToString() == keyBinding.ToString());
2017-10-16 12:11:35 +08:00
if (dbKeyBinding != null)
2017-10-05 03:52:12 +08:00
{
dbKeyBinding.KeyCombination = keyBinding.KeyCombination;
dbKeyBinding.Action = keyBinding.Action;
}
Connection.SaveChanges();
}
}
}