From 58086c3476462f32af36cb7df424d8b8ad2d5abb Mon Sep 17 00:00:00 2001 From: andy840119 Date: Sat, 30 Jul 2022 17:54:08 +0800 Subject: [PATCH] Use deep clone instead of copy the property in the utils. --- .../Utils/LyricsUtils.cs | 34 +++++++------------ 1 file changed, 13 insertions(+), 21 deletions(-) diff --git a/osu.Game.Rulesets.Karaoke/Utils/LyricsUtils.cs b/osu.Game.Rulesets.Karaoke/Utils/LyricsUtils.cs index 545feb0b2..b3211bd34 100644 --- a/osu.Game.Rulesets.Karaoke/Utils/LyricsUtils.cs +++ b/osu.Game.Rulesets.Karaoke/Utils/LyricsUtils.cs @@ -60,28 +60,20 @@ public static Tuple SplitLyric(Lyric lyric, int splitIndex) } } - var firstLyric = new Lyric - { - Text = lyric.Text[..splitIndex], - TimeTags = firstTimeTag.ToArray(), - RubyTags = lyric.RubyTags.Where(x => x.StartIndex < splitIndex && x.EndIndex <= splitIndex).ToArray(), - RomajiTags = lyric.RomajiTags.Where(x => x.StartIndex < splitIndex && x.EndIndex <= splitIndex).ToArray(), - // todo : should implement time and duration - Singers = lyric.Singers, - Language = lyric.Language, - }; - + // todo : should implement time and duration + var firstLyric = lyric.DeepClone(); + firstLyric.Text = lyric.Text[..splitIndex]; + firstLyric.TimeTags = firstTimeTag.ToArray(); + firstLyric.RubyTags = lyric.RubyTags.Where(x => x.StartIndex < splitIndex && x.EndIndex <= splitIndex).ToArray(); + firstLyric.RomajiTags = lyric.RomajiTags.Where(x => x.StartIndex < splitIndex && x.EndIndex <= splitIndex).ToArray(); + + // todo : should implement time and duration string secondLyricText = lyric.Text[splitIndex..]; - var secondLyric = new Lyric - { - Text = secondLyricText, - TimeTags = shiftingTimeTag(secondTimeTag.ToArray(), -splitIndex), - RubyTags = shiftingTextTag(lyric.RubyTags.Where(x => x.StartIndex >= splitIndex && x.EndIndex > splitIndex).ToArray(), secondLyricText, -splitIndex), - RomajiTags = shiftingTextTag(lyric.RomajiTags.Where(x => x.StartIndex >= splitIndex && x.EndIndex > splitIndex).ToArray(), secondLyricText, -splitIndex), - // todo : should implement time and duration - Singers = lyric.Singers, - Language = lyric.Language, - }; + var secondLyric = lyric.DeepClone(); + secondLyric.Text = secondLyricText; + secondLyric.TimeTags = shiftingTimeTag(secondTimeTag.ToArray(), -splitIndex); + secondLyric.RubyTags = shiftingTextTag(lyric.RubyTags.Where(x => x.StartIndex >= splitIndex && x.EndIndex > splitIndex).ToArray(), secondLyricText, -splitIndex); + secondLyric.RomajiTags = shiftingTextTag(lyric.RomajiTags.Where(x => x.StartIndex >= splitIndex && x.EndIndex > splitIndex).ToArray(), secondLyricText, -splitIndex); return new Tuple(firstLyric, secondLyric); }