mirror of
https://github.com/emilybache/GildedRose-Refactoring-Kata.git
synced 2026-02-16 06:51:27 +00:00
99 lines
1.7 KiB
Ruby
99 lines
1.7 KiB
Ruby
class GildedRose
|
|
|
|
# def initialize(items)
|
|
# @items = items
|
|
# end
|
|
|
|
def self.update_quality(items)
|
|
items.map do |item|
|
|
if !special_item?(item)
|
|
update_normal_quality(item) if !sulfuras?(item)
|
|
else
|
|
update_backstage_quality(item) if item.quality < 50
|
|
end
|
|
# ______________________________________________________________________________________
|
|
# start of block that reduces sell in
|
|
if !sulfuras?(item)
|
|
item.sell_in = item.sell_in - 1
|
|
end
|
|
# end of block that reduces sell in
|
|
|
|
if item.sell_in < 0
|
|
if item.name != "Aged Brie"
|
|
if !item.name.downcase.match /backstage/
|
|
update_normal_quality(item)
|
|
else
|
|
item.quality = 0
|
|
end
|
|
else
|
|
item.quality = item.quality + 1 if item.quality < 50
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
def self.update_backstage_quality(item)
|
|
case item.sell_in
|
|
when (-(Float::INFINITY)..0)
|
|
item.quality = 0
|
|
when 0..5
|
|
item.quality += 3
|
|
when 6..10
|
|
item.quality += 2
|
|
when 10..Float::INFINITY
|
|
item.quality += 1
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
def self.update_normal_quality(item)
|
|
item.quality -= 1 unless item.quality.zero?
|
|
|
|
end
|
|
|
|
def self.sulfuras?(item)
|
|
!item.name.downcase.match( /sulfuras/).nil?
|
|
end
|
|
|
|
def self.special_item?(item)
|
|
( !item.name.downcase.match( /aged brie/).nil? || !item.name.downcase.match(/backstage/).nil? || sulfuras?(item))
|
|
end
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class Item
|
|
attr_accessor :name, :sell_in, :quality
|
|
|
|
def initialize(name, sell_in, quality)
|
|
@name = name
|
|
@sell_in = sell_in
|
|
@quality = quality
|
|
end
|
|
|
|
def to_s()
|
|
"#{@name}, #{@sell_in}, #{@quality}"
|
|
end
|
|
end
|