mirror of
				https://gitlab.com/Kwoth/nadekobot.git
				synced 2025-11-03 16:24:27 -05: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();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@@ -15,6 +15,7 @@
 | 
			
		||||
 | 
			
		||||
    <ItemGroup>
 | 
			
		||||
      <ProjectReference Include="..\Nadeko.Common\Nadeko.Common.csproj" />
 | 
			
		||||
      <ProjectReference Include="..\Nadeko.Econ\Nadeko.Econ.csproj" />
 | 
			
		||||
      <ProjectReference Include="..\NadekoBot\NadekoBot.csproj" />
 | 
			
		||||
    </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