summaryrefslogtreecommitdiff
path: root/src/TrainerMod/Framework/Commands/Player/AddRingCommand.cs
diff options
context:
space:
mode:
authorJesse Plamondon-Willard <github@jplamondonw.com>2017-07-02 01:32:07 -0400
committerJesse Plamondon-Willard <github@jplamondonw.com>2017-07-02 01:32:07 -0400
commitf9482906ae7ce4dfd41bb4236e094be5d4fa7689 (patch)
treed1f881d2e44d39090c55f9290113a957bc031cad /src/TrainerMod/Framework/Commands/Player/AddRingCommand.cs
parent6364e162f22973201b9da69f76db512005a5501e (diff)
downloadSMAPI-f9482906ae7ce4dfd41bb4236e094be5d4fa7689.tar.gz
SMAPI-f9482906ae7ce4dfd41bb4236e094be5d4fa7689.tar.bz2
SMAPI-f9482906ae7ce4dfd41bb4236e094be5d4fa7689.zip
split TrainerMod commands into separate classes (#302)
Diffstat (limited to 'src/TrainerMod/Framework/Commands/Player/AddRingCommand.cs')
-rw-r--r--src/TrainerMod/Framework/Commands/Player/AddRingCommand.cs47
1 files changed, 47 insertions, 0 deletions
diff --git a/src/TrainerMod/Framework/Commands/Player/AddRingCommand.cs b/src/TrainerMod/Framework/Commands/Player/AddRingCommand.cs
new file mode 100644
index 00000000..d62d8b5b
--- /dev/null
+++ b/src/TrainerMod/Framework/Commands/Player/AddRingCommand.cs
@@ -0,0 +1,47 @@
+using System.Linq;
+using StardewModdingAPI;
+using StardewValley;
+using StardewValley.Objects;
+
+namespace TrainerMod.Framework.Commands.Player
+{
+ /// <summary>A command which adds a ring to the player inventory.</summary>
+ internal class AddRingCommand : TrainerCommand
+ {
+ /*********
+ ** Public methods
+ *********/
+ /// <summary>Construct an instance.</summary>
+ public AddRingCommand()
+ : base("player_addring", "Gives the player a ring.\n\nUsage: player_addring <item>\n- item: the ring ID (use the 'list_items' command to see a list).") { }
+
+ /// <summary>Handle the command.</summary>
+ /// <param name="monitor">Writes messages to the console and log file.</param>
+ /// <param name="command">The command name.</param>
+ /// <param name="args">The command arguments.</param>
+ public override void Handle(IMonitor monitor, string command, string[] args)
+ {
+ // validate
+ if (!args.Any())
+ {
+ this.LogArgumentsInvalid(monitor, command);
+ return;
+ }
+ if (!int.TryParse(args[0], out int ringID))
+ {
+ monitor.Log("<item> is invalid", LogLevel.Error);
+ return;
+ }
+ if (ringID < Ring.ringLowerIndexRange || ringID > Ring.ringUpperIndexRange)
+ {
+ monitor.Log($"There is no such ring ID (must be between {Ring.ringLowerIndexRange} and {Ring.ringUpperIndexRange}).", LogLevel.Error);
+ return;
+ }
+
+ // handle
+ Ring ring = new Ring(ringID);
+ Game1.player.addItemByMenuIfNecessary(ring);
+ monitor.Log($"OK, added {ring.Name} to your inventory.", LogLevel.Info);
+ }
+ }
+}