* Hive off ConsolePluginCommand into its own framework class
parent
35d5b3991b
commit
451c3d1dd7
|
@ -0,0 +1,139 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) Contributors, http://opensimulator.org/
|
||||||
|
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
* * Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* * Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* * Neither the name of the OpenSim Project nor the
|
||||||
|
* names of its contributors may be used to endorse or promote products
|
||||||
|
* derived from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
|
||||||
|
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||||
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||||
|
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
using System;
|
||||||
|
|
||||||
|
namespace OpenSim.Framework.Console
|
||||||
|
{
|
||||||
|
public delegate void ConsoleCommand(string[] comParams);
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Holder object for a new console plugin command
|
||||||
|
///
|
||||||
|
/// Override the methods like Run and IsHelpfull (but the defaults might work ok.)
|
||||||
|
/// </summary>
|
||||||
|
public class ConsolePluginCommand
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// command delegate used in running
|
||||||
|
/// </summary>
|
||||||
|
private ConsoleCommand m_commandDelegate;
|
||||||
|
/// <summary>
|
||||||
|
/// help text displayed
|
||||||
|
/// </summary>
|
||||||
|
private string m_helpText;
|
||||||
|
/// <summary>
|
||||||
|
/// command in the form of "showme new commands"
|
||||||
|
/// </summary>
|
||||||
|
private string[] m_cmdText;
|
||||||
|
|
||||||
|
/// <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.Split(new char[] { ' ' });
|
||||||
|
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?
|
||||||
|
cmdWithParams = cmdWithParams.ToLower().Trim();
|
||||||
|
string matchText = String.Join(" ",m_cmdText).ToLower().Trim();
|
||||||
|
if (cmdWithParams.StartsWith(matchText))
|
||||||
|
{
|
||||||
|
// QUESTION Instead return cmdText.Length; ?
|
||||||
|
return matchText.Length;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Run the delegate the incomming string may contain the command, if so, it is chopped off the cmdParams[]
|
||||||
|
/// </summary>
|
||||||
|
public void Run(string cmd, string[] cmdParams)
|
||||||
|
{
|
||||||
|
int skipParams = 0;
|
||||||
|
if (m_cmdText.Length > 1)
|
||||||
|
{
|
||||||
|
int currentParam = 1;
|
||||||
|
while (currentParam < m_cmdText.Length)
|
||||||
|
{
|
||||||
|
if (cmdParams[skipParams].ToLower().Equals(m_cmdText[currentParam].ToLower()))
|
||||||
|
{
|
||||||
|
skipParams++;
|
||||||
|
}
|
||||||
|
currentParam++;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
string[] sendCmdParams = cmdParams;
|
||||||
|
if (skipParams > 0)
|
||||||
|
{
|
||||||
|
sendCmdParams = new string[cmdParams.Length-skipParams];
|
||||||
|
for (int i=0;i<sendCmdParams.Length;i++) {
|
||||||
|
sendCmdParams[i] = cmdParams[skipParams++];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
m_commandDelegate(sendCmdParams);//.Trim().Split(new char[] { ' ' }));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Shows help information on the console's Notice method
|
||||||
|
/// </summary>
|
||||||
|
public void ShowHelp(ConsoleBase console)
|
||||||
|
{
|
||||||
|
console.Notice(String.Join(" ", m_cmdText) + " - " + m_helpText);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// return true if the ShowHelp(..) method might be helpfull
|
||||||
|
/// </summary>
|
||||||
|
public bool IsHelpfull(string cmdWithParams)
|
||||||
|
{
|
||||||
|
cmdWithParams = cmdWithParams.ToLower();
|
||||||
|
return cmdWithParams.Contains(String.Join(" ", m_cmdText).ToLower()) || m_helpText.ToLower().Contains(cmdWithParams);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -44,8 +44,6 @@ using Timer=System.Timers.Timer;
|
||||||
|
|
||||||
namespace OpenSim
|
namespace OpenSim
|
||||||
{
|
{
|
||||||
public delegate void ConsoleCommand(string[] comParams);
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Interactive OpenSim region server
|
/// Interactive OpenSim region server
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -760,111 +758,4 @@ namespace OpenSim
|
||||||
}
|
}
|
||||||
#endregion
|
#endregion
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Holder object for a new console plugin command
|
|
||||||
///
|
|
||||||
/// Override the methods like Run and IsHelpfull (but the defaults might work ok.)
|
|
||||||
/// </summary>
|
|
||||||
public class ConsolePluginCommand
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// command delegate used in running
|
|
||||||
/// </summary>
|
|
||||||
private ConsoleCommand m_commandDelegate;
|
|
||||||
/// <summary>
|
|
||||||
/// help text displayed
|
|
||||||
/// </summary>
|
|
||||||
private string m_helpText;
|
|
||||||
/// <summary>
|
|
||||||
/// command in the form of "showme new commands"
|
|
||||||
/// </summary>
|
|
||||||
private string[] m_cmdText;
|
|
||||||
|
|
||||||
/// <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.Split(new char[] { ' ' });
|
|
||||||
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?
|
|
||||||
cmdWithParams = cmdWithParams.ToLower().Trim();
|
|
||||||
string matchText = String.Join(" ",m_cmdText).ToLower().Trim();
|
|
||||||
if (cmdWithParams.StartsWith(matchText))
|
|
||||||
{
|
|
||||||
// QUESTION Instead return cmdText.Length; ?
|
|
||||||
return matchText.Length;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Run the delegate the incomming string may contain the command, if so, it is chopped off the cmdParams[]
|
|
||||||
/// </summary>
|
|
||||||
public void Run(string cmd, string[] cmdParams)
|
|
||||||
{
|
|
||||||
int skipParams = 0;
|
|
||||||
if (m_cmdText.Length > 1)
|
|
||||||
{
|
|
||||||
int currentParam = 1;
|
|
||||||
while (currentParam < m_cmdText.Length)
|
|
||||||
{
|
|
||||||
if (cmdParams[skipParams].ToLower().Equals(m_cmdText[currentParam].ToLower()))
|
|
||||||
{
|
|
||||||
skipParams++;
|
|
||||||
}
|
|
||||||
currentParam++;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
string[] sendCmdParams = cmdParams;
|
|
||||||
if (skipParams > 0)
|
|
||||||
{
|
|
||||||
sendCmdParams = new string[cmdParams.Length-skipParams];
|
|
||||||
for (int i=0;i<sendCmdParams.Length;i++) {
|
|
||||||
sendCmdParams[i] = cmdParams[skipParams++];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
m_commandDelegate(sendCmdParams);//.Trim().Split(new char[] { ' ' }));
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Shows help information on the console's Notice method
|
|
||||||
/// </summary>
|
|
||||||
public void ShowHelp(ConsoleBase console)
|
|
||||||
{
|
|
||||||
console.Notice(String.Join(" ", m_cmdText) + " - " + m_helpText);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// return true if the ShowHelp(..) method might be helpfull
|
|
||||||
/// </summary>
|
|
||||||
public bool IsHelpfull(string cmdWithParams)
|
|
||||||
{
|
|
||||||
cmdWithParams = cmdWithParams.ToLower();
|
|
||||||
return cmdWithParams.Contains(String.Join(" ", m_cmdText).ToLower()) || m_helpText.ToLower().Contains(cmdWithParams);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,6 +38,7 @@ using Mono.Addins;
|
||||||
using Nini.Config;
|
using Nini.Config;
|
||||||
using OpenSim.Framework;
|
using OpenSim.Framework;
|
||||||
using OpenSim.Framework.Communications.Cache;
|
using OpenSim.Framework.Communications.Cache;
|
||||||
|
using OpenSim.Framework.Console;
|
||||||
using OpenSim.Framework.Servers;
|
using OpenSim.Framework.Servers;
|
||||||
using OpenSim.Framework.Statistics;
|
using OpenSim.Framework.Statistics;
|
||||||
using OpenSim.Region.ClientStack;
|
using OpenSim.Region.ClientStack;
|
||||||
|
|
Loading…
Reference in New Issue