From 6ed5283bc06a62f38eb517e67b975832b603bf61 Mon Sep 17 00:00:00 2001
From: Jeff Ames
Date: Tue, 5 Feb 2008 19:44:27 +0000
Subject: Converted logging to use log4net. Changed LogBase to ConsoleBase,
which handles console I/O. This is mostly an in-place conversion, so lots of
refactoring can still be done.
---
OpenSim/Framework/Console/ConsoleBase.cs | 433 ++++++++++++++++++++++++++
OpenSim/Framework/Console/LogBase.cs | 511 -------------------------------
OpenSim/Framework/Console/MainConsole.cs | 41 +++
OpenSim/Framework/Console/MainLog.cs | 40 ---
4 files changed, 474 insertions(+), 551 deletions(-)
create mode 100644 OpenSim/Framework/Console/ConsoleBase.cs
delete mode 100644 OpenSim/Framework/Console/LogBase.cs
create mode 100644 OpenSim/Framework/Console/MainConsole.cs
delete mode 100644 OpenSim/Framework/Console/MainLog.cs
(limited to 'OpenSim/Framework/Console')
diff --git a/OpenSim/Framework/Console/ConsoleBase.cs b/OpenSim/Framework/Console/ConsoleBase.cs
new file mode 100644
index 0000000..3f68e50
--- /dev/null
+++ b/OpenSim/Framework/Console/ConsoleBase.cs
@@ -0,0 +1,433 @@
+/*
+* 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;
+using System.Collections.Generic;
+using System.Diagnostics;
+using System.IO;
+using System.Net;
+
+namespace OpenSim.Framework.Console
+{
+ public class ConsoleBase
+ {
+ private static readonly log4net.ILog m_log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
+
+ private object m_syncRoot = new object();
+
+ public conscmd_callback m_cmdParser;
+ public string m_componentName;
+
+ public ConsoleBase(string componentname, conscmd_callback cmdparser)
+ {
+ m_componentName = componentname;
+ m_cmdParser = cmdparser;
+
+ System.Console.WriteLine("Creating new local console");
+
+ m_log.Info("[" + m_componentName + "]: Started at " + DateTime.Now.ToString());
+ }
+
+ public void Close()
+ {
+ m_log.Info("[" + m_componentName + "]: Shutdown at " + DateTime.Now.ToString());
+ }
+
+ ///
+ /// derive an ansi color from a string, ignoring the darker colors.
+ /// This is used to help automatically bin component tags with colors
+ /// in various print functions.
+ ///
+ /// arbitrary string for input
+ /// an ansii color
+ private ConsoleColor DeriveColor(string input)
+ {
+ int colIdx = (input.ToUpper().GetHashCode() % 6) + 9;
+ return (ConsoleColor) colIdx;
+ }
+
+ ///
+ /// Sends a warning to the current console output
+ ///
+ /// The message to send
+ /// WriteLine-style message arguments
+ public void Warn(string format, params object[] args)
+ {
+ WriteNewLine(ConsoleColor.Yellow, format, args);
+ }
+
+ ///
+ /// Sends a warning to the current console output
+ ///
+ /// The module that sent this message
+ /// The message to send
+ /// WriteLine-style message arguments
+ public void Warn(string sender, string format, params object[] args)
+ {
+ WritePrefixLine(DeriveColor(sender), sender);
+ WriteNewLine(ConsoleColor.Yellow, format, args);
+ }
+
+ ///
+ /// Sends a notice to the current console output
+ ///
+ /// The message to send
+ /// WriteLine-style message arguments
+ public void Notice(string format, params object[] args)
+ {
+ WriteNewLine(ConsoleColor.White, format, args);
+ }
+
+ ///
+ /// Sends a notice to the current console output
+ ///
+ /// The module that sent this message
+ /// The message to send
+ /// WriteLine-style message arguments
+ public void Notice(string sender, string format, params object[] args)
+ {
+ WritePrefixLine(DeriveColor(sender), sender);
+ WriteNewLine(ConsoleColor.White, format, args);
+ }
+
+ ///
+ /// Sends an error to the current console output
+ ///
+ /// The message to send
+ /// WriteLine-style message arguments
+ public void Error(string format, params object[] args)
+ {
+ WriteNewLine(ConsoleColor.Red, format, args);
+ }
+
+ ///
+ /// Sends an error to the current console output
+ ///
+ /// The module that sent this message
+ /// The message to send
+ /// WriteLine-style message arguments
+ public void Error(string sender, string format, params object[] args)
+ {
+ WritePrefixLine(DeriveColor(sender), sender);
+ Error(format, args);
+ }
+
+ ///
+ /// Sends a status message to the current console output
+ ///
+ /// The message to send
+ /// WriteLine-style message arguments
+ public void Status(string format, params object[] args)
+ {
+ WriteNewLine(ConsoleColor.Blue, format, args);
+ }
+
+ ///
+ /// Sends a status message to the current console output
+ ///
+ /// The module that sent this message
+ /// The message to send
+ /// WriteLine-style message arguments
+ public void Status(string sender, string format, params object[] args)
+ {
+ WritePrefixLine(DeriveColor(sender), sender);
+ WriteNewLine(ConsoleColor.Blue, format, args);
+ }
+
+ [Conditional("DEBUG")]
+ public void Debug(string format, params object[] args)
+ {
+ WriteNewLine(ConsoleColor.Gray, format, args);
+ }
+
+ [Conditional("DEBUG")]
+ public void Debug(string sender, string format, params object[] args)
+ {
+ WritePrefixLine(DeriveColor(sender), sender);
+ WriteNewLine(ConsoleColor.Gray, format, args);
+ }
+
+ private void WriteNewLine(ConsoleColor color, string format, params object[] args)
+ {
+ try
+ {
+ lock (m_syncRoot)
+ {
+ try
+ {
+ System.Console.WriteLine(format, args);
+ }
+
+ catch (FormatException)
+ {
+ System.Console.WriteLine(args);
+ }
+
+ try
+ {
+ if (color != ConsoleColor.White)
+ System.Console.ForegroundColor = color;
+
+ System.Console.WriteLine(format, args);
+ System.Console.ResetColor();
+ }
+ catch (ArgumentNullException)
+ {
+ // Some older systems dont support coloured text.
+ System.Console.WriteLine(format, args);
+ }
+ catch (FormatException)
+ {
+ // Some older systems dont support coloured text.
+ System.Console.WriteLine(args);
+ }
+ }
+ }
+ catch (ObjectDisposedException)
+ {
+ }
+ }
+
+ private void WritePrefixLine(ConsoleColor color, string sender)
+ {
+ try
+ {
+ lock (m_syncRoot)
+ {
+ sender = sender.ToUpper();
+
+ System.Console.WriteLine("[" + sender + "] ");
+
+ System.Console.Write("[");
+
+ try
+ {
+ System.Console.ForegroundColor = color;
+ System.Console.Write(sender);
+ System.Console.ResetColor();
+ }
+ catch (ArgumentNullException)
+ {
+ // Some older systems dont support coloured text.
+ System.Console.WriteLine(sender);
+ }
+
+ System.Console.Write("] \t");
+ }
+ }
+ catch (ObjectDisposedException)
+ {
+ }
+ }
+
+ public string ReadLine()
+ {
+ try
+ {
+ return System.Console.ReadLine();
+ }
+ catch (Exception e)
+ {
+ m_log.Error("[Console]: System.Console.ReadLine exception " + e.ToString());
+ return String.Empty;
+ }
+ }
+
+ public int Read()
+ {
+ return System.Console.Read();
+ }
+
+ public IPAddress CmdPromptIPAddress(string prompt, string defaultvalue)
+ {
+ IPAddress address;
+ string addressStr;
+
+ while (true)
+ {
+ addressStr = CmdPrompt(prompt, defaultvalue);
+ if (IPAddress.TryParse(addressStr, out address))
+ {
+ break;
+ }
+ else
+ {
+ m_log.Error("Illegal address. Please re-enter.");
+ }
+ }
+
+ return address;
+ }
+
+ public uint CmdPromptIPPort(string prompt, string defaultvalue)
+ {
+ uint port;
+ string portStr;
+
+ while (true)
+ {
+ portStr = CmdPrompt(prompt, defaultvalue);
+ if (uint.TryParse(portStr, out port))
+ {
+ if (port >= IPEndPoint.MinPort && port <= IPEndPoint.MaxPort)
+ {
+ break;
+ }
+ }
+
+ m_log.Error("Illegal address. Please re-enter.");
+ }
+
+ return port;
+ }
+
+ // Displays a prompt and waits for the user to enter a string, then returns that string
+ // Done with no echo and suitable for passwords
+ public string PasswdPrompt(string prompt)
+ {
+ // FIXME: Needs to be better abstracted
+ ConsoleColor oldfg = System.Console.ForegroundColor;
+ System.Console.ForegroundColor = System.Console.BackgroundColor;
+ string temp = System.Console.ReadLine();
+ System.Console.ForegroundColor = oldfg;
+ return temp;
+ }
+
+ // Displays a command prompt and waits for the user to enter a string, then returns that string
+ public string CmdPrompt(string prompt)
+ {
+ System.Console.WriteLine(String.Format("{0}: ", prompt));
+ return ReadLine();
+ }
+
+ // Displays a command prompt and returns a default value if the user simply presses enter
+ public string CmdPrompt(string prompt, string defaultresponse)
+ {
+ string temp = CmdPrompt(String.Format("{0} [{1}]", prompt, defaultresponse));
+ if (temp == String.Empty)
+ {
+ return defaultresponse;
+ }
+ else
+ {
+ return temp;
+ }
+ }
+
+ // Displays a command prompt and returns a default value, user may only enter 1 of 2 options
+ public string CmdPrompt(string prompt, string defaultresponse, string OptionA, string OptionB)
+ {
+ bool itisdone = false;
+ string temp = CmdPrompt(prompt, defaultresponse);
+ while (itisdone == false)
+ {
+ if ((temp == OptionA) || (temp == OptionB))
+ {
+ itisdone = true;
+ }
+ else
+ {
+ System.Console.WriteLine("Valid options are " + OptionA + " or " + OptionB);
+ temp = CmdPrompt(prompt, defaultresponse);
+ }
+ }
+ return temp;
+ }
+
+ // Runs a command with a number of parameters
+ public Object RunCmd(string Cmd, string[] cmdparams)
+ {
+ m_cmdParser.RunCmd(Cmd, cmdparams);
+ return null;
+ }
+
+ // Shows data about something
+ public void ShowCommands(string ShowWhat)
+ {
+ m_cmdParser.Show(ShowWhat);
+ }
+
+ public void Prompt()
+ {
+ string tempstr = CmdPrompt(m_componentName + "# ");
+ RunCommand(tempstr);
+ }
+
+ public void RunCommand(string command)
+ {
+ string[] tempstrarray;
+ tempstrarray = command.Split(' ');
+ string cmd = tempstrarray[0];
+ Array.Reverse(tempstrarray);
+ Array.Resize(ref tempstrarray, tempstrarray.Length - 1);
+ Array.Reverse(tempstrarray);
+ string[] cmdparams = (string[]) tempstrarray;
+ try
+ {
+ RunCmd(cmd, cmdparams);
+ }
+ catch (Exception e)
+ {
+ m_log.Error("[Console]: Command failed with exception " + e.ToString());
+ }
+ }
+
+ public string LineInfo
+ {
+ get
+ {
+ string result = String.Empty;
+
+ string stacktrace = Environment.StackTrace;
+ List lines = new List(stacktrace.Split(new string[] {"at "}, StringSplitOptions.None));
+
+ if (lines.Count > 4)
+ {
+ lines.RemoveRange(0, 4);
+
+ string tmpLine = lines[0];
+
+ int inIndex = tmpLine.IndexOf(" in ");
+
+ if (inIndex > -1)
+ {
+ result = tmpLine.Substring(0, inIndex);
+
+ int lineIndex = tmpLine.IndexOf(":line ");
+
+ if (lineIndex > -1)
+ {
+ lineIndex += 6;
+ result += ", line " + tmpLine.Substring(lineIndex, (tmpLine.Length - lineIndex) - 5);
+ }
+ }
+ }
+ return result;
+ }
+ }
+ }
+}
diff --git a/OpenSim/Framework/Console/LogBase.cs b/OpenSim/Framework/Console/LogBase.cs
deleted file mode 100644
index a2c4b3a..0000000
--- a/OpenSim/Framework/Console/LogBase.cs
+++ /dev/null
@@ -1,511 +0,0 @@
-/*
-* 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;
-using System.Collections.Generic;
-using System.Diagnostics;
-using System.IO;
-using System.Net;
-
-namespace OpenSim.Framework.Console
-{
- public enum LogPriority : int
- {
- CRITICAL,
- HIGH,
- MEDIUM,
- NORMAL,
- LOW,
- VERBOSE,
- EXTRAVERBOSE
- }
-
- public class LogBase
- {
- private object m_syncRoot = new object();
-
- private StreamWriter Log;
- public conscmd_callback cmdparser;
- public string componentname;
- private bool m_verbose;
-
- public LogBase(string LogFile, string componentname, conscmd_callback cmdparser, bool verbose)
- {
- this.componentname = componentname;
- this.cmdparser = cmdparser;
- m_verbose = verbose;
- System.Console.WriteLine("Creating new local console");
-
- if (String.IsNullOrEmpty(LogFile))
- {
- LogFile = componentname + ".log";
- }
-
- System.Console.WriteLine("Logs will be saved to current directory in " + LogFile);
-
- try
- {
- Log = File.AppendText(LogFile);
- }
- catch (Exception ex)
- {
- System.Console.WriteLine("Unable to open log file. Do you already have another copy of OpenSim running? Permission problem?");
- System.Console.WriteLine(ex.Message);
- System.Console.WriteLine("");
- System.Console.WriteLine("Application is terminating.");
- System.Console.WriteLine("");
- System.Threading.Thread.CurrentThread.Abort();
- }
- Log.WriteLine("========================================================================");
- Log.WriteLine(componentname + " Started at " + DateTime.Now.ToString());
- }
-
- public void Close()
- {
- Log.WriteLine("Shutdown at " + DateTime.Now.ToString());
- Log.Close();
- }
-
- ///
- /// derive an ansi color from a string, ignoring the darker colors.
- /// This is used to help automatically bin component tags with colors
- /// in various print functions.
- ///
- /// arbitrary string for input
- /// an ansii color
- private ConsoleColor DeriveColor(string input)
- {
- int colIdx = (input.ToUpper().GetHashCode()%6) + 9;
- return (ConsoleColor) colIdx;
- }
-
- ///
- /// Sends a warning to the current log output
- ///
- /// The message to send
- /// WriteLine-style message arguments
- public void Warn(string format, params object[] args)
- {
- WriteNewLine(ConsoleColor.Yellow, format, args);
- return;
- }
-
- ///
- /// Sends a warning to the current log output
- ///
- /// The module that sent this message
- /// The message to send
- /// WriteLine-style message arguments
- public void Warn(string sender, string format, params object[] args)
- {
- WritePrefixLine(DeriveColor(sender), sender);
- WriteNewLine(ConsoleColor.Yellow, format, args);
- return;
- }
-
- ///
- /// Sends a notice to the current log output
- ///
- /// The message to send
- /// WriteLine-style message arguments
- public void Notice(string format, params object[] args)
- {
- WriteNewLine(ConsoleColor.White, format, args);
- return;
- }
-
- ///
- /// Sends a notice to the current log output
- ///
- /// The module that sent this message
- /// The message to send
- /// WriteLine-style message arguments
- public void Notice(string sender, string format, params object[] args)
- {
- WritePrefixLine(DeriveColor(sender), sender);
- WriteNewLine(ConsoleColor.White, format, args);
- return;
- }
-
- ///
- /// Sends an error to the current log output
- ///
- /// The message to send
- /// WriteLine-style message arguments
- public void Error(string format, params object[] args)
- {
- WriteNewLine(ConsoleColor.Red, format, args);
- return;
- }
-
- ///
- /// Sends an error to the current log output
- ///
- /// The module that sent this message
- /// The message to send
- /// WriteLine-style message arguments
- public void Error(string sender, string format, params object[] args)
- {
- WritePrefixLine(DeriveColor(sender), sender);
- Error(format, args);
- return;
- }
-
- ///
- /// Sends an informational message to the current log output
- ///
- /// The module that sent this message
- /// The message to send
- /// WriteLine-style message arguments
- public void Verbose(string sender, string format, params object[] args)
- {
- if (m_verbose)
- {
- WritePrefixLine(DeriveColor(sender), sender);
- WriteNewLine(ConsoleColor.Gray, format, args);
- return;
- }
- }
-
- ///
- /// Sends a status message to the current log output
- ///
- /// The message to send
- /// WriteLine-style message arguments
- public void Status(string format, params object[] args)
- {
- WriteNewLine(ConsoleColor.Blue, format, args);
- return;
- }
-
- ///
- /// Sends a status message to the current log output
- ///
- /// The module that sent this message
- /// The message to send
- /// WriteLine-style message arguments
- public void Status(string sender, string format, params object[] args)
- {
- WritePrefixLine(DeriveColor(sender), sender);
- WriteNewLine(ConsoleColor.Blue, format, args);
- return;
- }
-
- [Conditional("DEBUG")]
- public void Debug(string format, params object[] args)
- {
- WriteNewLine(ConsoleColor.Gray, format, args);
- return;
- }
-
- [Conditional("DEBUG")]
- public void Debug(string sender, string format, params object[] args)
- {
- WritePrefixLine(DeriveColor(sender), sender);
- WriteNewLine(ConsoleColor.Gray, format, args);
- return;
- }
-
- private void WriteNewLine(ConsoleColor color, string format, params object[] args)
- {
- try
- {
- lock (m_syncRoot)
- {
- string now = DateTime.Now.ToString("[MM-dd HH:mm:ss] ");
- Log.Write(now);
- try
- {
- Log.WriteLine(format, args);
- Log.Flush();
- }
-
- catch (FormatException)
- {
- System.Console.WriteLine(args);
- }
- System.Console.Write(now);
- try
- {
- if (color != ConsoleColor.White)
- System.Console.ForegroundColor = color;
-
- System.Console.WriteLine(format, args);
- System.Console.ResetColor();
- }
- catch (ArgumentNullException)
- {
- // Some older systems dont support coloured text.
- System.Console.WriteLine(format, args);
- }
- catch (FormatException)
- {
- // Some older systems dont support coloured text.
- System.Console.WriteLine(args);
- }
-
- return;
- }
- }
- catch (ObjectDisposedException)
- {
- return;
- }
- }
-
- private void WritePrefixLine(ConsoleColor color, string sender)
- {
- try
- {
- lock (m_syncRoot)
- {
- sender = sender.ToUpper();
-
- Log.WriteLine("[" + sender + "] ");
-
-
- Log.Flush();
-
- System.Console.Write("[");
-
- try
- {
- System.Console.ForegroundColor = color;
- System.Console.Write(sender);
- System.Console.ResetColor();
- }
- catch (ArgumentNullException)
- {
- // Some older systems dont support coloured text.
- System.Console.WriteLine(sender);
- }
-
- System.Console.Write("] \t");
-
- return;
- }
- }
- catch (ObjectDisposedException)
- {
- return;
- }
- }
-
-
- public string ReadLine()
- {
- try
- {
- string TempStr = System.Console.ReadLine();
- Log.WriteLine(TempStr);
- return TempStr;
- }
- catch (Exception e)
- {
- MainLog.Instance.Error("Console", "System.Console.ReadLine exception " + e.ToString());
- return String.Empty;
- }
- }
-
- public int Read()
- {
- int TempInt = System.Console.Read();
- Log.Write((char) TempInt);
- return TempInt;
- }
-
- public IPAddress CmdPromptIPAddress(string prompt, string defaultvalue)
- {
- IPAddress address;
- string addressStr;
-
- while (true)
- {
- addressStr = MainLog.Instance.CmdPrompt(prompt, defaultvalue);
- if (IPAddress.TryParse(addressStr, out address))
- {
- break;
- }
- else
- {
- MainLog.Instance.Error("Illegal address. Please re-enter.");
- }
- }
-
- return address;
- }
-
- public uint CmdPromptIPPort(string prompt, string defaultvalue)
- {
- uint port;
- string portStr;
-
- while (true)
- {
- portStr = MainLog.Instance.CmdPrompt(prompt, defaultvalue);
- if (uint.TryParse(portStr, out port))
- {
- if (port >= IPEndPoint.MinPort && port <= IPEndPoint.MaxPort)
- {
- break;
- }
- }
-
- MainLog.Instance.Error("Illegal address. Please re-enter.");
- }
-
- return port;
- }
-
- // Displays a prompt and waits for the user to enter a string, then returns that string
- // Done with no echo and suitable for passwords
- public string PasswdPrompt(string prompt)
- {
- // FIXME: Needs to be better abstracted
- Log.WriteLine(prompt);
- Notice(prompt);
- ConsoleColor oldfg = System.Console.ForegroundColor;
- System.Console.ForegroundColor = System.Console.BackgroundColor;
- string temp = System.Console.ReadLine();
- System.Console.ForegroundColor = oldfg;
- return temp;
- }
-
- // Displays a command prompt and waits for the user to enter a string, then returns that string
- public string CmdPrompt(string prompt)
- {
- Notice(String.Format("{0}: ", prompt));
- return ReadLine();
- }
-
- // Displays a command prompt and returns a default value if the user simply presses enter
- public string CmdPrompt(string prompt, string defaultresponse)
- {
- string temp = CmdPrompt(String.Format("{0} [{1}]", prompt, defaultresponse));
- if (temp == String.Empty)
- {
- return defaultresponse;
- }
- else
- {
- return temp;
- }
- }
-
- // Displays a command prompt and returns a default value, user may only enter 1 of 2 options
- public string CmdPrompt(string prompt, string defaultresponse, string OptionA, string OptionB)
- {
- bool itisdone = false;
- string temp = CmdPrompt(prompt, defaultresponse);
- while (itisdone == false)
- {
- if ((temp == OptionA) || (temp == OptionB))
- {
- itisdone = true;
- }
- else
- {
- Notice("Valid options are " + OptionA + " or " + OptionB);
- temp = CmdPrompt(prompt, defaultresponse);
- }
- }
- return temp;
- }
-
- // Runs a command with a number of parameters
- public Object RunCmd(string Cmd, string[] cmdparams)
- {
- cmdparser.RunCmd(Cmd, cmdparams);
- return null;
- }
-
- // Shows data about something
- public void ShowCommands(string ShowWhat)
- {
- cmdparser.Show(ShowWhat);
- }
-
- public void MainLogPrompt()
- {
- string tempstr = CmdPrompt(componentname + "# ");
- MainLogRunCommand(tempstr);
- }
-
- public void MainLogRunCommand(string command)
- {
- string[] tempstrarray;
- tempstrarray = command.Split(' ');
- string cmd = tempstrarray[0];
- Array.Reverse(tempstrarray);
- Array.Resize(ref tempstrarray, tempstrarray.Length - 1);
- Array.Reverse(tempstrarray);
- string[] cmdparams = (string[]) tempstrarray;
- try
- {
- RunCmd(cmd, cmdparams);
- }
- catch (Exception e)
- {
- MainLog.Instance.Error("Console", "Command failed with exception " + e.ToString());
- }
- }
-
- public string LineInfo
- {
- get
- {
- string result = String.Empty;
-
- string stacktrace = Environment.StackTrace;
- List lines = new List(stacktrace.Split(new string[] {"at "}, StringSplitOptions.None));
-
- if (lines.Count > 4)
- {
- lines.RemoveRange(0, 4);
-
- string tmpLine = lines[0];
-
- int inIndex = tmpLine.IndexOf(" in ");
-
- if (inIndex > -1)
- {
- result = tmpLine.Substring(0, inIndex);
-
- int lineIndex = tmpLine.IndexOf(":line ");
-
- if (lineIndex > -1)
- {
- lineIndex += 6;
- result += ", line " + tmpLine.Substring(lineIndex, (tmpLine.Length - lineIndex) - 5);
- }
- }
- }
- return result;
- }
- }
- }
-}
diff --git a/OpenSim/Framework/Console/MainConsole.cs b/OpenSim/Framework/Console/MainConsole.cs
new file mode 100644
index 0000000..fb88d04
--- /dev/null
+++ b/OpenSim/Framework/Console/MainConsole.cs
@@ -0,0 +1,41 @@
+/*
+* 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.
+*
+*/
+
+namespace OpenSim.Framework.Console
+{
+ public class MainConsole
+ {
+ private static ConsoleBase instance;
+
+ public static ConsoleBase Instance
+ {
+ get { return instance; }
+ set { instance = value; }
+ }
+ }
+}
\ No newline at end of file
diff --git a/OpenSim/Framework/Console/MainLog.cs b/OpenSim/Framework/Console/MainLog.cs
deleted file mode 100644
index bea2a22..0000000
--- a/OpenSim/Framework/Console/MainLog.cs
+++ /dev/null
@@ -1,40 +0,0 @@
-/*
-* 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.
-*
-*/
-namespace OpenSim.Framework.Console
-{
- public class MainLog
- {
- private static LogBase instance;
-
- public static LogBase Instance
- {
- get { return instance; }
- set { instance = value; }
- }
- }
-}
\ No newline at end of file
--
cgit v1.1