You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
94 lines
3.2 KiB
94 lines
3.2 KiB
using System;
|
|
using System.Collections.Generic;
|
|
using System.Collections.ObjectModel;
|
|
using System.Diagnostics;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using System.Threading.Tasks;
|
|
|
|
namespace Model
|
|
{
|
|
public class PlayerManager : IManager<Player>
|
|
{
|
|
/// <summary>
|
|
/// a hashset of the players that this manager is in charge of
|
|
/// <br/>
|
|
/// the hash is based on the player's unique property (name)
|
|
/// </summary>
|
|
private readonly HashSet<Player> players;
|
|
|
|
public PlayerManager()
|
|
{
|
|
players = new HashSet<Player>();
|
|
}
|
|
/// <summary>
|
|
/// add a new player
|
|
/// </summary>
|
|
/// <param name="toAdd">player to be added</param>
|
|
/// <returns>added player, or null if <paramref name="toAdd"/> was null</returns>
|
|
public Player Add(ref Player toAdd)
|
|
{
|
|
if (toAdd != null)
|
|
{
|
|
players.Add(toAdd);
|
|
}
|
|
return toAdd;
|
|
}
|
|
|
|
/// <summary>
|
|
/// may never get implemented in the model, go through GetOneByName() in the meantime
|
|
/// </summary>
|
|
/// <param name="id"></param>
|
|
/// <returns></returns>
|
|
/// <exception cref="NotImplementedException"></exception>
|
|
public Player GetOneById(int id)
|
|
{
|
|
throw new NotImplementedException("may never get implemented\ngo through GetOneByName() in the meantime");
|
|
}
|
|
|
|
/// <summary>
|
|
/// finds the player with that name and returns A COPY OF IT
|
|
/// <br/>
|
|
/// that copy does not belong to this manager's players, so it should not be modified
|
|
/// </summary>
|
|
/// <param name="name">a player's unique name</param>
|
|
/// <returns>player with said name</returns>
|
|
public Player GetOneByName(string name)
|
|
{
|
|
if (!String.IsNullOrEmpty(name))
|
|
{
|
|
Player result = players.Where(p => p.Name.Equals(name)).FirstOrDefault();
|
|
return new Player(result.Name); // will return null if no such player exists
|
|
}
|
|
return null; // we also want ot return null if no name was provided
|
|
}
|
|
|
|
/// </summary>
|
|
/// get a READ ONLY enumerable of all players belonging to this manager
|
|
/// </summary>
|
|
/// <returns>a readonly list of all this manager's players</returns>
|
|
public IEnumerable<Player> GetAll() => players.AsEnumerable();
|
|
|
|
/// <summary>
|
|
/// update a player from <paramref name="before"/> to <paramref name="after"/>
|
|
/// </summary>
|
|
/// <param name="before">player to be updated</param>
|
|
/// <param name="after">player in the state that it needs to be in after the update</param>
|
|
/// <returns>updated player</returns>
|
|
public Player Update(ref Player before, ref Player after)
|
|
{
|
|
Remove(ref before);
|
|
return Add(ref after);
|
|
}
|
|
|
|
/// <summary>
|
|
/// remove a player
|
|
/// </summary>
|
|
/// <param name="toRemove">player to be removed</param>
|
|
public void Remove(ref Player toRemove)
|
|
{
|
|
players.Remove(toRemove);
|
|
}
|
|
}
|
|
}
|