ShiftOS-TheRevival-Old/ShiftOS-TheRevival/MainForms/Console.vb

339 lines
14 KiB
VB.net
Raw Normal View History

2022-11-02 21:28:19 +00:00
Imports System.IO
Public Class Console
2022-11-07 07:16:34 +00:00
Public TrackPos As Integer
2022-11-01 22:57:27 +00:00
Public DefaultPrompt As String
2022-11-02 04:17:14 +00:00
Public BadCommand As Boolean
2022-11-02 21:28:19 +00:00
Public DisplayStory As Integer
Public StoryToTell As String
2022-11-03 15:27:40 +00:00
Public ChangeInterpreter As Boolean = False
Public CurrentInterpreter As String = "terminal"
Public CurrentDirectory As String
2022-11-06 08:20:38 +00:00
Public Pseudodir As String
Public StayAtChapter As Boolean = False
2022-11-06 11:45:00 +00:00
Public ToolBarUse As Boolean = False
Public ReleaseCursor As Boolean = False
2022-11-08 03:22:01 +00:00
Public ShOSKey As String
2022-11-01 22:57:27 +00:00
Private Sub Console_Load(sender As Object, e As EventArgs) Handles MyBase.Load
Console_Full()
2022-11-04 23:27:35 +00:00
Cursor.Hide()
InitializeTerminal()
End Sub
Public Sub InitializeTerminal()
2022-11-06 09:22:35 +00:00
Strings.OnceInfo(1) = Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData) & "\ShiftOS\ShiftFS"
2022-11-06 08:20:38 +00:00
Strings.OnceInfo(4) = "!"
2022-11-08 06:02:02 +00:00
Strings.OnceInfo(7) = Width
Strings.OnceInfo(8) = Height
2022-11-01 22:57:27 +00:00
If Strings.IsFree = True Then
Strings.ComputerInfo(0) = "shiftos"
Strings.ComputerInfo(1) = "user"
CheckFeature()
Terminal_PrintPrompt()
Terminal_AssignPrompt()
2022-11-02 01:52:31 +00:00
Else
If StayAtChapter = True Then
2022-11-06 11:45:00 +00:00
LoadGame()
CheckFeature()
Terminal_PrintPrompt()
Terminal_AssignPrompt()
Else
If Strings.ComputerInfo(3) = "0" Then
TextBox1.ReadOnly = True
StayAtChapter = True
StoryOnlyTimer.Start()
Else
2022-11-06 11:45:00 +00:00
LoadGame()
CheckFeature()
Terminal_PrintPrompt()
Terminal_AssignPrompt()
End If
2022-11-02 21:28:19 +00:00
End If
2022-11-01 22:57:27 +00:00
End If
2022-11-06 08:20:38 +00:00
CurrentDirectory = Strings.OnceInfo(1)
Pseudodir = CurrentDirectory.Replace(Strings.OnceInfo(1), "!\")
TextRebind()
2022-11-01 22:57:27 +00:00
End Sub
Public Sub CheckFeature()
If Strings.AvailableFeature(4) = "1" Then
2022-11-06 11:45:00 +00:00
If ToolBarUse = True Then
If Strings.OnceInfo(2) = "True" Then
InfoBarTimer.Start()
TextBox1.Dock = DockStyle.None
ToolBar.Visible = True
ToolBar.SendToBack()
InfoBar.Visible = True
InfoBar.SendToBack()
TextBox1.Dock = DockStyle.Fill
Else
TextBox1.Dock = DockStyle.None
InfoBar.Visible = False
ToolBar.Visible = True
ToolBar.SendToBack()
TextBox1.Dock = DockStyle.Fill
End If
2022-11-06 07:24:53 +00:00
Else
2022-11-06 11:45:00 +00:00
If Strings.OnceInfo(2) = "True" Then
InfoBarTimer.Start()
TextBox1.Dock = DockStyle.None
InfoBar.Visible = True
InfoBar.SendToBack()
ToolBar.Visible = False
TextBox1.Dock = DockStyle.Fill
Else
TextBox1.Dock = DockStyle.None
InfoBar.Visible = False
ToolBar.Visible = False
TextBox1.Dock = DockStyle.Fill
End If
2022-11-06 07:24:53 +00:00
End If
Else
TextBox1.Dock = DockStyle.None
InfoBar.Visible = False
TextBox1.Dock = DockStyle.Fill
End If
End Sub
Public Sub DoCommand()
2022-11-02 01:52:31 +00:00
End Sub
2022-11-07 07:16:34 +00:00
Private Sub txtterm_KeyPress(ByVal sender As Object, ByVal e As System.Windows.Forms.KeyEventArgs) Handles TextBox1.KeyDown
KeyInput = e.KeyData
2022-11-06 08:20:38 +00:00
Select Case e.KeyData
Case (Keys.Control + Keys.Q)
If CurrentInterpreter = "terminal" Then
Else
TerminateApp(KeyInput)
2022-11-07 07:16:34 +00:00
TextRebind()
2022-11-06 08:20:38 +00:00
End If
2022-11-07 07:16:34 +00:00
Case Else
CaptureKeyBinding(KeyInput)
2022-11-06 08:20:38 +00:00
End Select
2022-11-06 11:45:00 +00:00
If ReleaseCursor = True Then
Else
2022-11-07 07:16:34 +00:00
Select Case e.KeyData
Case Keys.Enter
e.SuppressKeyPress = True
If TextBox1.ReadOnly = True Then
2022-11-06 11:45:00 +00:00
2022-11-07 07:16:34 +00:00
Else
Terminal_ReadCommand()
2022-11-08 03:22:01 +00:00
If Strings.AvailableFeature(18) = 1 Then
ShOSKey_InputCommand(command)
End If
2022-11-07 07:16:34 +00:00
If ChangeInterpreter = True Then
DoChildCommand()
Terminal_PrintPrompt()
2022-11-07 07:16:34 +00:00
TextRebind()
2022-11-06 11:45:00 +00:00
Else
2022-11-14 13:09:29 +00:00
Terminal_DoCommand()
Terminal_PrintPrompt()
2022-11-07 07:16:34 +00:00
TextRebind()
2022-11-06 11:45:00 +00:00
End If
2022-11-07 07:16:34 +00:00
End If
TrackPos = 0
Case Keys.ShiftKey, Keys.LShiftKey, Keys.RShiftKey, Keys.Alt, Keys.ControlKey, Keys.LWin, Keys.RWin
2022-11-07 07:16:34 +00:00
e.SuppressKeyPress = True
TrackPos = TrackPos
2022-11-07 07:16:34 +00:00
Case Keys.Back
If TrackPos <= 0 Then
2022-11-06 11:45:00 +00:00
e.SuppressKeyPress = True
Else
2022-11-07 07:16:34 +00:00
TrackPos = TrackPos - 1
'If TextBox1.SelectedText.Length < 1 Then
' TrackPos = TrackPos - 1
'Else
' e.SuppressKeyPress = True
'End If
2022-11-06 11:45:00 +00:00
End If
2022-11-07 07:16:34 +00:00
Case Keys.Right
If TextBox1.SelectionStart = TextBox1.TextLength Then
2022-11-06 11:45:00 +00:00
Else
TrackPos = TrackPos + 1
End If
2022-11-07 07:16:34 +00:00
'If TrackPos <= 0 Then
' Dim CommandChar As String
' CommandChar = TextBox1.Lines(TextBox1.Lines.Length - 1)
' CommandChar = CommandChar.Replace(DefaultPrompt, "")
' TrackPos = CommandChar.Length - 1
' TextBox1.Select(TextBox1.TextLength, 0)
' TextBox1.ScrollToCaret()
'End If
Case Keys.Left
If TextBox1.SelectionStart = 0 Then
2022-11-06 11:45:00 +00:00
e.SuppressKeyPress = True
Else
2022-11-07 07:16:34 +00:00
TrackPos = TrackPos - 1
2022-11-06 11:45:00 +00:00
End If
2022-11-07 07:16:34 +00:00
If TrackPos <= 0 Then
Dim CommandChar As String
CommandChar = TextBox1.Lines(TextBox1.Lines.Length - 1)
CommandChar = CommandChar.Replace(DefaultPrompt, "")
TrackPos = CommandChar.Length - 1
TextBox1.Select(TextBox1.TextLength, 0)
TextBox1.ScrollToCaret()
End If
'If TrackPos < 1 Then
' e.SuppressKeyPress = True
' TrackPos = TrackPos - 1
'Else
' TrackPos = TrackPos - 2
'End If
Case Keys.Up
e.SuppressKeyPress = True
2022-11-08 03:22:01 +00:00
If Strings.AvailableFeature(18) = 1 Then
ShOSKey_Display()
TextRebind()
End If
2022-11-07 07:16:34 +00:00
Case Keys.Down
e.SuppressKeyPress = True
2022-11-08 03:22:01 +00:00
If Strings.AvailableFeature(18) = 1 Then
ShOSKey_Display()
TextRebind()
End If
2022-11-07 07:16:34 +00:00
Case Else
TrackPos = TrackPos + 1
End Select
2022-11-06 11:45:00 +00:00
End If
2022-11-07 07:16:34 +00:00
'If e.KeyCode = Keys.Enter Then
' 'If command = "clear" Then
' ' txtterm.Text = txtterm.Text + ShiftOSDesktop.username & "@" & ShiftOSDesktop.osname & " $> "
' ' txtterm.Select(txtterm.Text.Length, 0)
' 'Else
' ' txtterm.Text = txtterm.Text + Environment.NewLine & ShiftOSDesktop.username & "@" & ShiftOSDesktop.osname & " $> "
' ' txtterm.Select(txtterm.Text.Length, 0)
' 'End If
'Else
' If e.KeyCode = Keys.Back Then
' Else
' TrackPos = TrackPos + 1
' End If
'End If
'If e.KeyCode = Keys.Back Then
' 'If TrackPos < 1 Then
' ' e.SuppressKeyPress = True
' 'Else
' ' If TextBox1.SelectedText.Length < 1 Then
' ' TrackPos = TrackPos - 1
' ' Else
' ' e.SuppressKeyPress = True
' ' End If
' 'End If
'End If
2022-11-01 22:57:27 +00:00
End Sub
Private Sub TextBox1_Click(sender As Object, e As EventArgs) Handles TextBox1.Click, TextBox1.MouseDoubleClick
TextRebind()
2022-11-01 22:57:27 +00:00
End Sub
2022-11-02 21:28:19 +00:00
Private Sub StoryOnlyTimer_Tick(sender As Object, e As EventArgs) Handles StoryOnlyTimer.Tick
Select Case Strings.ComputerInfo(3)
Case "0"
Select Case DisplayStory
Case 5
ResetLine("Connected to <null>")
2022-11-02 21:28:19 +00:00
Case 25
NewLine("<null>: Hey there, Unknown user!")
2022-11-08 06:02:02 +00:00
Case 60
NewLine("<null>: Congratulaions! You have been involuntarily selected for a test on my experimental operating system, ShiftOS.")
2022-11-08 06:02:02 +00:00
Case 125
NewLine("<null>: ShiftOS is an operating system that will evolve itself as you use it as I progressively add more features into ShiftOS.")
2022-11-08 06:02:02 +00:00
Case 160
NewLine("<null>: Currently ShiftOS isn't much from a basic command-line operating system.")
2022-11-08 06:02:02 +00:00
Case 210
NewLine("<null>: I don't wish to reveal my indentity at this point in time.")
2022-11-08 06:02:02 +00:00
Case 270
NewLine("<null>: I will install ShiftOS on your system once I leave while I work on... something else.")
2022-11-08 06:02:02 +00:00
Case 335
NewLine("<null>: Once you have ShiftOS rich feature enough, I will come back to you. In the mean time, goodbye!")
2022-11-08 06:02:02 +00:00
Case 400
NewLine("<null> Disconnected")
2022-11-08 06:02:02 +00:00
Case 430
ResetLine("Installing ShiftOS...")
2022-11-08 06:02:02 +00:00
Case 550
ResetLine("ShiftOS Installed, The computer will restart in a few seconds")
2022-11-08 06:02:02 +00:00
Case 600
StoryOnlyTimer.Stop()
2022-11-02 21:28:19 +00:00
TextBox1.Text = Nothing
TextBox1.ReadOnly = False
Strings.ComputerInfo(0) = "shiftos"
Strings.ComputerInfo(1) = "user"
CheckFeature()
Terminal_PrintPrompt()
Terminal_AssignPrompt()
2022-11-02 21:28:19 +00:00
TextBox1.Select(TextBox1.TextLength, 0)
TextBox1.ScrollToCaret()
End Select
End Select
DisplayStory = DisplayStory + 1
End Sub
Private Sub InfoBarTimer_Tick(sender As Object, e As EventArgs) Handles InfoBarTimer.Tick
InfoBar.Text = "|"
If Strings.AvailableFeature(5) = "1" Then
InfoBar.Text = InfoBar.Text & " " & Math.Floor(Date.Now.Subtract(Date.Today).TotalSeconds) & " |"
ElseIf Strings.AvailableFeature(5) = "3" Then
If Strings.AvailableFeature(6) = "1" Then
InfoBar.Text = InfoBar.Text & " " & Math.Floor(Date.Now.Subtract(Date.Today).TotalMinutes) & " |"
ElseIf Strings.AvailableFeature(6) = "3" Then
If Strings.AvailableFeature(7) = "1" Then
InfoBar.Text = InfoBar.Text & " " & Math.Floor(Date.Now.Subtract(Date.Today).TotalHours) & " |"
ElseIf Strings.AvailableFeature(7) = "3" Then
If Strings.AvailableFeature(12) = "1" Then
If Date.Now.Hour < 12 Then
InfoBar.Text = InfoBar.Text & Environment.NewLine & " " & TimeOfDay.Hour & " AM |"
Else
InfoBar.Text = InfoBar.Text & Environment.NewLine & " " & TimeOfDay.Hour - 12 & " PM |"
End If
ElseIf Strings.AvailableFeature(12) = "3" Then
If Strings.AvailableFeature(23) = "1" Then
InfoBar.Text = InfoBar.Text & Environment.NewLine & " " & TimeOfDay.Hour & ":" & TimeOfDay.Minute & " |"
End If
End If
End If
End If
End If
If Strings.AvailableFeature(24) = 1 Then
InfoBar.Text = InfoBar.Text & " " & Date.Now.DayOfYear & " |"
ElseIf Strings.AvailableFeature(24) = 3 Then
If Strings.AvailableFeature(25) = 1 Then
Dim WeekOfYear As String = Date.Now.DayOfYear / 7
InfoBar.Text = InfoBar.Text & " " & WeekOfYear.Substring(0, 2) & " |"
ElseIf Strings.AvailableFeature(25) = 3 Then
If Strings.AvailableFeature(26) = 1 Then
InfoBar.Text = InfoBar.Text & " " & Date.Now.Month & " |"
ElseIf Strings.AvailableFeature(26) = 3 Then
If Strings.AvailableFeature(27) = 1 Then
InfoBar.Text = InfoBar.Text & " " & Date.Now.Year & " |"
ElseIf Strings.AvailableFeature(27) = 3 Then
If Strings.AvailableFeature(28) = 1 Then
InfoBar.Text = InfoBar.Text & " " & Date.Now.Day & "/" & Date.Now.Month & " |"
ElseIf Strings.AvailableFeature(28) = 3 Then
If Strings.AvailableFeature(29) = 1 Then
InfoBar.Text = InfoBar.Text & " " & Date.Now.Day & "/" & Date.Now.Month & "/" & Date.Now.Year & " |"
End If
End If
End If
End If
End If
End If
If Strings.OnceInfo(0) = "Yes" Then
InfoBar.Text = InfoBar.Text & " root |"
Else
InfoBar.Text = InfoBar.Text & " user |"
End If
InfoBar.Text = InfoBar.Text & " " & CurrentInterpreter & " |"
InfoBar.Text = InfoBar.Text & " " & Strings.ComputerInfo(2) & " CP |"
2022-11-07 07:16:34 +00:00
InfoBar.Text = InfoBar.Text & " " & TrackPos & " |"
End Sub
Private Sub TextBox1_Click(sender As Object, e As MouseEventArgs) Handles TextBox1.MouseDoubleClick, TextBox1.Click
End Sub
2022-11-01 22:57:27 +00:00
End Class