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

Strip comments from everything except metadata

This commit is contained in:
morguldir 2018-07-16 01:04:41 +02:00
parent a9f8c2acb8
commit 6c861a1638
4 changed files with 24 additions and 11 deletions

View File

@ -62,32 +62,34 @@ namespace osu.Game.Beatmaps.Formats
protected override void ParseLine(Beatmap beatmap, Section section, string line)
{
var stripped_line = StripComments(line);
switch (section)
{
case Section.General:
handleGeneral(line);
handleGeneral(stripped_line);
return;
case Section.Editor:
handleEditor(line);
handleEditor(stripped_line);
return;
case Section.Metadata:
handleMetadata(line);
return;
case Section.Difficulty:
handleDifficulty(line);
handleDifficulty(stripped_line);
return;
case Section.Events:
handleEvent(line);
handleEvent(stripped_line);
return;
case Section.TimingPoints:
handleTimingPoint(line);
handleTimingPoint(stripped_line);
return;
case Section.HitObjects:
handleHitObject(line);
handleHitObject(stripped_line);
return;
}
base.ParseLine(beatmap, section, line);
base.ParseLine(beatmap, section, stripped_line);
}
private void handleGeneral(string line)

View File

@ -58,6 +58,8 @@ namespace osu.Game.Beatmaps.Formats
protected virtual void ParseLine(T output, Section section, string line)
{
line = StripComments(line);
switch (section)
{
case Section.Colours:
@ -65,6 +67,13 @@ namespace osu.Game.Beatmaps.Formats
return;
}
}
internal string StripComments(string line)
{
var index = line.IndexOf("//");
if (index > 0)
return line.Substring(0, index);
return line;
}
private bool hasComboColours;
@ -74,12 +83,10 @@ namespace osu.Game.Beatmaps.Formats
bool isCombo = pair.Key.StartsWith(@"Combo");
line = Regex.Replace(pair.Value, "[^0-9,]", "");
string[] split = line.Split(',');
string[] split = pair.Value.Split(',');
if (split.Length != 3)
throw new InvalidOperationException($@"Color specified in incorrect format (should be R,G,B): {line}");
throw new InvalidOperationException($@"Color specified in incorrect format (should be R,G,B): {pair.Value}");
if (!byte.TryParse(split[0], out var r) || !byte.TryParse(split[1], out var g) || !byte.TryParse(split[2], out var b))
throw new InvalidOperationException(@"Color must be specified with 8-bit integer components");

View File

@ -42,6 +42,8 @@ namespace osu.Game.Beatmaps.Formats
protected override void ParseLine(Storyboard storyboard, Section section, string line)
{
line = StripComments(line);
switch (section)
{
case Section.Events:

View File

@ -14,6 +14,8 @@ namespace osu.Game.Skinning
protected override void ParseLine(SkinConfiguration skin, Section section, string line)
{
line = StripComments(line);
switch (section)
{
case Section.General: