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.
110 lines
3.5 KiB
110 lines
3.5 KiB
using System;
|
|
using System.Collections;
|
|
using System.Collections.Generic;
|
|
using System.Collections.ObjectModel;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using Model.Dice.Faces;
|
|
using Model.Players;
|
|
|
|
namespace Model.Games
|
|
{
|
|
/// <summary>
|
|
/// a Turn consists of a Player, a DateTime, and a IEnumerable of AbstractDieFace
|
|
/// Like a turn in some game.
|
|
/// <br/>
|
|
/// Two turns are equal if they are litterally the same instance in RAM
|
|
/// (default behaviors Equals() and GetHashCode())
|
|
/// </summary>
|
|
public class Turn
|
|
{
|
|
|
|
/// <summary>
|
|
/// the date and time, adjusted to UTC
|
|
/// </summary>
|
|
public readonly DateTime when;
|
|
|
|
/// <summary>
|
|
/// the Player who rolled the dice
|
|
/// </summary>
|
|
public readonly Player player;
|
|
|
|
private IEnumerable<AbstractDieFace> faces;
|
|
|
|
/// <summary>
|
|
/// this private constructor is to be used only by factories
|
|
/// </summary>
|
|
/// <param name="when">date and time of the turn</param>
|
|
/// <param name="player">player who played the turn</param>
|
|
private Turn(DateTime when, Player player, IEnumerable<AbstractDieFace> faces)
|
|
{
|
|
this.when = when;
|
|
this.player = player;
|
|
this.faces = faces;
|
|
}
|
|
|
|
/// <summary>
|
|
/// creates a Turn with a specified time, passed as a parameter.
|
|
/// <br/>
|
|
/// whatever the DateTimeKind of <paramref name="when"/> might be,
|
|
/// it will become UTC during construction
|
|
/// </summary>
|
|
/// <param name="when">date and time of the turn</param>
|
|
/// <param name="player">player who played the turn</param>
|
|
/// <returns>a new Turn object</returns>
|
|
public static Turn CreateWithSpecifiedTime(DateTime when, Player player, IEnumerable<AbstractDieFace> faces)
|
|
{
|
|
|
|
if (faces is null || !faces.Any())
|
|
{
|
|
throw new ArgumentException("param should not be null or empty", nameof(faces));
|
|
}
|
|
if (player is null)
|
|
{
|
|
throw new ArgumentNullException(nameof(player), "param should not be null");
|
|
}
|
|
if (when.Kind != DateTimeKind.Utc)
|
|
{
|
|
when = when.ToUniversalTime();
|
|
}
|
|
|
|
return new Turn(when, player, faces);
|
|
}
|
|
|
|
/// <summary>
|
|
/// creates a Turn with a default time, which is "now" in UTC.
|
|
/// </summary>
|
|
/// <param name="player">player who played the turn</param>
|
|
/// <returns>a new Turn object</returns>
|
|
public static Turn CreateWithDefaultTime(Player player, IEnumerable<AbstractDieFace> faces)
|
|
{
|
|
return CreateWithSpecifiedTime(DateTime.UtcNow, player, faces);
|
|
}
|
|
|
|
/// <summary>
|
|
/// represents a turn in string format
|
|
/// </summary>
|
|
/// <returns>a turn in string format</returns>
|
|
public override string ToString()
|
|
{
|
|
string[] datetime = when.ToString("s", System.Globalization.CultureInfo.InvariantCulture).Split("T");
|
|
string date = datetime[0];
|
|
string time = datetime[1];
|
|
|
|
StringBuilder sb = new();
|
|
|
|
sb.AppendFormat("{0} {1} -- {2} rolled:",
|
|
date,
|
|
time,
|
|
player.ToString());
|
|
|
|
foreach (AbstractDieFace face in faces)
|
|
{
|
|
sb.Append(" " + face.ToString());
|
|
}
|
|
|
|
return sb.ToString();
|
|
}
|
|
}
|
|
}
|