try to fix console AGAIN

0.9.1.0-post-fixes
UbitUmarov 2019-10-22 11:55:27 +01:00
parent 7f8d5bbdce
commit 7939974d92
6 changed files with 114 additions and 14 deletions

View File

@ -35,6 +35,32 @@ using log4net;
namespace OpenSim.Framework.Console namespace OpenSim.Framework.Console
{ {
public class ConsoleLevel
{
public string m_string;
ConsoleLevel(string v)
{
m_string = v;
}
static public implicit operator ConsoleLevel(string s)
{
return new ConsoleLevel(s);
}
public static string ToString(ConsoleLevel s)
{
return s.m_string;
}
public override string ToString()
{
return m_string;
}
}
public class ConsoleBase : IConsole public class ConsoleBase : IConsole
{ {
// private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); // private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
@ -58,14 +84,39 @@ namespace OpenSim.Framework.Console
{ {
} }
public void Output(string format, params object[] components) public void Output(string format)
{ {
Output(format, null, components); System.Console.WriteLine(format);
} }
public virtual void Output(string format, string level, params object[] components) public virtual void Output(string format, params object[] components)
{ {
System.Console.WriteLine(format, components); string level = null;
if (components != null && components.Length > 0)
{
if (components[0] == null || components[0] is ConsoleLevel)
{
if (components[0] is ConsoleLevel)
level = ((ConsoleLevel)components[0]).ToString();
if (components.Length > 1)
{
object[] tmp = new object[components.Length - 1];
Array.Copy(components, 1, tmp, 0, components.Length - 1);
components = tmp;
}
else
components = null;
}
}
string text;
if (components == null || components.Length == 0)
text = format;
else
text = String.Format(format, components);
System.Console.WriteLine(text);
} }
public string Prompt(string p) public string Prompt(string p)

View File

@ -389,9 +389,32 @@ namespace OpenSim.Framework.Console
System.Console.WriteLine(); System.Console.WriteLine();
} }
public override void Output(string format, string level, params object[] components) public override void Output(string format, params object[] components)
{ {
string text = String.Format(format, components); string level = null;
if(components != null && components.Length > 0)
{
if(components[0] == null || components[0] is ConsoleLevel)
{
if(components[0] is ConsoleLevel)
level = ((ConsoleLevel)components[0]).ToString();
if (components.Length > 1)
{
object[] tmp = new object[components.Length - 1];
Array.Copy(components, 1, tmp, 0, components.Length - 1);
components = tmp;
}
else
components = null;
}
}
string text;
if (components == null || components.Length == 0)
text = format;
else
text = String.Format(format, components);
FireOnOutput(text); FireOnOutput(text);

View File

@ -62,8 +62,8 @@ namespace OpenSim.Framework.Console
set {} set {}
} }
public void Output(string format) { }
public void Output(string format, params object[] components) { } public void Output(string format, params object[] components) { }
public void Output(string format, string level, params object[] components) { }
public string Prompt(string p) { return ""; } public string Prompt(string p) { return ""; }
public string Prompt(string p, string def) { return ""; } public string Prompt(string p, string def) { return ""; }

View File

@ -55,12 +55,14 @@ namespace OpenSim.Framework.Console
{ {
if (m_console != null) if (m_console != null)
{ {
string level = "normal"; ConsoleLevel level;
if (le.Level == Level.Error) if (le.Level == Level.Error)
level = "error"; level = "error";
else if (le.Level == Level.Warn) else if (le.Level == Level.Warn)
level = "warn"; level = "warn";
else
level = "normal";
m_console.Output(loggingMessage, level); m_console.Output(loggingMessage, level);
} }

View File

@ -190,12 +190,34 @@ namespace OpenSim.Framework.Console
m_Server.AddHTTPHandler("/SessionCommand/", HandleHttpSessionCommand); m_Server.AddHTTPHandler("/SessionCommand/", HandleHttpSessionCommand);
} }
public override void Output(string format, string level = null, params object[] components) public override void Output(string format, params object[] components)
{ {
if (components.Length == 0) string level = null;
Output(format, level, false, false, false); if (components != null && components.Length > 0)
{
if (components[0] == null || components[0] is ConsoleLevel)
{
if (components[0] is ConsoleLevel)
level = ((ConsoleLevel)components[0]).ToString();
if (components.Length > 1)
{
object[] tmp = new object[components.Length - 1];
Array.Copy(components, 1, tmp, 0, components.Length - 1);
components = tmp;
}
else else
Output(String.Format(format, components), level, false, false, false); components = null;
}
}
string text;
if (components == null || components.Length == 0)
text = format;
else
text = String.Format(format, components);
Output(text, level, false, false, false);
} }
protected void Output(string text, string level, bool isPrompt, bool isCommand, bool isInput) protected void Output(string text, string level, bool isPrompt, bool isCommand, bool isInput)

View File

@ -32,10 +32,12 @@ namespace OpenSim.Framework
{ {
public interface IConsole public interface IConsole
{ {
IScene ConsoleScene { get; set; } IScene ConsoleScene { get; set; }
void Output(string format);
void Output(string format, params object[] components); void Output(string format, params object[] components);
void Output(string format, string level, params object[] components);
string Prompt(string p); string Prompt(string p);
string Prompt(string p, string def); string Prompt(string p, string def);