Simplify configuration and commands

Remove enabled property in favor of checking for 'never'. Autosave on console command use. Remove save/load commands
This commit is contained in:
Terry Hearst 2024-01-01 16:13:02 -05:00
parent 4e85c33589
commit dc24ec0593
5 changed files with 24 additions and 40 deletions

View file

@ -18,7 +18,6 @@ namespace DiamondTimeViewer
{ {
private const string CONFIG_FILE_NAME = "config.json"; private const string CONFIG_FILE_NAME = "config.json";
public static bool Enabled = true;
public static DisplayMode Mode = DisplayMode.Diamond; public static DisplayMode Mode = DisplayMode.Diamond;
public static bool HideSilver = false; public static bool HideSilver = false;
@ -46,9 +45,6 @@ namespace DiamondTimeViewer
return; return;
} }
if (data["enabled"] != null)
Enabled = data["enabled"].AsBool;
if (data["mode"] != null) if (data["mode"] != null)
{ {
string mode = data["mode"].Value.ToLower(); string mode = data["mode"].Value.ToLower();
@ -77,7 +73,6 @@ namespace DiamondTimeViewer
public static void SaveConfig() public static void SaveConfig()
{ {
JSONNode node = new JSONClass(); JSONNode node = new JSONClass();
node.Add("enabled", Enabled ? "true" : "false");
switch(Mode) switch(Mode)
{ {
case DisplayMode.Never: case DisplayMode.Never:

View file

@ -15,12 +15,6 @@ namespace DiamondTimeViewer
MIU.Console.Instance.Write(""); MIU.Console.Instance.Write("");
MIU.Console.Instance.Write(" hideSilver Hide silver when showing diamond"); MIU.Console.Instance.Write(" hideSilver Hide silver when showing diamond");
MIU.Console.Instance.Write(" showSilver Show silver always"); MIU.Console.Instance.Write(" showSilver Show silver always");
MIU.Console.Instance.Write("");
MIU.Console.Instance.Write(" enable Enable the mod");
MIU.Console.Instance.Write(" disable Disable the mod (should be the same as \"never\" unless I messed up)");
MIU.Console.Instance.Write("");
MIU.Console.Instance.Write(" save Saves the current config");
MIU.Console.Instance.Write(" load Loads the config file");
} }
[ConsoleCommand(description = "Configures the Diamond Time Viewer", paramsDescription = "[value]")] [ConsoleCommand(description = "Configures the Diamond Time Viewer", paramsDescription = "[value]")]
@ -34,42 +28,42 @@ namespace DiamondTimeViewer
string value = args[0]; string value = args[0];
string message;
switch (value) switch (value)
{ {
case "never": case "never":
Config.Mode = DisplayMode.Never; Config.Mode = DisplayMode.Never;
return "mode set to: never"; message = "mode set to: never";
break;
case "diamond": case "diamond":
Config.Mode = DisplayMode.Diamond; Config.Mode = DisplayMode.Diamond;
return "mode set to: diamond"; message = "mode set to: diamond";
break;
case "gold": case "gold":
Config.Mode = DisplayMode.Gold; Config.Mode = DisplayMode.Gold;
return "mode set to: gold"; message = "mode set to: gold";
break;
case "always": case "always":
Config.Mode = DisplayMode.Always; Config.Mode = DisplayMode.Always;
return "mode set to: always"; message = "mode set to: always";
break;
case "hideSilver": case "hideSilver":
Config.HideSilver = true; Config.HideSilver = true;
return "Hiding silver time"; message = "Hiding silver time";
break;
case "showSilver": case "showSilver":
Config.HideSilver = false; Config.HideSilver = false;
return "Showing silver time"; message = "Showing silver time";
case "enable": break;
Config.Enabled = true;
return "Mod enabled";
case "disable":
Config.Enabled = false;
return "Mod disabled";
case "save":
Config.SaveConfig();
return "Config file saved";
case "load":
Config.ReadConfig();
return "Config file loaded";
default: default:
printUsage(); printUsage();
// Return early (no auto save)
return ""; return "";
} }
Config.SaveConfig();
return message;
} }
} }
} }

