/* * This file is part of the Illarion project. * * Copyright © 2014 - Illarion e.V. * * Illarion is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Illarion is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. */ package illarion.easynpc.parsed.talk.consequences; import illarion.easynpc.data.Items; import illarion.easynpc.parsed.shared.ParsedItemData; import illarion.easynpc.parsed.talk.AdvancedNumber; import illarion.easynpc.parsed.talk.TalkConsequence; import illarion.easynpc.writer.LuaRequireTable; import illarion.easynpc.writer.LuaWriter; import javax.annotation.Nonnull; import java.io.IOException; import java.io.Writer; /** * This class is used to store all required values for the item consequence. * * @author Martin Karing <nitram@illarion.org> */ public final class ConsequenceItem implements TalkConsequence { /** * The LUA code needed to be included for a create item consequence. */ private static final String LUA_CODE = "talkEntry:addConsequence(%1$s(%2$s, %3$s, %4$s, %5$s))" + LuaWriter.NL; /** * The LUA module needed for this consequence to work. */ private static final String LUA_MODULE = BASE_LUA_MODULE + "item"; /** * The data value of the created items. */ private final ParsedItemData data; /** * The item that is supposed to be created with this consequence. */ private final Items item; /** * The quality value of the created items. */ private final int quality; /** * The amount of items to be created. */ private final AdvancedNumber value; /** * The constructor that allows setting the parameters of this item. * * @param newItem the item to create * @param newValue the amount to create * @param newQuality the quality value of the item * @param newData the data value of the item */ public ConsequenceItem( Items newItem, AdvancedNumber newValue, int newQuality, ParsedItemData newData) { item = newItem; value = newValue; quality = newQuality; data = newData; } /** * Get the module that is needed for this consequence to work. */ @Nonnull @Override public String getLuaModule() { return LUA_MODULE; } /** * Write the LUA code of this consequence. */ @Override public void writeLua(@Nonnull Writer target, @Nonnull LuaRequireTable requires) throws IOException { target.write(String.format(LUA_CODE, requires.getStorage(LUA_MODULE), Integer.toString(item.getItemId()), value.getLua(), Integer.toString(quality), data.getLua())); } }