R-02 Added additional classes

This commit is contained in:
dashiwa 2020-12-31 16:33:48 +03:00
parent 523c894eb1
commit bd3dd7b791
5 changed files with 114 additions and 77 deletions

View File

@ -0,0 +1,46 @@
<?php
namespace GildedRose;
use GildedRose\Item;
class FirstProcessingRule
{
private $item;
public function __construct(Item $item)
{
$this->item = $item;
}
public function firstProcessingRule()
{
$item = $this->item;
if ($item->name != 'Aged Brie' and $item->name != 'Backstage passes to a TAFKAL80ETC concert') {
if ($item->quality > 0) {
if ($item->name != 'Sulfuras, Hand of Ragnaros') {
$item->quality = $item->quality - 1;
}
}
} else {
if ($item->quality < 50) {
$item->quality = $item->quality + 1;
if ($item->name == 'Backstage passes to a TAFKAL80ETC concert') {
if ($item->sell_in < 11) {
if ($item->quality < 50) {
$item->quality = $item->quality + 1;
}
}
if ($item->sell_in < 6) {
if ($item->quality < 50) {
$item->quality = $item->quality + 1;
}
}
}
}
}
}
}

View File

@ -4,9 +4,8 @@ declare(strict_types=1);
namespace GildedRose;
use GildedRose\GildedRoseInterface;
final class GildedRose implements GildedRoseInterface
final class GildedRose
{
/**
* @var Item[]
@ -22,68 +21,17 @@ final class GildedRose implements GildedRoseInterface
{
foreach ($this->items as $item) {
$this->firstProcessingRule($item);
$firstItem = new FirstProcessingRule($item);
$this->secondProcessingRule($item);
$firstItem->firstProcessingRule();
$this->thirdProcessingRule($item);
}
}
$secondItem = new SecondProcessingRule($item);
public function firstProcessingRule(&$item)
{
$secondItem->secondProcessingRule();
if ($item->name != 'Aged Brie' and $item->name != 'Backstage passes to a TAFKAL80ETC concert') {
if ($item->quality > 0) {
if ($item->name != 'Sulfuras, Hand of Ragnaros') {
$item->quality = $item->quality - 1;
}
}
} else {
if ($item->quality < 50) {
$item->quality = $item->quality + 1;
if ($item->name == 'Backstage passes to a TAFKAL80ETC concert') {
if ($item->sell_in < 11) {
if ($item->quality < 50) {
$item->quality = $item->quality + 1;
}
}
if ($item->sell_in < 6) {
if ($item->quality < 50) {
$item->quality = $item->quality + 1;
}
}
}
}
}
}
$thirdItem = new ThirdProcessingRule($item);
public function secondProcessingRule(&$item)
{
if ($item->name != 'Sulfuras, Hand of Ragnaros') {
$item->sell_in = $item->sell_in - 1;
}
}
public function thirdProcessingRule(&$item)
{
if ($item->sell_in < 0) {
if ($item->name != 'Aged Brie') {
if ($item->name != 'Backstage passes to a TAFKAL80ETC concert') {
if ($item->quality > 0) {
if ($item->name != 'Sulfuras, Hand of Ragnaros') {
$item->quality = $item->quality - 1;
}
}
} else {
$item->quality = $item->quality - $item->quality;
}
} else {
if ($item->quality < 50) {
$item->quality = $item->quality + 1;
}
}
$thirdItem->thirdProcessingRule();
}
}

View File

@ -1,18 +0,0 @@
<?php
namespace GildedRose;
use GildedRose\Item;
interface GildedRoseInterface
{
public function updateQuality();
public function firstProcessingRule(Item &$item);
public function secondProcessingRule(Item &$item);
public function thirdProcessingRule(Item &$item);
}

View File

@ -0,0 +1,24 @@
<?php
namespace GildedRose;
class SecondProcessingRule
{
public function __construct(Item $item)
{
$this->item = $item;
}
public function secondProcessingRule()
{
$item = $this->item;
if ($item->name != 'Sulfuras, Hand of Ragnaros') {
$item->sell_in = $item->sell_in - 1;
}
}
}

View File

@ -0,0 +1,37 @@
<?php
namespace GildedRose;
class ThirdProcessingRule
{
public function __construct(Item $item)
{
$this->item = $item;
}
public function thirdProcessingRule()
{
$item = $this->item;
if ($item->sell_in < 0) {
if ($item->name != 'Aged Brie') {
if ($item->name != 'Backstage passes to a TAFKAL80ETC concert') {
if ($item->quality > 0) {
if ($item->name != 'Sulfuras, Hand of Ragnaros') {
$item->quality = $item->quality - 1;
}
}
} else {
$item->quality = $item->quality - $item->quality;
}
} else {
if ($item->quality < 50) {
$item->quality = $item->quality + 1;
}
}
}
}
}