View file

@ -8,7 +8,7 @@ namespace DiamondTimeViewer.Patches
{ {
static void Postfix(GamePlayManager __instance, MarbleController marble) static void Postfix(GamePlayManager __instance, MarbleController marble)
{ {
if (!Config.Enabled) if (Config.Mode == DisplayMode.Never)
return; return;
if ((__instance.PlayType == PlayType.Normal || __instance.PlayType == PlayType.Ghost) && !MarbleManager.usedRewind && LevelSelect.instance != null) if ((__instance.PlayType == PlayType.Normal || __instance.PlayType == PlayType.Ghost) && !MarbleManager.usedRewind && LevelSelect.instance != null)

View file

@ -8,7 +8,7 @@ namespace DiamondTimeViewer.Patches
{ {
static bool Prefix(MedalsDisplay __instance, float silver, float gold, List<string> eggUnlock) static bool Prefix(MedalsDisplay __instance, float silver, float gold, List<string> eggUnlock)
{ {
if (!Config.Enabled) if (Config.Mode == DisplayMode.Never)
return true; return true;
// Get diamond time (since it is not passed in as a parameter) // Get diamond time (since it is not passed in as a parameter)
@ -28,9 +28,6 @@ namespace DiamondTimeViewer.Patches
case DisplayMode.Gold: case DisplayMode.Gold:
showDiamondTime = LevelSelect.instance.bestScore > 0f && LevelSelect.instance.bestScore <= gold; showDiamondTime = LevelSelect.instance.bestScore > 0f && LevelSelect.instance.bestScore <= gold;
break; break;
case DisplayMode.Never:
showDiamondTime = false;
break;
} }
} }

View file

@ -16,17 +16,15 @@ This is a mod of [Marble It Up! Ultra](https://marbleitup.com/) which allows you
All of these options can be configured by editing `config.json` or using the `dtv` console command. All of these options can be configured by editing `config.json` or using the `dtv` console command.
There are a few modes which I felt made sense as a way to show diamond times. They are as follows, in order of most to least restrictive: There are a few modes which I felt made sense as a way to show diamond times. They are as follows, in order of most to least restrictive:
* Never show diamond times. This should be the same as not having the mod installed, unless I made a mistake somewhere. * `never`: Never show diamond times. This option disables the mod and lets the original code run.
* Only show the diamond time after you have achieved it. **This is the default mode.** * `diamond`: Only show the diamond time after you have achieved it. **This is the default mode.**
* Show the diamond time after you have achieved the gold time. This is to help players who can achieve gold times, but might not want to commit to grinding a diamond time unless they think they can achieve it. * `gold`: Show the diamond time after you have achieved the gold time. This is to help players who can achieve gold times, but might not want to commit to grinding a diamond time unless they think they can achieve it.
* Always show diamond times no matter what. * `always`: Always show diamond times no matter what.
When showing the diamond time, it will show three times instead of two, making things slightly more cluttered. If this is bothersome, I added some additonal options: When showing the diamond time, it will show three times instead of two, making things slightly more cluttered. If this is bothersome, I added some additonal options:
* Show silver time no matter what. **This is the default mode.** * Show silver time no matter what. **This is the default mode.**
* Hide the silver time when showing the diamond time. This means that no matter what, you will always see exactly two times in the menu. When the diamond time is being displayed, it will not display the silver time, so it will only show the gold and diamond time and retain a similar layout to the vanilla game. * Hide the silver time when showing the diamond time. This means that no matter what, you will always see exactly two times in the menu. When the diamond time is being displayed, it will not display the silver time, so it will only show the gold and diamond time and retain a similar layout to the vanilla game.
For some reason, I also felt the need to include the ability to disable the mod entirely. The mod being completely disabled _should be_ the same as selecting the mode "never". But if I made any mistakes, there could be differences, and if there are, please report them!
## Build ## Build
If you just want to use the mod, refer to the Usage section above. These instructions are if you want to compile the mod itself. If you just want to use the mod, refer to the Usage section above. These instructions are if you want to compile the mod itself.