1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-26 12:45:09 +08:00

Underscore + lowercase all keys

This commit is contained in:
smoogipoo 2017-12-07 14:36:32 +09:00
parent dfc10d42e8
commit 245b5f759f
5 changed files with 28 additions and 10 deletions

View File

@ -45,13 +45,13 @@ namespace osu.Game.IO.Serialization.Converters
var obj = JObject.Load(reader);
var lookupTable = new List<string>();
serializer.Populate(obj["LookupTable"].CreateReader(), lookupTable);
serializer.Populate(obj["lookup_table"].CreateReader(), lookupTable);
foreach (var tok in obj["Items"])
foreach (var tok in obj["items"])
{
var itemReader = tok.CreateReader();
var typeName = lookupTable[(int)tok["Type"]];
var typeName = lookupTable[(int)tok["type"]];
var instance = (T)Activator.CreateInstance(Type.GetType(typeName));
serializer.Populate(itemReader, instance);
@ -84,16 +84,16 @@ namespace osu.Game.IO.Serialization.Converters
}
var itemObject = JObject.FromObject(item, serializer);
itemObject.AddFirst(new JProperty("Type", typeId));
itemObject.AddFirst(new JProperty("type", typeId));
objects.Add(itemObject);
}
writer.WriteStartObject();
writer.WritePropertyName("LookupTable");
writer.WritePropertyName("lookup_table");
serializer.Serialize(writer, lookupTable);
writer.WritePropertyName("Items");
writer.WritePropertyName("items");
serializer.Serialize(writer, objects);
writer.WriteEndObject();

View File

@ -18,7 +18,7 @@ namespace osu.Game.IO.Serialization.Converters
public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
{
var obj = JObject.Load(reader);
return new Vector2((float)obj["X"], (float)obj["Y"]);
return new Vector2((float)obj["x"], (float)obj["y"]);
}
public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
@ -27,9 +27,9 @@ namespace osu.Game.IO.Serialization.Converters
writer.WriteStartObject();
writer.WritePropertyName("X");
writer.WritePropertyName("x");
writer.WriteValue(vector.X);
writer.WritePropertyName("Y");
writer.WritePropertyName("y");
writer.WriteValue(vector.Y);
writer.WriteEndObject();

View File

@ -30,7 +30,8 @@ namespace osu.Game.IO.Serialization
Formatting = Formatting.Indented,
ObjectCreationHandling = ObjectCreationHandling.Replace,
DefaultValueHandling = DefaultValueHandling.IgnoreAndPopulate,
Converters = new JsonConverter[] { new Vector2Converter() }
Converters = new JsonConverter[] { new Vector2Converter() },
ContractResolver = new KeyContractResolver()
};
}
}

View File

@ -0,0 +1,16 @@
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
using Humanizer;
using Newtonsoft.Json.Serialization;
namespace osu.Game.IO.Serialization
{
public class KeyContractResolver : DefaultContractResolver
{
protected override string ResolvePropertyName(string propertyName)
{
return propertyName.Underscore();
}
}
}

View File

@ -272,6 +272,7 @@
<Compile Include="Graphics\UserInterface\HoverClickSounds.cs" />
<Compile Include="Graphics\UserInterface\HoverSounds.cs" />
<Compile Include="Graphics\UserInterface\OsuButton.cs" />
<Compile Include="IO\Serialization\KeyContractResolver.cs" />
<Compile Include="Migrations\20171019041408_InitialCreate.cs" />
<Compile Include="Migrations\20171019041408_InitialCreate.Designer.cs">
<DependentUpon>20171019041408_InitialCreate.cs</DependentUpon>