Merge commit '903d5c02cb372af3fef5884d95312110229fbc1e' into bigmerge
commit
a8747b3888
|
@ -46,12 +46,11 @@ namespace OpenSim.Framework.Console
|
||||||
// private readonly object m_syncRoot = new object();
|
// private readonly object m_syncRoot = new object();
|
||||||
private const string LOGLEVEL_NONE = "(none)";
|
private const string LOGLEVEL_NONE = "(none)";
|
||||||
|
|
||||||
private int y = -1;
|
private int m_cursorYPosition = -1;
|
||||||
private int cp = 0;
|
private int m_cursorXPosition = 0;
|
||||||
private int h = 1;
|
private StringBuilder m_commandLine = new StringBuilder();
|
||||||
private StringBuilder cmdline = new StringBuilder();
|
private bool m_echo = true;
|
||||||
private bool echo = true;
|
private List<string> m_history = new List<string>();
|
||||||
private List<string> history = new List<string>();
|
|
||||||
|
|
||||||
private static readonly ConsoleColor[] Colors = {
|
private static readonly ConsoleColor[] Colors = {
|
||||||
// the dark colors don't seem to be visible on some black background terminals like putty :(
|
// the dark colors don't seem to be visible on some black background terminals like putty :(
|
||||||
|
@ -81,10 +80,10 @@ namespace OpenSim.Framework.Console
|
||||||
|
|
||||||
private void AddToHistory(string text)
|
private void AddToHistory(string text)
|
||||||
{
|
{
|
||||||
while (history.Count >= 100)
|
while (m_history.Count >= 100)
|
||||||
history.RemoveAt(0);
|
m_history.RemoveAt(0);
|
||||||
|
|
||||||
history.Add(text);
|
m_history.Add(text);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -111,11 +110,11 @@ namespace OpenSim.Framework.Console
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
int bw = System.Console.BufferWidth;
|
int bufferWidth = System.Console.BufferWidth;
|
||||||
|
|
||||||
// On Mono 2.4.2.3 (and possibly above), the buffer value is sometimes erroneously zero (Mantis 4657)
|
// On Mono 2.4.2.3 (and possibly above), the buffer value is sometimes erroneously zero (Mantis 4657)
|
||||||
if (bw > 0 && left >= bw)
|
if (bufferWidth > 0 && left >= bufferWidth)
|
||||||
System.Console.CursorLeft = bw - 1;
|
System.Console.CursorLeft = bufferWidth - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (top < 0)
|
if (top < 0)
|
||||||
|
@ -124,11 +123,11 @@ namespace OpenSim.Framework.Console
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
int bh = System.Console.BufferHeight;
|
int bufferHeight = System.Console.BufferHeight;
|
||||||
|
|
||||||
// On Mono 2.4.2.3 (and possibly above), the buffer value is sometimes erroneously zero (Mantis 4657)
|
// On Mono 2.4.2.3 (and possibly above), the buffer value is sometimes erroneously zero (Mantis 4657)
|
||||||
if (bh > 0 && top >= bh)
|
if (bufferHeight > 0 && top >= bufferHeight)
|
||||||
top = bh - 1;
|
top = bufferHeight - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
System.Console.CursorTop = top;
|
System.Console.CursorTop = top;
|
||||||
|
@ -160,10 +159,10 @@ namespace OpenSim.Framework.Console
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
int bh = System.Console.BufferHeight;
|
int bufferHeight = System.Console.BufferHeight;
|
||||||
// On Mono 2.4.2.3 (and possibly above), the buffer value is sometimes erroneously zero (Mantis 4657)
|
// On Mono 2.4.2.3 (and possibly above), the buffer value is sometimes erroneously zero (Mantis 4657)
|
||||||
if (bh > 0 && top >= bh)
|
if (bufferHeight > 0 && top >= bufferHeight)
|
||||||
System.Console.CursorTop = bh - 1;
|
System.Console.CursorTop = bufferHeight - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (left < 0)
|
if (left < 0)
|
||||||
|
@ -172,11 +171,11 @@ namespace OpenSim.Framework.Console
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
int bw = System.Console.BufferWidth;
|
int bufferWidth = System.Console.BufferWidth;
|
||||||
|
|
||||||
// On Mono 2.4.2.3 (and possibly above), the buffer value is sometimes erroneously zero (Mantis 4657)
|
// On Mono 2.4.2.3 (and possibly above), the buffer value is sometimes erroneously zero (Mantis 4657)
|
||||||
if (bw > 0 && left >= bw)
|
if (bufferWidth > 0 && left >= bufferWidth)
|
||||||
left = bw - 1;
|
left = bufferWidth - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
System.Console.CursorLeft = left;
|
System.Console.CursorLeft = left;
|
||||||
|
@ -186,31 +185,30 @@ namespace OpenSim.Framework.Console
|
||||||
|
|
||||||
private void Show()
|
private void Show()
|
||||||
{
|
{
|
||||||
lock (cmdline)
|
lock (m_commandLine)
|
||||||
{
|
{
|
||||||
if (y == -1 || System.Console.BufferWidth == 0)
|
if (m_cursorYPosition == -1 || System.Console.BufferWidth == 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
int xc = prompt.Length + cp;
|
int xc = prompt.Length + m_cursorXPosition;
|
||||||
int new_x = xc % System.Console.BufferWidth;
|
int new_x = xc % System.Console.BufferWidth;
|
||||||
int new_y = y + xc / System.Console.BufferWidth;
|
int new_y = m_cursorYPosition + xc / System.Console.BufferWidth;
|
||||||
int end_y = y + (cmdline.Length + prompt.Length) / System.Console.BufferWidth;
|
int end_y = m_cursorYPosition + (m_commandLine.Length + prompt.Length) / System.Console.BufferWidth;
|
||||||
if (end_y / System.Console.BufferWidth >= h)
|
|
||||||
h++;
|
|
||||||
if (end_y >= System.Console.BufferHeight) // wrap
|
if (end_y >= System.Console.BufferHeight) // wrap
|
||||||
{
|
{
|
||||||
y--;
|
m_cursorYPosition--;
|
||||||
new_y--;
|
new_y--;
|
||||||
SetCursorLeft(0);
|
SetCursorLeft(0);
|
||||||
SetCursorTop(System.Console.BufferHeight - 1);
|
SetCursorTop(System.Console.BufferHeight - 1);
|
||||||
System.Console.WriteLine(" ");
|
System.Console.WriteLine(" ");
|
||||||
}
|
}
|
||||||
|
|
||||||
y = SetCursorTop(y);
|
m_cursorYPosition = SetCursorTop(m_cursorYPosition);
|
||||||
SetCursorLeft(0);
|
SetCursorLeft(0);
|
||||||
|
|
||||||
if (echo)
|
if (m_echo)
|
||||||
System.Console.Write("{0}{1}", prompt, cmdline);
|
System.Console.Write("{0}{1}", prompt, m_commandLine);
|
||||||
else
|
else
|
||||||
System.Console.Write("{0}", prompt);
|
System.Console.Write("{0}", prompt);
|
||||||
|
|
||||||
|
@ -221,20 +219,20 @@ namespace OpenSim.Framework.Console
|
||||||
|
|
||||||
public override void LockOutput()
|
public override void LockOutput()
|
||||||
{
|
{
|
||||||
Monitor.Enter(cmdline);
|
Monitor.Enter(m_commandLine);
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (y != -1)
|
if (m_cursorYPosition != -1)
|
||||||
{
|
{
|
||||||
y = SetCursorTop(y);
|
m_cursorYPosition = SetCursorTop(m_cursorYPosition);
|
||||||
System.Console.CursorLeft = 0;
|
System.Console.CursorLeft = 0;
|
||||||
|
|
||||||
int count = cmdline.Length + prompt.Length;
|
int count = m_commandLine.Length + prompt.Length;
|
||||||
|
|
||||||
while (count-- > 0)
|
while (count-- > 0)
|
||||||
System.Console.Write(" ");
|
System.Console.Write(" ");
|
||||||
|
|
||||||
y = SetCursorTop(y);
|
m_cursorYPosition = SetCursorTop(m_cursorYPosition);
|
||||||
SetCursorLeft(0);
|
SetCursorLeft(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -245,12 +243,12 @@ namespace OpenSim.Framework.Console
|
||||||
|
|
||||||
public override void UnlockOutput()
|
public override void UnlockOutput()
|
||||||
{
|
{
|
||||||
if (y != -1)
|
if (m_cursorYPosition != -1)
|
||||||
{
|
{
|
||||||
y = System.Console.CursorTop;
|
m_cursorYPosition = System.Console.CursorTop;
|
||||||
Show();
|
Show();
|
||||||
}
|
}
|
||||||
Monitor.Exit(cmdline);
|
Monitor.Exit(m_commandLine);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void WriteColorText(ConsoleColor color, string sender)
|
private void WriteColorText(ConsoleColor color, string sender)
|
||||||
|
@ -317,29 +315,29 @@ namespace OpenSim.Framework.Console
|
||||||
|
|
||||||
public override void Output(string text, string level)
|
public override void Output(string text, string level)
|
||||||
{
|
{
|
||||||
lock (cmdline)
|
lock (m_commandLine)
|
||||||
{
|
{
|
||||||
if (y == -1)
|
if (m_cursorYPosition == -1)
|
||||||
{
|
{
|
||||||
WriteLocalText(text, level);
|
WriteLocalText(text, level);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
y = SetCursorTop(y);
|
m_cursorYPosition = SetCursorTop(m_cursorYPosition);
|
||||||
SetCursorLeft(0);
|
SetCursorLeft(0);
|
||||||
|
|
||||||
int count = cmdline.Length + prompt.Length;
|
int count = m_commandLine.Length + prompt.Length;
|
||||||
|
|
||||||
while (count-- > 0)
|
while (count-- > 0)
|
||||||
System.Console.Write(" ");
|
System.Console.Write(" ");
|
||||||
|
|
||||||
y = SetCursorTop(y);
|
m_cursorYPosition = SetCursorTop(m_cursorYPosition);
|
||||||
SetCursorLeft(0);
|
SetCursorLeft(0);
|
||||||
|
|
||||||
WriteLocalText(text, level);
|
WriteLocalText(text, level);
|
||||||
|
|
||||||
y = System.Console.CursorTop;
|
m_cursorYPosition = System.Console.CursorTop;
|
||||||
|
|
||||||
Show();
|
Show();
|
||||||
}
|
}
|
||||||
|
@ -347,9 +345,9 @@ namespace OpenSim.Framework.Console
|
||||||
|
|
||||||
private bool ContextHelp()
|
private bool ContextHelp()
|
||||||
{
|
{
|
||||||
string[] words = Parser.Parse(cmdline.ToString());
|
string[] words = Parser.Parse(m_commandLine.ToString());
|
||||||
|
|
||||||
bool trailingSpace = cmdline.ToString().EndsWith(" ");
|
bool trailingSpace = m_commandLine.ToString().EndsWith(" ");
|
||||||
|
|
||||||
// Allow ? through while typing a URI
|
// Allow ? through while typing a URI
|
||||||
//
|
//
|
||||||
|
@ -368,19 +366,18 @@ namespace OpenSim.Framework.Console
|
||||||
|
|
||||||
public override string ReadLine(string p, bool isCommand, bool e)
|
public override string ReadLine(string p, bool isCommand, bool e)
|
||||||
{
|
{
|
||||||
h = 1;
|
m_cursorXPosition = 0;
|
||||||
cp = 0;
|
|
||||||
prompt = p;
|
prompt = p;
|
||||||
echo = e;
|
m_echo = e;
|
||||||
int historyLine = history.Count;
|
int historyLine = m_history.Count;
|
||||||
|
|
||||||
SetCursorLeft(0); // Needed for mono
|
SetCursorLeft(0); // Needed for mono
|
||||||
System.Console.Write(" "); // Needed for mono
|
System.Console.Write(" "); // Needed for mono
|
||||||
|
|
||||||
lock (cmdline)
|
lock (m_commandLine)
|
||||||
{
|
{
|
||||||
y = System.Console.CursorTop;
|
m_cursorYPosition = System.Console.CursorTop;
|
||||||
cmdline.Remove(0, cmdline.Length);
|
m_commandLine.Remove(0, m_commandLine.Length);
|
||||||
}
|
}
|
||||||
|
|
||||||
while (true)
|
while (true)
|
||||||
|
@ -388,95 +385,95 @@ namespace OpenSim.Framework.Console
|
||||||
Show();
|
Show();
|
||||||
|
|
||||||
ConsoleKeyInfo key = System.Console.ReadKey(true);
|
ConsoleKeyInfo key = System.Console.ReadKey(true);
|
||||||
char c = key.KeyChar;
|
char enteredChar = key.KeyChar;
|
||||||
|
|
||||||
if (!Char.IsControl(c))
|
if (!Char.IsControl(enteredChar))
|
||||||
{
|
{
|
||||||
if (cp >= 318)
|
if (m_cursorXPosition >= 318)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (c == '?' && isCommand)
|
if (enteredChar == '?' && isCommand)
|
||||||
{
|
{
|
||||||
if (ContextHelp())
|
if (ContextHelp())
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
cmdline.Insert(cp, c);
|
m_commandLine.Insert(m_cursorXPosition, enteredChar);
|
||||||
cp++;
|
m_cursorXPosition++;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
switch (key.Key)
|
switch (key.Key)
|
||||||
{
|
{
|
||||||
case ConsoleKey.Backspace:
|
case ConsoleKey.Backspace:
|
||||||
if (cp == 0)
|
if (m_cursorXPosition == 0)
|
||||||
break;
|
break;
|
||||||
cmdline.Remove(cp-1, 1);
|
m_commandLine.Remove(m_cursorXPosition-1, 1);
|
||||||
cp--;
|
m_cursorXPosition--;
|
||||||
|
|
||||||
SetCursorLeft(0);
|
SetCursorLeft(0);
|
||||||
y = SetCursorTop(y);
|
m_cursorYPosition = SetCursorTop(m_cursorYPosition);
|
||||||
|
|
||||||
if (echo)
|
if (m_echo)
|
||||||
System.Console.Write("{0}{1} ", prompt, cmdline);
|
System.Console.Write("{0}{1} ", prompt, m_commandLine);
|
||||||
else
|
else
|
||||||
System.Console.Write("{0}", prompt);
|
System.Console.Write("{0}", prompt);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case ConsoleKey.End:
|
case ConsoleKey.End:
|
||||||
cp = cmdline.Length;
|
m_cursorXPosition = m_commandLine.Length;
|
||||||
break;
|
break;
|
||||||
case ConsoleKey.Home:
|
case ConsoleKey.Home:
|
||||||
cp = 0;
|
m_cursorXPosition = 0;
|
||||||
break;
|
break;
|
||||||
case ConsoleKey.UpArrow:
|
case ConsoleKey.UpArrow:
|
||||||
if (historyLine < 1)
|
if (historyLine < 1)
|
||||||
break;
|
break;
|
||||||
historyLine--;
|
historyLine--;
|
||||||
LockOutput();
|
LockOutput();
|
||||||
cmdline.Remove(0, cmdline.Length);
|
m_commandLine.Remove(0, m_commandLine.Length);
|
||||||
cmdline.Append(history[historyLine]);
|
m_commandLine.Append(m_history[historyLine]);
|
||||||
cp = cmdline.Length;
|
m_cursorXPosition = m_commandLine.Length;
|
||||||
UnlockOutput();
|
UnlockOutput();
|
||||||
break;
|
break;
|
||||||
case ConsoleKey.DownArrow:
|
case ConsoleKey.DownArrow:
|
||||||
if (historyLine >= history.Count)
|
if (historyLine >= m_history.Count)
|
||||||
break;
|
break;
|
||||||
historyLine++;
|
historyLine++;
|
||||||
LockOutput();
|
LockOutput();
|
||||||
if (historyLine == history.Count)
|
if (historyLine == m_history.Count)
|
||||||
{
|
{
|
||||||
cmdline.Remove(0, cmdline.Length);
|
m_commandLine.Remove(0, m_commandLine.Length);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
cmdline.Remove(0, cmdline.Length);
|
m_commandLine.Remove(0, m_commandLine.Length);
|
||||||
cmdline.Append(history[historyLine]);
|
m_commandLine.Append(m_history[historyLine]);
|
||||||
}
|
}
|
||||||
cp = cmdline.Length;
|
m_cursorXPosition = m_commandLine.Length;
|
||||||
UnlockOutput();
|
UnlockOutput();
|
||||||
break;
|
break;
|
||||||
case ConsoleKey.LeftArrow:
|
case ConsoleKey.LeftArrow:
|
||||||
if (cp > 0)
|
if (m_cursorXPosition > 0)
|
||||||
cp--;
|
m_cursorXPosition--;
|
||||||
break;
|
break;
|
||||||
case ConsoleKey.RightArrow:
|
case ConsoleKey.RightArrow:
|
||||||
if (cp < cmdline.Length)
|
if (m_cursorXPosition < m_commandLine.Length)
|
||||||
cp++;
|
m_cursorXPosition++;
|
||||||
break;
|
break;
|
||||||
case ConsoleKey.Enter:
|
case ConsoleKey.Enter:
|
||||||
SetCursorLeft(0);
|
SetCursorLeft(0);
|
||||||
y = SetCursorTop(y);
|
m_cursorYPosition = SetCursorTop(m_cursorYPosition);
|
||||||
|
|
||||||
System.Console.WriteLine();
|
System.Console.WriteLine();
|
||||||
//Show();
|
//Show();
|
||||||
|
|
||||||
lock (cmdline)
|
lock (m_commandLine)
|
||||||
{
|
{
|
||||||
y = -1;
|
m_cursorYPosition = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
string commandLine = cmdline.ToString();
|
string commandLine = m_commandLine.ToString();
|
||||||
|
|
||||||
if (isCommand)
|
if (isCommand)
|
||||||
{
|
{
|
||||||
|
@ -484,12 +481,12 @@ namespace OpenSim.Framework.Console
|
||||||
|
|
||||||
if (cmd.Length != 0)
|
if (cmd.Length != 0)
|
||||||
{
|
{
|
||||||
int i;
|
int index;
|
||||||
|
|
||||||
for (i=0 ; i < cmd.Length ; i++)
|
for (index=0 ; index < cmd.Length ; index++)
|
||||||
{
|
{
|
||||||
if (cmd[i].Contains(" "))
|
if (cmd[index].Contains(" "))
|
||||||
cmd[i] = "\"" + cmd[i] + "\"";
|
cmd[index] = "\"" + cmd[index] + "\"";
|
||||||
}
|
}
|
||||||
AddToHistory(String.Join(" ", cmd));
|
AddToHistory(String.Join(" ", cmd));
|
||||||
return String.Empty;
|
return String.Empty;
|
||||||
|
@ -497,7 +494,7 @@ namespace OpenSim.Framework.Console
|
||||||
}
|
}
|
||||||
|
|
||||||
// If we're not echoing to screen (e.g. a password) then we probably don't want it in history
|
// If we're not echoing to screen (e.g. a password) then we probably don't want it in history
|
||||||
if (echo && commandLine != "")
|
if (m_echo && commandLine != "")
|
||||||
AddToHistory(commandLine);
|
AddToHistory(commandLine);
|
||||||
|
|
||||||
return commandLine;
|
return commandLine;
|
||||||
|
|
Loading…
Reference in New Issue