mirror of
https://gitlab.com/Kwoth/nadekobot.git
synced 2025-09-11 09:48:26 -04:00
Mostly finished implementation of the new deck? ALso added some tests
This commit is contained in:
@@ -1,6 +1,4 @@
|
||||
#nullable disable
|
||||
using Nadeko.Common;
|
||||
|
||||
namespace Nadeko.Econ;
|
||||
|
||||
public class Deck
|
15
src/Nadeko.Econ/Deck/NewCard.cs
Normal file
15
src/Nadeko.Econ/Deck/NewCard.cs
Normal file
@@ -0,0 +1,15 @@
|
||||
namespace Nadeko.Econ;
|
||||
|
||||
public abstract class NewCard<TSuit, TValue>
|
||||
where TSuit : struct, Enum
|
||||
where TValue : struct, Enum
|
||||
{
|
||||
public TSuit Suit { get; }
|
||||
public TValue Value { get; }
|
||||
|
||||
public NewCard(TSuit suit, TValue value)
|
||||
{
|
||||
Suit = suit;
|
||||
Value = value;
|
||||
}
|
||||
}
|
51
src/Nadeko.Econ/Deck/NewDeck.cs
Normal file
51
src/Nadeko.Econ/Deck/NewDeck.cs
Normal file
@@ -0,0 +1,51 @@
|
||||
namespace Nadeko.Econ;
|
||||
|
||||
public abstract class NewDeck<TCard, TSuit, TValue>
|
||||
where TCard: NewCard<TSuit, TValue>
|
||||
where TSuit : struct, Enum
|
||||
where TValue : struct, Enum
|
||||
{
|
||||
public virtual int CurrentCount
|
||||
=> _cards.Count;
|
||||
|
||||
public virtual int TotalCount { get; }
|
||||
|
||||
private readonly LinkedList<TCard> _cards = new();
|
||||
public NewDeck()
|
||||
{
|
||||
var suits = Enum.GetValues<TSuit>();
|
||||
var values = Enum.GetValues<TValue>();
|
||||
|
||||
TotalCount = suits.Length * values.Length;
|
||||
|
||||
foreach (var suit in suits)
|
||||
{
|
||||
foreach (var val in values)
|
||||
{
|
||||
_cards.AddLast((TCard)Activator.CreateInstance(typeof(TCard), suit, val)!);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public virtual TCard? Draw()
|
||||
{
|
||||
var first = _cards.First;
|
||||
if (first is not null)
|
||||
{
|
||||
_cards.RemoveFirst();
|
||||
return first.Value;
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
public virtual void Shuffle()
|
||||
{
|
||||
var cards = _cards.ToList();
|
||||
cards.Shuffle();
|
||||
|
||||
_cards.Clear();
|
||||
foreach (var card in cards)
|
||||
_cards.AddFirst(card);
|
||||
}
|
||||
}
|
17
src/Nadeko.Econ/Deck/Regular/RegularCard.cs
Normal file
17
src/Nadeko.Econ/Deck/Regular/RegularCard.cs
Normal file
@@ -0,0 +1,17 @@
|
||||
namespace Nadeko.Econ;
|
||||
|
||||
public sealed class RegularCard : NewCard<RegularSuit, RegularValue>
|
||||
{
|
||||
public RegularCard(RegularSuit suit, RegularValue value) : base(suit, value)
|
||||
{
|
||||
}
|
||||
|
||||
private bool Equals(RegularCard other)
|
||||
=> other.Suit == this.Suit && other.Value == this.Value;
|
||||
|
||||
public override bool Equals(object? obj)
|
||||
=> ReferenceEquals(this, obj) || obj is RegularCard other && Equals(other);
|
||||
|
||||
public override int GetHashCode()
|
||||
=> Suit.GetHashCode() * 17 + Value.GetHashCode();
|
||||
}
|
5
src/Nadeko.Econ/Deck/Regular/RegularDeck.cs
Normal file
5
src/Nadeko.Econ/Deck/Regular/RegularDeck.cs
Normal file
@@ -0,0 +1,5 @@
|
||||
namespace Nadeko.Econ;
|
||||
|
||||
public sealed class RegularDeck : NewDeck<RegularCard, RegularSuit, RegularValue>
|
||||
{
|
||||
}
|
9
src/Nadeko.Econ/Deck/Regular/RegularSuit.cs
Normal file
9
src/Nadeko.Econ/Deck/Regular/RegularSuit.cs
Normal file
@@ -0,0 +1,9 @@
|
||||
namespace Nadeko.Econ;
|
||||
|
||||
public enum RegularSuit
|
||||
{
|
||||
Hearts,
|
||||
Diamonds,
|
||||
Clubs,
|
||||
Spades
|
||||
}
|
18
src/Nadeko.Econ/Deck/Regular/RegularValue.cs
Normal file
18
src/Nadeko.Econ/Deck/Regular/RegularValue.cs
Normal file
@@ -0,0 +1,18 @@
|
||||
namespace Nadeko.Econ;
|
||||
|
||||
public enum RegularValue
|
||||
{
|
||||
A = 1,
|
||||
Two = 2,
|
||||
Three = 3,
|
||||
Four = 4,
|
||||
Five = 5,
|
||||
Six = 6,
|
||||
Seven = 7,
|
||||
Eight = 8,
|
||||
Nine = 9,
|
||||
Ten = 10,
|
||||
Jack = 12,
|
||||
Queen = 13,
|
||||
King = 14,
|
||||
}
|
@@ -1,35 +0,0 @@
|
||||
namespace Nadeko.Econ;
|
||||
|
||||
public abstract class NewDeck<TCard, TSuit>
|
||||
where TCard: NewCard<TSuit>
|
||||
where TSuit : Enum
|
||||
{
|
||||
public int CurrentCount { get; }
|
||||
public int TotalCount { get; }
|
||||
|
||||
public abstract TCard Draw();
|
||||
}
|
||||
|
||||
public abstract class NewCard<TSuit>
|
||||
where TSuit: Enum
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
public sealed class RegularCard : NewCard<RegularSuit>
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
public enum RegularSuit
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
public sealed class RegularDeck : NewDeck<RegularCard, RegularSuit>
|
||||
{
|
||||
public override RegularCard Draw()
|
||||
=> throw new NotImplementedException();
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user