using System; namespace StardewModdingAPI.Framework.ModHelpers { /// Provides an API for managing console commands. internal class CommandHelper : BaseHelper, ICommandHelper { /********* ** Accessors *********/ /// The mod using this instance. private readonly IModMetadata Mod; /// Manages console commands. private readonly CommandManager CommandManager; /********* ** Public methods *********/ /// Construct an instance. /// The mod using this instance. /// Manages console commands. public CommandHelper(IModMetadata mod, CommandManager commandManager) : base(mod?.Manifest?.UniqueID ?? "SMAPI") { this.Mod = mod; this.CommandManager = commandManager; } /// Add a console command. /// The command name, which the user must type to trigger it. /// The human-readable documentation shown when the player runs the built-in 'help' command. /// The method to invoke when the command is triggered. This method is passed the command name and arguments submitted by the user. /// The or is null or empty. /// The is not a valid format. /// There's already a command with that name. public ICommandHelper Add(string name, string documentation, Action callback) { this.CommandManager.Add(this.Mod, name, documentation, callback); return this; } /// Trigger a command. /// The command name. /// The command arguments. /// Returns whether a matching command was triggered. public bool Trigger(string name, string[] arguments) { return this.CommandManager.Trigger(name, arguments); } } }