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 +++++++++++++++++++++++++++++++
1 file changed, 433 insertions(+)
create mode 100644 OpenSim/Framework/Console/ConsoleBase.cs
(limited to 'OpenSim/Framework/Console/ConsoleBase.cs')
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;
+ }
+ }
+ }
+}
--
cgit v1.1