/* * This file is part of the Illarion project. * * Copyright © 2015 - 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.common.config.entries; import illarion.common.config.Config; import javax.annotation.Nonnull; import javax.annotation.Nullable; /** * This is a configuration entry that is used to a simple text entry in the * configuration. * * @author Martin Karing <nitram@illarion.org> */ public final class TextEntry implements ConfigEntry { /** * The configuration that is controlled by this text entry. */ private Config cfg; /** * The key in the configuration that is handled by this configuration. */ private final String configEntry; /** * Create a new configuration entry that is handled by this entry. * * @param entry the configuration key that is handled by this text entry */ public TextEntry(String entry) { configEntry = entry; } /** * Get the value set in the configuration for this text entry. * * @return the configuration stored for this text entry */ @Nullable public String getValue() { return cfg.getString(configEntry); } /** * Set the configuration handled by this configuration entry. * * @param config the configuration that is supposed to be handled by this * configuration entry */ @Override public void setConfig(@Nonnull Config config) { cfg = config; } /** * Set the new value of the configuration entry that is controlled by this. * * @param newValue the new configuration value */ public void setValue(@Nonnull String newValue) { cfg.set(configEntry, newValue); } }