aboutsummaryrefslogtreecommitdiff
path: root/ShiftOS.Engine/Terminal/TerminalCommand.cs
diff options
context:
space:
mode:
authorAlex-TIMEHACK <[email protected]>2017-11-18 16:29:54 +0000
committerAlex-TIMEHACK <[email protected]>2017-11-18 16:29:54 +0000
commit4037be53b29a122732cfc10693e9c0027f606bb0 (patch)
tree8533ea9ee0ac8f5f7f696b85cb039f783657ada0 /ShiftOS.Engine/Terminal/TerminalCommand.cs
parent65b7ac2b8cbc4478f6d31a21f106048aeb075078 (diff)
parent97722fbe9d474adffbba0b92e9727c48a8205234 (diff)
downloadshiftos-rewind-4037be53b29a122732cfc10693e9c0027f606bb0.tar.gz
shiftos-rewind-4037be53b29a122732cfc10693e9c0027f606bb0.tar.bz2
shiftos-rewind-4037be53b29a122732cfc10693e9c0027f606bb0.zip
Updated my fork!
Conflicts: ShiftOS.Engine/ShiftOS.Engine.csproj ShiftOS.Engine/Terminal/Commands/Hello.cs ShiftOS.Engine/Terminal/TerminalBackend.cs ShiftOS.Engine/Terminal/TerminalCommand.cs ShiftOS.Main/ShiftOS.Main.csproj ShiftOS.Main/ShiftOS/Apps/Terminal.cs ShiftOS.Main/ShiftOS/Desktop.cs
Diffstat (limited to 'ShiftOS.Engine/Terminal/TerminalCommand.cs')
-rw-r--r--ShiftOS.Engine/Terminal/TerminalCommand.cs182
1 files changed, 182 insertions, 0 deletions
diff --git a/ShiftOS.Engine/Terminal/TerminalCommand.cs b/ShiftOS.Engine/Terminal/TerminalCommand.cs
new file mode 100644
index 0000000..110d1d2
--- /dev/null
+++ b/ShiftOS.Engine/Terminal/TerminalCommand.cs
@@ -0,0 +1,182 @@
+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;
+
+ }
+
+ }
+
+} \ No newline at end of file