Skip to content

Commit

Permalink
update README
Browse files Browse the repository at this point in the history
  • Loading branch information
SpontanCombust committed Jul 13, 2023
1 parent 01d4915 commit 8567590
Showing 1 changed file with 25 additions and 39 deletions.
64 changes: 25 additions & 39 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -61,66 +61,52 @@ To see all the possible options that can be used with the parser use the `--help
4. Add generated script file to your mod structure


5. Let the framework know about your settings class
5. Write a convenience function to get your settings object

```ts
public var settings : MyModSettings;
```js
function GetMyModSettings(): MyModSettings
{
var settings : MyModSettings;

mySettings = new MyModSettings in thePlayer;
settings = (MyModSettings)GetSettingsMasterRegistry().GetSettings('MyModSettings');
if (!settings)
{
settings = new MyModSettings in theGame;
GetSettingsMasterRegistry().AddSettings(settings, 'MyModSettings');
}

GetSettingsMasterRegistry().AddSettings(mySettings, 'MyModSettings');
return settings;
}
```
First argument is the settings object itself.
Second argument is the ID you want this object to be identified with.

The `AddSettings()` function needs to be used only once. It is up to you when and where you use it. It can be done with Bootstrap or for example in player's OnSpawned function, your choice. The registry will hold the settings object through the entire time the game runs and even if you try to add these settings multiple times with the same ID given, the framework will detect it and won't add a duplicate.

The `AddSettings()` function needs to be used only once. It is up to you when and where you use it. It can be done with Bootstrap, in player's OnSpawned function or by writing a short function like above that will do this automatically on the first call. The registry will hold the settings object through the entire time the game runs. The second argument of this function is an arbitrary identifier by which you will later be able to retrieve settings object with `GetSettings()` method.

If you don't want to you don't need to store the settings object yourself. You can use registry's GetSettings() method to get access to your settings object.
```ts
// creating the object without assigning it anywhere
GetSettingsMasterRegistry().AddSettings(new MyModSettings in theGame, 'MyModSettings');

...

var mySettings : MyModSettings;

mySettings = (MyModSettings)GetSettingsMasterRegistry().GetSettings('MyModSettings');

if(mySettings)
{
if(mySettings.tab1.option == 1)
{
...
}
}
```

<br>

6. Use the settings object in your mod

```js
if(thePlayer.mySettings.tab1.toggle)
var settings : MyModSettings = GetMyModSettings();

if(settings.tab1.toggle)
{
doSomething();
settings.tab1.sliderInt = 50;
settings.WriteSettings();
}
```
From the moment the settings object is added to the registry it gets updated whenever user changes settings in the menu. You do not need to refresh said object yourself, but if you really need to you can do so by calling `ReadSettings()` on it.
The structure of the generated settings class is meant to resemble the structure of the XML. The class contains variables analogous to XML's Group nodes. Those variables in turn contain variables which are equivalent to individual Var nodes. Their types are appropriate, for example a variable for TOGGLE will be of type bool and a SLIDER variable will be either int or float depending on whether said slider can produce fractions. <br>
Now instead of using CInGameConfigWrapper's methods to access user configuration you can use this dedicated settings object.

It is also possible to change values of these variables and use it to write the data back into game configuration.
```js
mySettings.tab2subtab1.anotherSlider = 0.8;
mySettings.tab2subtab2.anotherToggle = false;

mySettings.WriteSettings();
```
Whenever you fetch the settings object its data is always up-to-date. You do not need to refresh said object yourself, but it is possible with `ReadSettings()` method.
It is also possible to save the data back into user configuration. To do this, after you assign new values to members of the settings object, call the `WriteSettings()` method.

<br>

7. Extend settings master
7. (Optional) Extend settings master

If the basic functionality that framework classes provide is not enough for you you can extend the settings class generated by the parser and use that child class instead.
If the basic functionality that framework classes provided is not enough for you you can extend the settings class generated by the parser and use that child class instead.
The most common usage of this would be overriding `ReadSettings()` method to run arbitrary code whenever the settings class gets updated. To see all the functions available for overriding refer to the [class specification](doc/class_specification.md) or code itself.


Expand Down

0 comments on commit 8567590

Please sign in to comment.