diff --git a/exercises/php/cards/Animal.php b/exercises/php/cards/Animal.php index adde2aa..bb44404 100644 --- a/exercises/php/cards/Animal.php +++ b/exercises/php/cards/Animal.php @@ -4,33 +4,17 @@ class Animal { - public array $animal = [ - "AARDVARK", - "BABOON", - "CAMEL", - "DEER", - "ELEPHANT", - "FROG", - "GORILLA", - "HARE", - "IMPALA", - "JAGUAR", - "KANGAROO", - "LION", - "MOOSE", - "NEWT", - "OCTOPUS", - "PENGUIN", - "QUETZAL", - "RABBIT", - "SALMON", - "TORTOISE", - "UAKARIS", - "VAQUITA", - "WHALE", - "X_RAY_TETRA", - "YAK", - "ZEBRA" - ]; + private string $animalName; + + public function __construct(string $animalName) + { + $this->animalName = $animalName; + } + + public function __toString(): string + { + return $this->animalName; + } + } \ No newline at end of file diff --git a/exercises/php/cards/AnimalCard.php b/exercises/php/cards/AnimalCard.php index a0651ab..a0d7dbf 100644 --- a/exercises/php/cards/AnimalCard.php +++ b/exercises/php/cards/AnimalCard.php @@ -6,16 +6,16 @@ class AnimalCard implements Card { - private string $animal; + private Animal $animal; - public function __construct(string $animal) + public function __construct(Animal $animal) { $this->animal = $animal; } public function __toString(): string { - return $this->animal; + return strval($this->animal); } public function snap(?Card $card): bool diff --git a/exercises/php/cards/AnimalDeck.php b/exercises/php/cards/AnimalDeck.php index 67c888d..552736b 100644 --- a/exercises/php/cards/AnimalDeck.php +++ b/exercises/php/cards/AnimalDeck.php @@ -10,10 +10,9 @@ public function __construct() { $this->cards = []; - $cAnimal = new Animal(); - foreach ($cAnimal->animal as $animal) { - $this->cards[] = new AnimalCard($animal); - $this->cards[] = new AnimalCard($animal); + foreach (Animals::ANIMALS as $animal) { + $this->cards[] = new AnimalCard(new Animal($animal)); + $this->cards[] = new AnimalCard(new Animal($animal)); } } diff --git a/exercises/php/cards/Animals.php b/exercises/php/cards/Animals.php new file mode 100644 index 0000000..a7b54e0 --- /dev/null +++ b/exercises/php/cards/Animals.php @@ -0,0 +1,36 @@ +suit = $suit; $this->faceValue = $faceValue; @@ -57,7 +57,7 @@ public function getFaceValue(): int public function getSuit(): string { - return $this->suit; + return strval($this->suit); } public function snap(?Card $card): bool diff --git a/exercises/php/cards/PlayingCardDeck.php b/exercises/php/cards/PlayingCardDeck.php index b12945e..2f090f9 100644 --- a/exercises/php/cards/PlayingCardDeck.php +++ b/exercises/php/cards/PlayingCardDeck.php @@ -8,12 +8,11 @@ class PlayingCardDeck implements Deck public function __construct() { - $cSuits = new Suit(); $this->cards = []; - foreach ($cSuits->suit as $suit) { + foreach (Suits::SUITS as $suit) { for ($faceValue = 0; $faceValue < 13; $faceValue++) { - $this->cards[] = new PlayingCard($suit, $faceValue); + $this->cards[] = new PlayingCard(new Suit($suit), $faceValue); } } } diff --git a/exercises/php/cards/Suit.php b/exercises/php/cards/Suit.php index dfae53e..b2d937b 100644 --- a/exercises/php/cards/Suit.php +++ b/exercises/php/cards/Suit.php @@ -4,11 +4,16 @@ class Suit { - public array $suit = [ - "clubs", - "diamonds", - "hearts", - "spades" - ]; + private string $suitName; + + public function __construct(string $suitName) + { + $this->suitName = $suitName; + } + + public function __toString(): string + { + return $this->suitName; + } } \ No newline at end of file diff --git a/exercises/php/cards/Suits.php b/exercises/php/cards/Suits.php new file mode 100644 index 0000000..9322f97 --- /dev/null +++ b/exercises/php/cards/Suits.php @@ -0,0 +1,14 @@ +animal as $animal) { - $this->testCards[] = new AnimalCard($animal); - $this->testCards[] = new AnimalCard($animal); + foreach (Animals::ANIMALS as $animal) { + $this->testCards[] = new AnimalCard(new Animal($animal)); + $this->testCards[] = new AnimalCard(new Animal($animal)); } }