Mantis#1499. Thank you kindly, DMiles for a patch that:

was incorrectly sending the command along with the args to the CommandDelegate
help was getting lost on top of normal help & help was getting missed except 
in an exact match (and only returning the first)
0.6.0-stable
Charles Krinke 2008-06-08 00:34:00 +00:00
parent 0e5f2b3293
commit 4ea9183b66
1 changed files with 134 additions and 79 deletions

View File

@ -58,6 +58,10 @@ namespace OpenSim
private string m_timedScript = "disabled"; private string m_timedScript = "disabled";
private Timer m_scriptTimer; private Timer m_scriptTimer;
/// <summary>
/// List of Console Plugin Commands
/// </summary>
private static List<ConsolePluginCommand> m_PluginCommandInfos = new List<ConsolePluginCommand>();
public OpenSim(IConfigSource configSource) : base(configSource) public OpenSim(IConfigSource configSource) : base(configSource)
{ {
@ -226,7 +230,6 @@ namespace OpenSim
break; break;
case "help": case "help":
RunPluginCommandHelp(CombineParams(cmdparams, 0),m_console);
m_console.Notice("alert - send alert to a designated user or all users."); m_console.Notice("alert - send alert to a designated user or all users.");
m_console.Notice(" alert [First] [Last] [Message] - send an alert to a user. Case sensitive."); m_console.Notice(" alert [First] [Last] [Message] - send an alert to a user. Case sensitive.");
m_console.Notice(" alert general [Message] - send an alert to all users."); m_console.Notice(" alert general [Message] - send an alert to all users.");
@ -259,6 +262,7 @@ namespace OpenSim
m_console.Notice("config get section field - get a config value"); m_console.Notice("config get section field - get a config value");
m_console.Notice("config save - save OpenSim.ini"); m_console.Notice("config save - save OpenSim.ini");
m_console.Notice("terrain help - show help for terrain commands."); m_console.Notice("terrain help - show help for terrain commands.");
ShowPluginCommandsHelp(CombineParams(cmdparams, 0), m_console);
break; break;
case "threads": case "threads":
@ -673,97 +677,148 @@ namespace OpenSim
return result; return result;
} }
/// <summary>
/// Runs the best matching plugin command
///
/// returns true if a match was found, false otherwise.
/// </summary>
public bool RunPluginCommands(string cmdWithParams)
{
ConsolePluginCommand bestMatch = null;
int bestLength = 0;
foreach (ConsolePluginCommand cmdinfo in m_PluginCommandInfos)
{
int matchLen = cmdinfo.matchLength(cmdWithParams);
if (matchLen > bestLength)
{
bestMatch = cmdinfo;
bestLength = matchLen;
}
}
if (bestMatch == null) return false;
bestMatch.Run(cmdWithParams.Substring(bestLength));
return true;
}
/// <summary>
/// Show the matching plugins command help
/// </summary>
public void ShowPluginCommandsHelp(string cmdWithParams, ConsoleBase console)
{
foreach (ConsolePluginCommand cmdinfo in m_PluginCommandInfos)
{
if (cmdinfo.IsHelpfull(cmdWithParams))
{
cmdinfo.ShowHelp(console);
}
}
}
/// <summary>
/// Registers a new console plugin command
/// </summary>
public static void RegisterCmd(string cmd, ConsoleCommand deligate, string help)
{
RegisterConsolePluginCommand(new ConsolePluginCommand(cmd, deligate, help));
}
/// <summary>
/// Registers a new console plugin command
/// </summary>
public static void RegisterConsolePluginCommand(ConsolePluginCommand pluginCommand)
{
m_PluginCommandInfos.Add(pluginCommand);
}
#endregion #endregion
static private List<ConsolePluginCommand> m_PluginCommandInfos = new List<ConsolePluginCommand>();
public bool RunPluginCommands(string cmd)
{
ConsolePluginCommand bestMatch = null;
int bestLength = 0;
foreach (ConsolePluginCommand cmdinfo in m_PluginCommandInfos)
{
int matchLen = cmdinfo.matchLength(cmd);
if (matchLen > bestLength)
{
bestMatch = cmdinfo;
bestLength = matchLen;
} }
} /// <summary>
if (bestMatch == null) /// Holder object for a new console plugin command
{ ///
return false; /// Override the methods like Run and IsHelpfull (but the defaults might work ok.)
} /// </summary>
bestMatch.Run(cmd);
return true;
}
public bool RunPluginCommandHelp(string cmd, ConsoleBase console)
{
ConsolePluginCommand bestMatch = null;
int bestLength = 0;
foreach (ConsolePluginCommand cmdinfo in m_PluginCommandInfos)
{
int matchLen = cmdinfo.matchLength(cmd);
if (matchLen > bestLength)
{
bestMatch = cmdinfo;
bestLength = matchLen;
}
}
if (bestMatch == null)
{
return false;
}
bestMatch.ShowHelp(console);
return true;
}
public static void RegisterCmd(string cmd, ConsoleCommand deligate, string hlp)
{
m_PluginCommandInfos.Add(new ConsolePluginCommand(cmd, deligate, hlp));
}
public class ConsolePluginCommand public class ConsolePluginCommand
{ {
/// <summary>
/// command delegate used in running
/// </summary>
private ConsoleCommand m_commandDelegate; private ConsoleCommand m_commandDelegate;
/// <summary>
/// help text displayed
/// </summary>
private string m_helpText; private string m_helpText;
/// <summary>
/// command in the form of "showme new commands"
/// </summary>
private string m_cmdText; private string m_cmdText;
public int matchLength(string targetText) /// <summary>
/// Construct a new ConsolePluginCommand
///
/// for use with OpenSim.RegisterConsolePluginCommand(myCmd);
///
/// </summary>
/// <param name="command">in the form of "showme new commands"</param>
/// <param name="dlg">ommand delegate used in running</param>
/// <param name="help">the text displayed in "help showme new commands"</param>
public ConsolePluginCommand(string command, ConsoleCommand dlg, string help)
{
m_cmdText = command;
m_commandDelegate = dlg;
m_helpText = help;
}
/// <summary>
/// Returns the match length this command has upon the 'cmdWithParams'
/// At least a higher number for "show plugin status" then "show" would return
/// This is used to have multi length command verbs
///
/// @see OopenSim.RunPluginCommands
/// It will only run the one with the highest number
///
/// </summary>
public int matchLength(string cmdWithParams)
{ {
// QUESTION: have a case insensitive flag? // QUESTION: have a case insensitive flag?
targetText = targetText.ToLower(); cmdWithParams = cmdWithParams.ToLower().Trim();
string matchText = m_cmdText.ToLower(); string matchText = m_cmdText.ToLower().Trim();
if (targetText.StartsWith(matchText)) if (cmdWithParams.StartsWith(matchText))
{ {
// TODO return cmdText.Length; ? // QUESTION Instead return cmdText.Length; ?
return matchText.Length; return matchText.Length;
} }
return 0; return 0;
} }
public ConsolePluginCommand(string cmd, ConsoleCommand del, string help)
{
m_cmdText = cmd;
m_commandDelegate = del;
m_helpText = help;
}
public void Run(string incomming) /// <summary>
/// Run the delegate the incomming string may contain the command, if so, it is chopped off
/// </summary>
public void Run(string cmdParams)
{ {
string targetText = m_cmdText.ToLower(); string targetText = m_cmdText.ToLower();
string matchText = incomming.ToLower(); string matchText = cmdParams.ToLower();
if (targetText.StartsWith(matchText)) if (targetText.StartsWith(matchText))
{ {
incomming = incomming.Substring(matchText.Length); cmdParams = cmdParams.Substring(matchText.Length);
} }
m_commandDelegate(incomming.Split(new char[] {' '})); m_commandDelegate(cmdParams.Split(new char[] { ' ' }));
} }
/// <summary>
/// Shows help information on the console's Notice method
/// </summary>
public void ShowHelp(ConsoleBase console) public void ShowHelp(ConsoleBase console)
{ {
console.Notice(m_cmdText + ": " + m_helpText); console.Notice(m_cmdText + " - " + m_helpText);
// throw new Exception("The method or operation is not implemented."); }
}
/// <summary>
/// return true if the ShowHelp(..) method might be helpfull
/// </summary>
public bool IsHelpfull(string cmdWithParams)
{
cmdWithParams = cmdWithParams.ToLower();
return cmdWithParams.Contains(m_cmdText.ToLower()) || m_helpText.ToLower().Contains(cmdWithParams);
} }
} }
} }