All Downloads are FREE. Search and download functionalities are using the official Maven repository.

kz.charles_grozny.bukkitConfig.configuration.file.FileConfigurationOptions Maven / Gradle / Ivy

The newest version!
package kz.charles_grozny.bukkitConfig.configuration.file;

import kz.charles_grozny.bukkitConfig.configuration.Configuration;
import kz.charles_grozny.bukkitConfig.configuration.*;

/**
 * Various settings for controlling the input and output of a {@link
 * FileConfiguration}
 */
public class FileConfigurationOptions extends MemoryConfigurationOptions {
    private String header = null;
    private boolean copyHeader = true;

    protected FileConfigurationOptions(MemoryConfiguration configuration) {
        super(configuration);
    }

    @Override
    public FileConfiguration configuration() {
        return (FileConfiguration) super.configuration();
    }

    @Override
    public FileConfigurationOptions copyDefaults(boolean value) {
        super.copyDefaults(value);
        return this;
    }

    @Override
    public FileConfigurationOptions pathSeparator(char value) {
        super.pathSeparator(value);
        return this;
    }

    /**
     * Gets the header that will be applied to the top of the saved output.
     * 

* This header will be commented out and applied directly at the top of * the generated output of the {@link FileConfiguration}. It is not * required to include a newline at the end of the header as it will * automatically be applied, but you may include one if you wish for extra * spacing. *

* Null is a valid value which will indicate that no header is to be * applied. The default value is null. * * @return Header */ public String header() { return header; } /** * Sets the header that will be applied to the top of the saved output. *

* This header will be commented out and applied directly at the top of * the generated output of the {@link FileConfiguration}. It is not * required to include a newline at the end of the header as it will * automatically be applied, but you may include one if you wish for extra * spacing. *

* Null is a valid value which will indicate that no header is to be * applied. * * @param value New header * @return This object, for chaining */ public FileConfigurationOptions header(String value) { this.header = value; return this; } /** * Gets whether or not the header should be copied from a default source. *

* If this is true, if a default {@link FileConfiguration} is passed to * {@link * FileConfiguration#setDefaults(Configuration)} * then upon saving it will use the header from that config, instead of * the one provided here. *

* If no default is set on the configuration, or the default is not of * type FileConfiguration, or that config has no header ({@link #header()} * returns null) then the header specified in this configuration will be * used. *

* Defaults to true. * * @return Whether or not to copy the header */ public boolean copyHeader() { return copyHeader; } /** * Sets whether or not the header should be copied from a default source. *

* If this is true, if a default {@link FileConfiguration} is passed to * {@link * FileConfiguration#setDefaults(Configuration)} * then upon saving it will use the header from that config, instead of * the one provided here. *

* If no default is set on the configuration, or the default is not of * type FileConfiguration, or that config has no header ({@link #header()} * returns null) then the header specified in this configuration will be * used. *

* Defaults to true. * * @param value Whether or not to copy the header * @return This object, for chaining */ public FileConfigurationOptions copyHeader(boolean value) { copyHeader = value; return this; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy