Custom Settings

You can add your own custom settings, too!

Customized settings give you an ability to leverage the built-in settings application provided by the Nitrocid base system to customize your mod's behavior. These settings are saved to your kernel configuration directory as JSON files under the class names for easy recognition.

In your mod, you can register and unregister your custom settings using the following functions from the ConfigTools class:

  • RegisterCustomSetting(BaseKernelConfig kernelConfig)

  • UnregisterCustomSetting(string setting)

Beware that your base kernel configuration class must contain valid entries in your list of entries under the JSON representation.

You can use the below function to convert your JSON settings entries to their usable ones:

public static SettingsEntry[] GetSettingsEntries(string entriesText)

Defining custom settings

Before you continue, you must first understand the settings format and take a quick look at it here:

Settings Format

The first thing that your custom kernel settings requires is that you need to have a class (for example, let's assume that your custom settings class name is OxygenSettings) that is derived from both the BaseKernelConfig class and the IKernelConfig interface.

OxygenSettings.cs
internal class OxygenSettings : BaseKernelConfig, IKernelConfig
{
    // Your custom settings here
}

This class must override the SettingsEntries property from the base class so that it can understand your custom settings entries and how they're defined. The easiest way to override it is to just let this property return an array from SettingsEntries using the GetSettingsEntries function, pointing it at your variable containing your JSON representation of the settings entries, as demonstrated in the below example:

OxygenSettings.cs
internal class OxygenSettings : BaseKernelConfig, IKernelConfig
{
    // Your JSON representation about your settings entries
    private readonly string _entriesJson =
        """
        [
            {
                "Name": "CustomSection",
                "Desc": "This is the custom section.",
                "DisplayAs": "Custom section",
                "Keys": [
                    {
                        "Name": "Custom switch",
                        "Type": "SBoolean",
                        "Variable": "CustomSwitch",
                        "Description": "Specifies the custom switch."
                    },
                    {
                        "Name": "Custom character",
                        "Type": "SChar",
                        "Variable": "CustomChar",
                        "Description": "Specifies the custom character."
                    },
                    {
                        "Name": "Custom color",
                        "Type": "SColor",
                        "Variable": "CustomColor",
                        "Description": "Specifies the custom color."
                    },
                    {
                        "Name": "Custom double",
                        "Type": "SDouble",
                        "Variable": "CustomDouble",
                        "Description": "Specifies the custom double."
                    },
                    {
                        "Name": "Custom figlet font",
                        "Type": "SFiglet",
                        "Variable": "CustomFigletFont",
                        "Description": "Specifies the custom figlet font."
                    },
                    {
                        "Name": "Custom integer",
                        "Type": "SInt",
                        "Variable": "CustomInt",
                        "Description": "Specifies the custom integer."
                    },
                    {
                        "Name": "Custom integer slider",
                        "Type": "SIntSlider",
                        "Variable": "CustomIntSlider",
                        "Description": "Specifies the custom integer slider.",
                        "MinimumValue": 0,
                        "MaximumValue": 255
                    },
                    {
                        "Name": "Custom list",
                        "Type": "SList",
                        "Variable": "CustomList",
                        "SelectionFunctionName": "GetPathList",
                        "SelectionFunctionType": "Filesystem",
                        "DelimiterVariable": "PathLookupDelimiter",
                        "IsValuePath": true,
                        "IsPathCurrentPath": true,
                        "Description": "Specifies the custom list."
                    },
                    {
                        "Name": "Custom preset",
                        "Type": "SPreset",
                        "Variable": "CustomPreset",
                        "ShellType": "Shell",
                        "Description": "Specifies the custom preset."
                    },
                    {
                        "Name": "Custom selection",
                        "Type": "SSelection",
                        "Variable": "CustomSelection",
                        "IsEnumeration": false,
                        "SelectionFunctionName": "ListAllLanguages",
                        "SelectionFunctionType": "LanguageManager",
                        "IsSelectionFunctionDict": true,
                        "SelectionFallback": [ "en-US" ],
                        "Description": "Specifies the custom selection."
                    },
                    {
                        "Name": "Custom string",
                        "Type": "SString",
                        "Variable": "CustomString",
                        "Description": "Specifies the custom string."
                    }
                ]
            }
        ]
        """;

    // You must override this
    public override SettingsEntry[] SettingsEntries =>
        ConfigTools.GetSettingsEntries(_entriesJson);

    // Your variables. Your JSON representation of the entries must contain information about these
    public char CustomChar { get; set; } = 'A';
    public string CustomColor { get; set; } = Color.Empty.PlainSequence;
    public double CustomDouble { get; set; } = 0.5d;
    public bool CustomSwitch { get; set; } = true;
    public string CustomFigletFont { get; set; } = "small";
    public int CustomInt { get; set; } = 1;
    public int CustomIntSlider { get; set; } = 4;
    public string CustomList { get; set; } = "";
    public string CustomPreset { get; set; } = "Default";
    public string CustomString { get; set; } = "Default";
    public string CustomSelection { get; set; } = "en-US";
}

After that, you must register your configuration class by just two lines somewhere in your mod initialization code:

MyModInit.cs
var customSettings = new OxygenSettings();
ConfigTools.RegisterCustomSetting(customSettings);

You can also embed your settings JSON content if it became too big using the Resources feature, which you can learn more about how to add a file to your project resources and use it here.

You don't have to save a copy of your customSettings variable, since it gets added to the custom settings list that the kernel configuration tool supervises.

You can also unregister your custom settings by putting the UnregisterCustomSetting() function somewhere in your mod stop function like this:

MyModStop.cs
ConfigTools.UnregisterCustomSetting(nameof(OxygenSettings));

You don't have to do all the guesswork to figure out how to get your custom configuration name. All you have to do is to point the above function to the name of your configuration class using the nameof function.

Using your own custom settings

To use your own custom settings, you'll have to get a settings instance from GetKernelConfig() before being able to get the updated settings instance containing your configured settings, even if you have a new instance of your custom settings. You can easily wrap it to a property like this:

Mod.cs
internal static BaseKernelConfig Configuration =>
    Config.GetKernelConfig(nameof(OxygenSettings));

You can then get a value from your desired settings key. For example, if you want to get a value of a string configuration defined earlier, called CustomString, you can get the value of this key like this:

Mod.cs
var key = ConfigTools.GetSettingsKey(Configuration, nameof(OxygenSettings.CustomString));
string value = (string)ConfigTools.GetValueFromEntry(key, Configuration);

If you used this method against your newly-created instance of your custom settings (the customSettings variable) instead of the above property, calls to GetValueFromEntry() would not return the configured results changed by the settings command.

Testing your own custom settings

To test your own custom settings to check to see if it works or not, make sure that you've registered your custom settings upon starting your mod. Invoking the help usage of the settings command (help settings) is enough to list all of your kernel settings (built-in and custom).

Use the settings command to specify your kernel settings type with the -type switch, pointing it to your custom kernel settings name, which is usually your settings class name, for example, settings -type=OxygenSettings.

If everything goes well, you should be able to change your settings there.

When registering custom settings, the kernel runs a validation test to ensure that your custom settings are formed well before adding it to the list. If it fails, the kernel will give you a list of the configuration entries that you'll have to fix before being able to use them.

If any of the kernel configuration entries is invalid, the configuration tools will report a failure. Make sure that all of the entries are valid and that you've specified the variable names correctly. Use nameof to help you assign them.

The variable names are case-sensitive.

Last updated