mirror of
https://gitlab.com/Kwoth/nadekobot.git
synced 2025-09-10 17:28:27 -04:00
Mostly finished implementation of the new deck? ALso added some tests
This commit is contained in:
@@ -1,6 +1,4 @@
|
|||||||
#nullable disable
|
#nullable disable
|
||||||
using Nadeko.Common;
|
|
||||||
|
|
||||||
namespace Nadeko.Econ;
|
namespace Nadeko.Econ;
|
||||||
|
|
||||||
public class Deck
|
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();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
@@ -15,6 +15,7 @@
|
|||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ProjectReference Include="..\Nadeko.Common\Nadeko.Common.csproj" />
|
<ProjectReference Include="..\Nadeko.Common\Nadeko.Common.csproj" />
|
||||||
|
<ProjectReference Include="..\Nadeko.Econ\Nadeko.Econ.csproj" />
|
||||||
<ProjectReference Include="..\NadekoBot\NadekoBot.csproj" />
|
<ProjectReference Include="..\NadekoBot\NadekoBot.csproj" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
|
51
src/NadekoBot.Tests/NewDeckTests.cs
Normal file
51
src/NadekoBot.Tests/NewDeckTests.cs
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
using Nadeko.Econ;
|
||||||
|
using NUnit.Framework;
|
||||||
|
|
||||||
|
namespace NadekoBot.Tests;
|
||||||
|
|
||||||
|
public class NewDeckTests
|
||||||
|
{
|
||||||
|
private RegularDeck _deck;
|
||||||
|
|
||||||
|
[SetUp]
|
||||||
|
public void Setup()
|
||||||
|
{
|
||||||
|
_deck = new RegularDeck();
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestCount()
|
||||||
|
{
|
||||||
|
Assert.AreEqual(52, _deck.TotalCount);
|
||||||
|
Assert.AreEqual(52, _deck.CurrentCount);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestDeckDraw()
|
||||||
|
{
|
||||||
|
var card = _deck.Draw();
|
||||||
|
|
||||||
|
Assert.IsNotNull(card);
|
||||||
|
Assert.AreEqual(card.Suit, RegularSuit.Hearts);
|
||||||
|
Assert.AreEqual(card.Value, RegularValue.A);
|
||||||
|
Assert.AreEqual(_deck.CurrentCount, _deck.TotalCount - 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestDeckSpent()
|
||||||
|
{
|
||||||
|
for (var i = 0; i < _deck.TotalCount - 1; ++i)
|
||||||
|
{
|
||||||
|
_deck.Draw();
|
||||||
|
}
|
||||||
|
|
||||||
|
var lastCard = _deck.Draw();
|
||||||
|
|
||||||
|
Assert.IsNotNull(lastCard);
|
||||||
|
Assert.AreEqual(lastCard, new RegularCard(RegularSuit.Spades, RegularValue.King));
|
||||||
|
|
||||||
|
var noCard = _deck.Draw();
|
||||||
|
|
||||||
|
Assert.IsNull(noCard);
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user