From fe8e992bdfbd847840ca13c45958400091ea4261 Mon Sep 17 00:00:00 2001 From: QingQiz Date: Tue, 5 Jul 2022 00:36:18 +0800 Subject: [PATCH] FIX: comma should be escaped in filename when writing to .osu --- BmsToOsu/Converter/Osu.cs | 14 ++-- BmsToOsu/Program.cs | 156 ++++++++++++++++++++++---------------- BmsToOsu/Utils/PathExt.cs | 5 ++ 3 files changed, 101 insertions(+), 74 deletions(-) diff --git a/BmsToOsu/Converter/Osu.cs b/BmsToOsu/Converter/Osu.cs index 9184409..e12ae65 100644 --- a/BmsToOsu/Converter/Osu.cs +++ b/BmsToOsu/Converter/Osu.cs @@ -69,7 +69,7 @@ public static (string, HashSet fileToCp) ToOsuBeatMap( if (!string.IsNullOrEmpty(bg)) { fileToCp.Add(Path.GetFileName(bg)); - bd.AppendLine($"0,0,\"{bg}\",0,0"); + bd.AppendLine($"0,0,\"{bg.Escape()}\",0,0"); } // bga @@ -103,12 +103,12 @@ public static (string, HashSet fileToCp) ToOsuBeatMap( if (vExt is not (".wmv" or ".mpg" or ".avi" or ".mp4" or ".webm" or ".mkv")) { - bd.AppendLine($"Sprite,{layer},CentreRight,\"{bga.File}\",600,240"); + bd.AppendLine($"Sprite,{layer},CentreRight,\"{bga.File.Escape()}\",600,240"); bd.AppendLine($" F,0,{(int)bga.StartTime},{(int)endTime},1"); } else { - bd.AppendLine($"Video,{(int)bga.StartTime},\"{bga.File}\""); + bd.AppendLine($"Video,{(int)bga.StartTime},\"{bga.File.Escape()}\""); } if (!string.IsNullOrEmpty(bga.File)) fileToCp.Add(bga.File); @@ -117,7 +117,7 @@ public static (string, HashSet fileToCp) ToOsuBeatMap( // sound effect foreach (var sfx in data.SoundEffects) { - bd.AppendLine($"Sample,{(int)sfx.StartTime},0,\"{sfx.SoundFile}\",100"); + bd.AppendLine($"Sample,{(int)sfx.StartTime},0,\"{sfx.SoundFile.Escape()}\",100"); fileToCp.Add(sfx.SoundFile); } @@ -126,7 +126,7 @@ public static (string, HashSet fileToCp) ToOsuBeatMap( { foreach (var hitObj in data.HitObject.Values.SelectMany(obj => obj)) { - bd.AppendLine($"Sample,{(int)hitObj.StartTime},0,\"{hitObj.HitSoundFile}\",100"); + bd.AppendLine($"Sample,{(int)hitObj.StartTime},0,\"{hitObj.HitSoundFile.Escape()}\",100"); } } @@ -182,8 +182,8 @@ public static (string, HashSet fileToCp) ToOsuBeatMap( bd.AppendLine( obj.IsLongNote - ? $"{xPos},192,{(int)obj.StartTime},{objType},0,{(int)obj.EndTime}:0:0:0:0:{hitSound}" - : $"{xPos},192,{(int)obj.StartTime},{1 << 0},0,0:0:0:0:{hitSound}"); + ? $"{xPos},192,{(int)obj.StartTime},{objType},0,{(int)obj.EndTime}:0:0:0:0:{hitSound.Escape()}" + : $"{xPos},192,{(int)obj.StartTime},{1 << 0},0,0:0:0:0:{hitSound.Escape()}"); } } diff --git a/BmsToOsu/Program.cs b/BmsToOsu/Program.cs index b2abd1e..d92b746 100644 --- a/BmsToOsu/Program.cs +++ b/BmsToOsu/Program.cs @@ -2,7 +2,9 @@ using BmsToOsu; using BmsToOsu.Converter; using BmsToOsu.Entity; +using BmsToOsu.Utils; using CommandLine; +using CommandLine.Text; using log4net; Logger.Config(); @@ -14,91 +16,111 @@ ".bms", ".bml", ".bme", ".bmx" }; -Parser.Default.ParseArguments