Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
160 changes: 66 additions & 94 deletions src/fi/oulu/tol/sqat/GildedRose.java
Original file line number Diff line number Diff line change
Expand Up @@ -3,105 +3,77 @@
import java.util.ArrayList;
import java.util.List;


public class GildedRose {

private static List<Item> items = null;

/**
* @param args
*/
public static void main(String[] args) {

System.out.println("OMGHAI!");

items = new ArrayList<Item>();
items.add(new Item("+5 Dexterity Vest", 10, 20));
items.add(new Item("Aged Brie", 2, 0));
items.add(new Item("Elixir of the Mongoose", 5, 7));
items.add(new Item("Sulfuras, Hand of Ragnaros", 0, 80));
items.add(new Item("Backstage passes to a TAFKAL80ETC concert", 15, 20));
items.add(new Item("Conjured Mana Cake", 3, 6));

updateQuality();
}
public List<Item> getItems() {
return items;
}

public void addItem(Item item) {
items.add(item);
}

public GildedRose() {
items = new ArrayList<Item>();
}

public static void updateEndOfDay() {
for (Item item : items) {
if ((!"Aged Brie".equals(item.getName()))
&& !"Backstage passes to a TAFKAL80ETC concert".equals(item.getName())) {
if (!item.hasZeroQuality()) {
if (!"Sulfuras, Hand of Ragnaros".equals(item.getName())) {
item.decreaseQuality();
}
}
} else {
if (!item.hasReachedMaximumQuality()) {
item.increaseQuality();

if ("Backstage passes to a TAFKAL80ETC concert".equals(item.getName())) {
if (item.getSellIn() < 11) {
if (!item.hasReachedMaximumQuality()) {
item.increaseQuality();
}
}

if (item.getSellIn() < 6) {
if (!item.hasReachedMaximumQuality()) {
item.increaseQuality();
}
}
}
}
}

if (!"Sulfuras, Hand of Ragnaros".equals(item.getName())) {
item.decreaseSellIn();
}

if (item.isExpired()) {
if ("Aged Brie".equals(item.getName())) {

if (!item.hasReachedMaximumQuality()) {
item.increaseQuality();
}
} else {

if ("Backstage passes to a TAFKAL80ETC concert".equals(item.getName())) {
item.setQuality(0);
} else {
if (!item.hasZeroQuality()) {
if (!"Sulfuras, Hand of Ragnaros".equals(item.getName())) {
item.decreaseQuality();
}
}

}


public static void updateQuality()
{
for (int i = 0; i < items.size(); i++)
{
if ((!"Aged Brie".equals(items.get(i).getName())) && !"Backstage passes to a TAFKAL80ETC concert".equals(items.get(i).getName()))
{
if (items.get(i).getQuality() > 0)
{
if (!"Sulfuras, Hand of Ragnaros".equals(items.get(i).getName()))
{
items.get(i).setQuality(items.get(i).getQuality() - 1);
}
}
}
else
{
if (items.get(i).getQuality() < 50)
{
items.get(i).setQuality(items.get(i).getQuality() + 1);

if ("Backstage passes to a TAFKAL80ETC concert".equals(items.get(i).getName()))
{
if (items.get(i).getSellIn() < 11)
{
if (items.get(i).getQuality() < 50)
{
items.get(i).setQuality(items.get(i).getQuality() + 1);
}
}

if (items.get(i).getSellIn() < 6)
{
if (items.get(i).getQuality() < 50)
{
items.get(i).setQuality(items.get(i).getQuality() + 1);
}
}
}
}
}

if (!"Sulfuras, Hand of Ragnaros".equals(items.get(i).getName()))
{
items.get(i).setSellIn(items.get(i).getSellIn() - 1);
}

if (items.get(i).getSellIn() < 0)
{
if (!"Aged Brie".equals(items.get(i).getName()))
{
if (!"Backstage passes to a TAFKAL80ETC concert".equals(items.get(i).getName()))
{
if (items.get(i).getQuality() > 0)
{
if (!"Sulfuras, Hand of Ragnaros".equals(items.get(i).getName()))
{
items.get(i).setQuality(items.get(i).getQuality() - 1);
}
}
}
else
{
items.get(i).setQuality(items.get(i).getQuality() - items.get(i).getQuality());
}
}
else
{
if (items.get(i).getQuality() < 50)
{
items.get(i).setQuality(items.get(i).getQuality() + 1);
}
}
}
}
}
}
}
}
}

}
31 changes: 28 additions & 3 deletions src/fi/oulu/tol/sqat/Item.java
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,9 @@


public class Item {
public String name;
public int sellIn;
public int quality;
String name;
int sellIn;
int quality;

public Item(String name, int sellIn, int quality) {
this.setName(name);
Expand All @@ -31,5 +31,30 @@ public int getQuality() {
public void setQuality(int quality) {
this.quality = quality;
}
public void decreaseQuality(){
--quality;
}
public void increaseQuality(){
quality++;
}
public void decreaseSellIn(){
--sellIn;
}
public boolean isExpired(){
if (sellIn <0)
return true;
return false;
}
public boolean hasReachedMaximumQuality(){
if(quality < 50)
return false;
return true;
}
public boolean hasZeroQuality(){
if(quality >0)
return false;
return true;

}
}

Loading