1
0
mirror of https://github.com/ppy/osu.git synced 2024-12-15 16:06:06 +08:00

Further safety checking.

This commit is contained in:
smoogipooo 2017-03-03 15:59:33 +09:00
parent 777996d884
commit 1d1c08125b
3 changed files with 56 additions and 21 deletions

View File

@ -24,6 +24,7 @@ using osu.Framework.Configuration;
using osu.Framework.Graphics.Textures;
using osu.Framework.IO.Stores;
using osu.Framework.Platform;
using osu.Framework.Logging;
namespace osu.Game.Screens.Tournament
{
@ -249,6 +250,8 @@ namespace osu.Game.Screens.Tournament
private void writeResults(string text)
{
Action writeAction = () =>
{
try
{
// Write to drawings_results
using (Stream stream = storage.GetStream(results_filename, FileAccess.Write, FileMode.Create))
@ -256,6 +259,11 @@ namespace osu.Game.Screens.Tournament
{
sw.Write(text);
}
}
catch (Exception ex)
{
Logger.Error(ex, "Failed to write results.");
}
};
if (writeOp == null)
@ -269,6 +277,8 @@ namespace osu.Game.Screens.Tournament
teamsContainer.ClearTeams();
allTeams.Clear();
List<Team> newTeams = new List<Team>();
try
{
using (Stream stream = storage.GetStream(teams_filename, FileAccess.Read, FileMode.Open))
@ -276,32 +286,46 @@ namespace osu.Game.Screens.Tournament
{
while (sr.Peek() != -1)
{
string line = sr.ReadLine();
string line = sr.ReadLine().Trim();
if (string.IsNullOrEmpty(line))
continue;
string[] split = line.Split(':');
if (split.Length < 2)
{
Logger.Log($"Invalid team definition: {line}. Expected \"flag_name : team_name : team_acronym\".");
continue;
}
string flagName = split[0].Trim();
string name = split[1].Trim();
string teamName = split[1].Trim();
string acronym = name.Substring(0, Math.Min(3, name.Length));
if (split.Length >= 3)
acronym = split[2].Trim();
string acronym = split.Length >= 3 ? split[2].Trim() : teamName;
acronym = acronym.Substring(0, Math.Min(3, acronym.Length));
if (groupsContainer.ContainsTeam(name))
if (groupsContainer.ContainsTeam(teamName))
continue;
Team t = new Team()
{
FlagName = flagName,
FullName = name,
FullName = teamName,
Acronym = acronym
};
allTeams.Add(t);
teamsContainer.AddTeam(t);
newTeams.Add(t);
}
}
allTeams = newTeams;
teamsContainer.AddTeams(allTeams);
}
catch (Exception ex)
{
Logger.Error(ex, "Failed to read teams.");
}
catch { }
}
private void reset(bool loadLastResults = false)
@ -310,9 +334,9 @@ namespace osu.Game.Screens.Tournament
reloadTeams();
try
{
if (loadLastResults)
{
try
{
// Read from drawings_results
using (Stream stream = storage.GetStream(results_filename, FileAccess.Read, FileMode.Open))
@ -320,7 +344,7 @@ namespace osu.Game.Screens.Tournament
{
while (sr.Peek() != -1)
{
string line = sr.ReadLine();
string line = sr.ReadLine().Trim();
if (string.IsNullOrEmpty(line))
continue;
@ -338,14 +362,16 @@ namespace osu.Game.Screens.Tournament
}
}
}
catch (Exception ex)
{
Logger.Error(ex, "Failed to read last drawings results.");
}
}
else
{
writeResults(string.Empty);
}
}
catch
{
}
}
}
}

View File

@ -20,7 +20,7 @@ namespace osu.Game.Screens.Tournament
{
public class Group : Container
{
public string GroupName;
public readonly string GroupName;
public int TeamsCount { get; private set; }

View File

@ -163,6 +163,15 @@ namespace osu.Game.Screens.Tournament
scrollState = ScrollState.Idle;
}
public void AddTeams(IEnumerable<Team> teams)
{
if (teams == null)
return;
foreach (Team t in teams)
AddTeam(t);
}
public void ClearTeams()
{
availableTeams.Clear();