using System.Linq;
using StardewValley;
namespace StardewModdingAPI.Mods.ConsoleCommands.Framework.Commands.Player
{
/// A command which edits the player's current health.
internal class SetHealthCommand : TrainerCommand
{
/*********
** Properties
*********/
/// Whether to keep the player's health at its maximum.
private bool InfiniteHealth;
/*********
** Accessors
*********/
/// Whether the command needs to perform logic when the game updates.
public override bool NeedsUpdate => this.InfiniteHealth;
/*********
** Public methods
*********/
/// Construct an instance.
public SetHealthCommand()
: base("player_sethealth", "Sets the player's health.\n\nUsage: player_sethealth [value]\n- value: an integer amount, or 'inf' for infinite health.") { }
/// Handle the command.
/// Writes messages to the console and log file.
/// The command name.
/// The command arguments.
public override void Handle(IMonitor monitor, string command, ArgumentParser args)
{
// no-argument mode
if (!args.Any())
{
monitor.Log($"You currently have {(this.InfiniteHealth ? "infinite" : Game1.player.health.ToString())} health. Specify a value to change it.", LogLevel.Info);
return;
}
// handle
string amountStr = args[0];
if (amountStr == "inf")
{
this.InfiniteHealth = true;
monitor.Log("OK, you now have infinite health.", LogLevel.Info);
}
else
{
this.InfiniteHealth = false;
if (int.TryParse(amountStr, out int amount))
{
Game1.player.health = amount;
monitor.Log($"OK, you now have {Game1.player.health} health.", LogLevel.Info);
}
else
this.LogArgumentNotInt(monitor);
}
}
/// Perform any logic needed on update tick.
/// Writes messages to the console and log file.
public override void Update(IMonitor monitor)
{
if (this.InfiniteHealth)
Game1.player.health = Game1.player.maxHealth;
}
}
}