/*
* This file is part of Foxbot.
*
* Foxbot is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Foxbot 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.
*
* You should have received a copy of the GNU General Public License
* along with Foxbot. If not, see <http://www.gnu.org/licenses/>.
*/
package co.foxdev.foxbot.config.yamlconfig;
import com.google.common.base.Preconditions;
import java.util.Map;
/**
* This is a {@link Configuration} implementation that does not save or load
* from any source, and stores all values in memory only. This is useful for
* temporary Configurations for providing defaults.
*/
public class MemoryConfiguration extends MemorySection implements Configuration
{
protected Configuration defaults;
protected MemoryConfigurationOptions options;
/**
* Creates an empty {@link MemoryConfiguration} with no default values.
*/
public MemoryConfiguration()
{
}
/**
* Creates an empty {@link MemoryConfiguration} using the specified
* {@link Configuration} as a source for all default values.
*
* @param defaults Default value provider
* @throws IllegalArgumentException Thrown if defaults is null
*/
public MemoryConfiguration(Configuration defaults)
{
this.defaults = defaults;
}
@Override
public void addDefault(String path, Object value)
{
Preconditions.checkNotNull(path, "Path may not be null");
if (defaults == null)
{
defaults = new MemoryConfiguration();
}
defaults.set(path, value);
}
public void addDefaults(Map<String, Object> defaults)
{
Preconditions.checkNotNull(defaults, "Defaults may not be null");
for (Map.Entry<String, Object> entry : defaults.entrySet())
{
addDefault(entry.getKey(), entry.getValue());
}
}
public void addDefaults(Configuration defaults)
{
Preconditions.checkNotNull(defaults, "Defaults may not be null");
addDefaults(defaults.getValues(true));
}
public void setDefaults(Configuration defaults)
{
Preconditions.checkNotNull(defaults, "Defaults may not be null");
this.defaults = defaults;
}
public Configuration getDefaults()
{
return defaults;
}
@Override
public ConfigurationSection getParent()
{
return null;
}
public MemoryConfigurationOptions options()
{
if (options == null)
{
options = new MemoryConfigurationOptions(this);
}
return options;
}
}