mirror of
https://github.com/ShiftOS-Rewind/ShiftOS.git
synced 2025-01-22 11:21:45 -05:00
Merge remote-tracking branch 'refs/remotes/ShiftOS-Rewind/master'
This commit is contained in:
commit
b4a8a646b1
12 changed files with 270 additions and 119 deletions
Binary file not shown.
|
@ -69,9 +69,6 @@
|
||||||
<Compile Include="ShiftFS\ShiftFile.cs" />
|
<Compile Include="ShiftFS\ShiftFile.cs" />
|
||||||
<Compile Include="ShiftFS\ShiftFS.cs" />
|
<Compile Include="ShiftFS\ShiftFS.cs" />
|
||||||
<Compile Include="ShiftFS\IShiftNode.cs" />
|
<Compile Include="ShiftFS\IShiftNode.cs" />
|
||||||
<Compile Include="Terminal\Commands\Hello.cs" />
|
|
||||||
<Compile Include="Terminal\TerminalBackend.cs" />
|
|
||||||
<Compile Include="Terminal\TerminalCommand.cs" />
|
|
||||||
<Compile Include="Misc\Tools.cs" />
|
<Compile Include="Misc\Tools.cs" />
|
||||||
<Compile Include="WindowManager\InfoboxTemplate.cs">
|
<Compile Include="WindowManager\InfoboxTemplate.cs">
|
||||||
<SubType>UserControl</SubType>
|
<SubType>UserControl</SubType>
|
||||||
|
|
|
@ -1,9 +0,0 @@
|
||||||
namespace ShiftOS.Engine.Terminal.Commands
|
|
||||||
{
|
|
||||||
public class Hello : TerminalCommand
|
|
||||||
{
|
|
||||||
public override string GetName() => "Hello";
|
|
||||||
|
|
||||||
public override string Run(params string[] parameters) => "Oh, HELLO, " + string.Join(" ", parameters);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,47 +0,0 @@
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Reflection;
|
|
||||||
|
|
||||||
namespace ShiftOS.Engine.Terminal
|
|
||||||
{
|
|
||||||
public static class TerminalBackend
|
|
||||||
{
|
|
||||||
// The line below gets all the terminal commands in... well... the entire ShiftOS.Engine
|
|
||||||
static readonly IEnumerable<TerminalCommand> Instances = from t in Assembly.GetExecutingAssembly().GetTypes()
|
|
||||||
where t.IsSubclassOf(typeof(TerminalCommand)) &&
|
|
||||||
t.GetConstructor(Type.EmptyTypes) != null
|
|
||||||
select (TerminalCommand) Activator.CreateInstance(t);
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Runs a terminal command.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="command"></param>
|
|
||||||
/// <returns>Returns all the output from that command.</returns>
|
|
||||||
public static string RunCommand(string command)
|
|
||||||
{
|
|
||||||
string name;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
name = command.Split(' ')[0];
|
|
||||||
}
|
|
||||||
catch
|
|
||||||
{
|
|
||||||
name = command;
|
|
||||||
}
|
|
||||||
|
|
||||||
var theParams = new string[command.Split(' ').Length - 1];
|
|
||||||
Array.Copy(command.Split(' '), 1, theParams, 0, command.Split(' ').Length - 1);
|
|
||||||
|
|
||||||
foreach (var instance in Instances)
|
|
||||||
{
|
|
||||||
if (instance.GetName() == name)
|
|
||||||
{
|
|
||||||
return instance.Run(theParams);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return "The command cannot be found.";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,9 +0,0 @@
|
||||||
namespace ShiftOS.Engine.Terminal
|
|
||||||
{
|
|
||||||
public abstract class TerminalCommand
|
|
||||||
{
|
|
||||||
public abstract string GetName();
|
|
||||||
|
|
||||||
public abstract string Run(params string[] parameters);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -99,6 +99,9 @@
|
||||||
<Compile Include="ShiftOS\Desktop.Designer.cs">
|
<Compile Include="ShiftOS\Desktop.Designer.cs">
|
||||||
<DependentUpon>Desktop.cs</DependentUpon>
|
<DependentUpon>Desktop.cs</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
|
<Compile Include="Terminal\Commands\Hello.cs" />
|
||||||
|
<Compile Include="Terminal\TerminalBackend.cs" />
|
||||||
|
<Compile Include="Terminal\TerminalCommand.cs" />
|
||||||
<EmbeddedResource Include="Properties\Resources.resx">
|
<EmbeddedResource Include="Properties\Resources.resx">
|
||||||
<Generator>ResXFileCodeGenerator</Generator>
|
<Generator>ResXFileCodeGenerator</Generator>
|
||||||
<LastGenOutput>Resources.Designer.cs</LastGenOutput>
|
<LastGenOutput>Resources.Designer.cs</LastGenOutput>
|
||||||
|
|
2
ShiftOS.Main/ShiftOS/Apps/Terminal.Designer.cs
generated
2
ShiftOS.Main/ShiftOS/Apps/Terminal.Designer.cs
generated
|
@ -60,6 +60,6 @@
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
private System.Windows.Forms.RichTextBox termmain;
|
public System.Windows.Forms.RichTextBox termmain;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,14 +1,19 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Windows.Forms;
|
using System.Windows.Forms;
|
||||||
using ShiftOS.Engine.Terminal;
|
using ShiftOS.Engine;
|
||||||
|
using ShiftOS.Main.Terminal;
|
||||||
|
|
||||||
namespace ShiftOS.Main.ShiftOS.Apps
|
namespace ShiftOS.Main.ShiftOS.Apps
|
||||||
{
|
{
|
||||||
public partial class Terminal : UserControl
|
public partial class Terminal : UserControl
|
||||||
{
|
{
|
||||||
public string DefaulttextBefore = "user> ";
|
public int TerminalID = TerminalBackend.trmTopID++; // Used so that we can have multiple instances of the terminal whilst the command begin run knowing what terminal to send the text to - very complicated ;)
|
||||||
string DefaulttextResult = "user@shiftos> "; // NOT YET IMPLEMENTED!!!
|
public string defaulttextBefore = "user> ";
|
||||||
bool DoClear = false;
|
public string defaulttextResult = "user@shiftos> "; // NOT YET IMPLEMENTED!!!
|
||||||
|
public bool DoClear = false;
|
||||||
|
public bool RunningCommand = false;
|
||||||
|
public bool WaitingResponse = false;
|
||||||
|
public string InputReturnText = "";
|
||||||
|
|
||||||
// The below variables makes the terminal... a terminal!
|
// The below variables makes the terminal... a terminal!
|
||||||
string OldText = "";
|
string OldText = "";
|
||||||
|
@ -20,14 +25,92 @@ namespace ShiftOS.Main.ShiftOS.Apps
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
|
|
||||||
termmain.ContextMenuStrip = new ContextMenuStrip(); // Disables the right click of a richtextbox!
|
termmain.ContextMenuStrip = new ContextMenuStrip(); // Disables the right click of a richtextbox!
|
||||||
|
|
||||||
|
TerminalBackend.trm.Add(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Print()
|
||||||
|
{
|
||||||
|
termmain.AppendText($"\n {defaulttextResult}");
|
||||||
|
TrackingPosition = termmain.Text.Length;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Print(string text)
|
void Print(string text)
|
||||||
{
|
{
|
||||||
termmain.AppendText($"\n {text} \n {DefaulttextResult}");
|
termmain.AppendText($"\n {text} \n {defaulttextResult}");
|
||||||
TrackingPosition = termmain.Text.Length;
|
TrackingPosition = termmain.Text.Length;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//if (e.Control && e.KeyCode == Keys.V)
|
||||||
|
// {
|
||||||
|
// //if (Clipboard.ContainsText())
|
||||||
|
// // termmain.Paste(DataFormats.GetFormat(DataFormats.Text));
|
||||||
|
// e.Handled = true;
|
||||||
|
// } else if (e.KeyCode == Keys.Enter) {
|
||||||
|
// RunningCommand = true;
|
||||||
|
// TerminalBackend.RunCommand(termmain.Text.Substring(TrackingPosition, termmain.Text.Length - TrackingPosition), TerminalID); // The most horrific line in the entire application!
|
||||||
|
// RunningCommand = false;
|
||||||
|
// termmain.AppendText($"\n {defaulttextResult}");
|
||||||
|
// TrackingPosition = termmain.Text.Length;
|
||||||
|
// e.Handled = true;
|
||||||
|
// }
|
||||||
|
//}
|
||||||
|
|
||||||
|
private void termmain_TextChanged(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
if (!RunningCommand)
|
||||||
|
{
|
||||||
|
if (termmain.SelectionStart < TrackingPosition)
|
||||||
|
{
|
||||||
|
if (!DoClear) // If it's not clearing the terminal
|
||||||
|
{
|
||||||
|
termmain.Text = OldText;
|
||||||
|
termmain.Select(termmain.Text.Length, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
OldText = termmain.Text;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void termmain_SelectionChanged(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
if (!RunningCommand)
|
||||||
|
{
|
||||||
|
if (termmain.SelectionStart < TrackingPosition)
|
||||||
|
{
|
||||||
|
termmain.Text = OldText;
|
||||||
|
termmain.Select(termmain.Text.Length, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void Terminal_Load(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
termmain.Text = $"\n {defaulttextResult}";
|
||||||
|
TrackingPosition = termmain.Text.Length;
|
||||||
|
termmain.Select(termmain.TextLength, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Input(string request)
|
||||||
|
{
|
||||||
|
InputReturnText = "";
|
||||||
|
RunningCommand = false;
|
||||||
|
|
||||||
|
termmain.AppendText($"\n {request} ");
|
||||||
|
TrackingPosition = termmain.Text.Length;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Clear()
|
||||||
|
{
|
||||||
|
DoClear = true;
|
||||||
|
termmain.Text = $"\n {defaulttextResult}";
|
||||||
|
TrackingPosition = termmain.Text.Length;
|
||||||
|
DoClear = false;
|
||||||
|
}
|
||||||
|
|
||||||
void termmain_KeyDown(object sender, KeyEventArgs e)
|
void termmain_KeyDown(object sender, KeyEventArgs e)
|
||||||
{
|
{
|
||||||
// The below code disables the ability to paste anything other then text...
|
// The below code disables the ability to paste anything other then text...
|
||||||
|
@ -40,41 +123,10 @@ namespace ShiftOS.Main.ShiftOS.Apps
|
||||||
}
|
}
|
||||||
else if (e.KeyCode == Keys.Enter)
|
else if (e.KeyCode == Keys.Enter)
|
||||||
{
|
{
|
||||||
Print(
|
TerminalBackend.RunCommand(termmain.Text.Substring(TrackingPosition, termmain.Text.Length - TrackingPosition), TerminalID); // The most horrific line in the entire application!
|
||||||
TerminalBackend.RunCommand(
|
Print();
|
||||||
termmain.Text.Substring(
|
|
||||||
TrackingPosition,
|
|
||||||
termmain.Text.Length - TrackingPosition))); // The most horrific line in the entire application!
|
|
||||||
e.Handled = true;
|
e.Handled = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void termmain_TextChanged(object sender, EventArgs e)
|
|
||||||
{
|
|
||||||
if (termmain.SelectionStart < TrackingPosition)
|
|
||||||
{
|
|
||||||
if (DoClear) return;
|
|
||||||
|
|
||||||
termmain.Text = OldText;
|
|
||||||
termmain.Select(termmain.Text.Length, 0);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
OldText = termmain.Text;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void termmain_SelectionChanged(object sender, EventArgs e)
|
|
||||||
{
|
|
||||||
if (termmain.SelectionStart >= TrackingPosition) return;
|
|
||||||
|
|
||||||
termmain.Text = OldText;
|
|
||||||
termmain.Select(termmain.Text.Length, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
void Terminal_Load(object sender, EventArgs e)
|
|
||||||
{
|
|
||||||
Print("\n");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -54,10 +54,11 @@ namespace ShiftOS.Main.ShiftOS
|
||||||
void timer1_Tick(object sender, EventArgs e) =>
|
void timer1_Tick(object sender, EventArgs e) =>
|
||||||
taskbarClock.Text = $"{DateTime.Now:t}";
|
taskbarClock.Text = $"{DateTime.Now:t}";
|
||||||
|
|
||||||
void terminalToolStripMenuItem_Click(object sender, EventArgs e)
|
private void terminalToolStripMenuItem_Click(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
var trm = new Terminal();
|
Apps.Terminal trm = new Apps.Terminal();
|
||||||
ShiftWM.Init(trm, "Terminal", null);
|
|
||||||
|
ShiftWM.Init(trm, "Terminal", null, false, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void textPadToolStripMenuItem_Click(object sender, EventArgs e)
|
void textPadToolStripMenuItem_Click(object sender, EventArgs e)
|
||||||
|
|
23
ShiftOS.Main/Terminal/Commands/Hello.cs
Normal file
23
ShiftOS.Main/Terminal/Commands/Hello.cs
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Drawing;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace ShiftOS.Main.Terminal.Commands
|
||||||
|
{
|
||||||
|
public class Hello : TerminalCommand
|
||||||
|
{
|
||||||
|
public override string Name { get; } = "Hello";
|
||||||
|
public override string Summary { get; } = "Just an example command.";
|
||||||
|
public override string Usage { get; } = "Hello <NAME>.";
|
||||||
|
public override bool Unlocked { get; set; } = false;
|
||||||
|
|
||||||
|
public override void Run(params string[] parameters)
|
||||||
|
{
|
||||||
|
string name = string.Join(" ", parameters);
|
||||||
|
WriteLine($"Oh, hello, {name}.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
48
ShiftOS.Main/Terminal/TerminalBackend.cs
Normal file
48
ShiftOS.Main/Terminal/TerminalBackend.cs
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Reflection;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Windows.Forms;
|
||||||
|
|
||||||
|
namespace ShiftOS.Main.Terminal
|
||||||
|
{
|
||||||
|
public static class TerminalBackend
|
||||||
|
{
|
||||||
|
// The line below gets all the terminal commands in... well... the entire ShiftOS.Engine
|
||||||
|
public static IEnumerable<TerminalCommand> instances = Assembly.GetExecutingAssembly().GetTypes()
|
||||||
|
.Where(t => t.IsSubclassOf(typeof(TerminalCommand)) && t.GetConstructor(Type.EmptyTypes) != null)
|
||||||
|
.Select(t => Activator.CreateInstance(t) as TerminalCommand);
|
||||||
|
|
||||||
|
public static List<ShiftOS.Apps.Terminal> trm = new List<ShiftOS.Apps.Terminal>();
|
||||||
|
public static int trmTopID = 0;
|
||||||
|
/// <summary>
|
||||||
|
/// Runs a terminal command.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="command"></param>
|
||||||
|
/// <param name="rtb"><summary>The rich text box that the text will be written to.</summary></param>
|
||||||
|
public static void RunCommand(string command, int TermID)
|
||||||
|
{
|
||||||
|
string name;
|
||||||
|
try { name = command.Split(' ')[0]; } catch { name = command; }
|
||||||
|
|
||||||
|
var theParams = new string[command.Split(' ').Length - 1];
|
||||||
|
Array.Copy(command.Split(' '), 1, theParams, 0, command.Split(' ').Length - 1);
|
||||||
|
|
||||||
|
foreach (TerminalCommand instance in instances)
|
||||||
|
{
|
||||||
|
if (instance.Name.ToLower() == name.ToLower())
|
||||||
|
{
|
||||||
|
instance.TermID = TermID;
|
||||||
|
// Add a new line!
|
||||||
|
Array.Find(trm.ToArray(), w => w.TerminalID == TermID).termmain.AppendText("\n");
|
||||||
|
instance.Run(theParams);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Array.Find(trm.ToArray(), w => w.TerminalID == TermID).termmain.Text += " \n The command cannot be found. \n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
92
ShiftOS.Main/Terminal/TerminalCommand.cs
Normal file
92
ShiftOS.Main/Terminal/TerminalCommand.cs
Normal file
|
@ -0,0 +1,92 @@
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Drawing;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Windows.Forms;
|
||||||
|
|
||||||
|
namespace ShiftOS.Main.Terminal
|
||||||
|
{
|
||||||
|
public class TerminalCommand
|
||||||
|
{
|
||||||
|
public int TermID { get; set; }
|
||||||
|
|
||||||
|
public virtual string Name { get; }
|
||||||
|
public virtual string Summary { get; }
|
||||||
|
public virtual string Usage { get; }
|
||||||
|
public virtual bool Unlocked { get; set; }
|
||||||
|
|
||||||
|
public virtual void Run(params string[] parameters) { }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Writes a blank line in the terminal.
|
||||||
|
/// </summary>
|
||||||
|
public virtual void WriteLine()
|
||||||
|
{
|
||||||
|
WriteLine("");
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Writes specified text in the terminal and starts a new line.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="value"><summary>The text to write before the new line is made.</summary></param>
|
||||||
|
public virtual void WriteLine(string value)
|
||||||
|
{
|
||||||
|
Array.Find(TerminalBackend.trm.ToArray(), w => w.TerminalID == TermID).termmain.AppendText($"{value} \n");
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Writes specified text in the terminal in the specified color and starts a new line.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="value"><summary>The text to write before the new line is made.</summary></param>
|
||||||
|
/// <param name="textClr"><summary>The color the text is written in.</summary></param>
|
||||||
|
public virtual void WriteLine(string value, Color textClr)
|
||||||
|
{
|
||||||
|
ShiftOS.Apps.Terminal trm = Array.Find(TerminalBackend.trm.ToArray(), w => w.TerminalID == TermID);
|
||||||
|
|
||||||
|
int startPoint = trm.termmain.Text.Length;
|
||||||
|
trm.termmain.AppendText($"{value} \n");
|
||||||
|
trm.termmain.Select(startPoint, $"{value} \n".Length);
|
||||||
|
trm.termmain.SelectionColor = textClr;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Writes specified text in the terminal.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="value"><summary>The text to write.</summary></param>
|
||||||
|
/// <param name="textClr"><summary>The color the text is written in.</summary></param>
|
||||||
|
public virtual void Write(string value, Color textClr)
|
||||||
|
{
|
||||||
|
|
||||||
|
ShiftOS.Apps.Terminal trm = Array.Find(TerminalBackend.trm.ToArray(), w => w.TerminalID == TermID);
|
||||||
|
|
||||||
|
int startPoint = trm.termmain.Text.Length;
|
||||||
|
trm.termmain.AppendText($"{value}");
|
||||||
|
trm.termmain.Select(startPoint, $"{value}".Length);
|
||||||
|
trm.termmain.SelectionColor = textClr;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Writes specified text in the terminal.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="value"><summary>The text to say before requesting text. </summary></param>
|
||||||
|
//public virtual Task<string> Input(string value = "")
|
||||||
|
//{
|
||||||
|
// ShiftOS.Apps.Terminal trm = Array.Find(TerminalBackend.trm.ToArray(), w => w.TerminalID == TermID);
|
||||||
|
// trm.Input(value);
|
||||||
|
|
||||||
|
// Task<string> Input = new Task<string>(() =>
|
||||||
|
// {
|
||||||
|
// while (true)
|
||||||
|
// if (trm.InputReturnText != "") break;
|
||||||
|
|
||||||
|
// // The terminal has finally decided!
|
||||||
|
|
||||||
|
// return trm.InputReturnText;
|
||||||
|
// });
|
||||||
|
// Input.Start();
|
||||||
|
// return Input;
|
||||||
|
//}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue