Imports System.Globalization Public Class ActionScript Public Scripts As New List(Of Script) Public Class ScriptLevel Public WaitingEndWhen As New List(Of Boolean) Public Switched As New List(Of Boolean) Public WaitingEndIf As New List(Of Boolean) Public CanTriggerElse As New List(Of Boolean) Public IfIndex As Integer Public WhenIndex As Integer Public WhileQuery As New List(Of Script) Public WhileQueryInitialized As Boolean = False Public ScriptVersion As Integer Public CurrentLine As Integer Public ScriptName As String End Class ''' ''' Returns the current ScriptLevel based on the script index. ''' Public Shared Function CSL() As ScriptLevel Return ScriptLevels(ScriptLevelIndex) End Function Public Shared ScriptLevels(99) As ScriptLevel Public Shared ScriptLevelIndex As Integer = -1 Public reDelay As Single = 0.0F Dim LevelRef As Level Public Sub New(ByVal LevelRef As Level) Me.LevelRef = LevelRef End Sub Public Shared TempInputDirection As Integer = -1 Public Shared TempSpin As Boolean = False Public Sub Update() nextScript: Dim unlock As Boolean = Me.IsReady If Scripts.Count > 0 Then Scripts(0).Update() End If For i = 0 To Scripts.Count - 1 If i <= Scripts.Count - 1 Then Dim s As Script = Scripts(i) If s.IsReady = True Then i -= 1 Me.AddToWhileQuery(s) Scripts.Remove(s) ScriptLevels(s.Level).CurrentLine += 1 If IsReady = False And s.CanContinue = True Then GoTo nextScript End If End If End If Next If Me.IsReady = True Then If unlock = False Then Logger.Debug("Unlock Camera") CType(Screen.Camera, OverworldCamera).YawLocked = False CType(Screen.Camera, OverworldCamera).ResetCursor() End If If reDelay > 0.0F Then reDelay -= 0.1F If reDelay <= 0.0F Then reDelay = 0.0F End If End If End If End Sub Public ReadOnly Property IsReady() As Boolean Get If Scripts.Count > 0 Then Return False Else Return True End If End Get End Property Public Shared IsInsightScript As Boolean = False ''' ''' Starts a script. ''' ''' The input string. ''' Type of information; 0: Script path, 1: Text, 2: Direct input. Public Sub StartScript(ByVal Input As String, ByVal InputType As Integer, Optional ByVal CheckDelay As Boolean = True, Optional ByVal ResetInsight As Boolean = True) ScriptLevelIndex += 1 TempSpin = False Dim arr(99) As Boolean ScriptLevels(ScriptLevelIndex) = New ScriptLevel() With {.IfIndex = 0, .WhenIndex = 0, .ScriptVersion = 1, .WaitingEndIf = arr.ToList(), .WaitingEndWhen = arr.ToList(), .CurrentLine = 0, .ScriptName = "No script running", .CanTriggerElse = arr.ToList(), .Switched = arr.ToList()} Dim l As ScriptLevel = ScriptLevels(ScriptLevelIndex) If ResetInsight = True Then IsInsightScript = False End If If reDelay = 0.0F Or CheckDelay = False Then Select Case InputType Case 0 ' Start a script from a file. Logger.Debug("Start script (ID: " & Input & ")") l.ScriptName = "Type: Script; Input: " & Input Dim path As String = GameModeManager.GetScriptPath(Input & ".dat") Security.FileValidation.CheckFileValid(path, False, "ActionScript.vb") If System.IO.File.Exists(path) = True Then Dim Data As String = System.IO.File.ReadAllText(path) Data = Data.Replace(Environment.NewLine, "^") Dim ScriptData() As String = Data.Split(CChar("^")) AddScriptLines(ScriptData) Else Logger.Log(Logger.LogTypes.ErrorMessage, "ActionScript.vb: The script file """ & path & """ doesn't exist!") End If Case 1 ' Display text. Logger.Debug("Start Script (Text: " & Input & ")") l.ScriptName = "Type: Text; Input: " & Input Dim Data As String = "version=2^@text.show(" & Input & ")^" & ":end" Dim ScriptData() As String = Data.Split(CChar("^")) AddScriptLines(ScriptData) Case 2 ' Start a script from direct input. Dim activator As String = Environment.StackTrace.Split(Environment.NewLine)(3) activator = activator.Remove(activator.IndexOf("(")) Logger.Debug("Start Script (DirectInput; " & activator & ")") l.ScriptName = "Type: Direct; Input: " & Input Dim Data As String = Input.Replace(Environment.NewLine, "^") Dim ScriptData() As String = Data.Split(CChar("^")) AddScriptLines(ScriptData) End Select End If End Sub Private Sub AddScriptLines(ByVal ScriptData() As String) Dim i As Integer = 0 Dim l As ScriptLevel = ScriptLevels(ScriptLevelIndex) For Each newScript As String In ScriptData If i = 0 And newScript.ToLower().StartsWith("version=") Then l.ScriptVersion = CInt(newScript.ToLower().Remove(0, ("version=").Length)) l.CurrentLine += 1 Else While newScript.StartsWith(" ") = True Or newScript.StartsWith(StringHelper.Tab) = True newScript = newScript.Remove(0, 1) End While While newScript.EndsWith(" ") = True Or newScript.EndsWith(StringHelper.Tab) = True newScript = newScript.Remove(newScript.Length - 1, 1) End While If newScript <> "" Then Me.Scripts.Insert(i, New Script(newScript, ScriptLevelIndex)) i += 1 End If End If Next End Sub Public Sub Switch(ByVal Answer As Object) Dim l As ScriptLevel = ScriptLevels(ScriptLevelIndex) Dim proceed As Boolean = False Dim first As Boolean = True While proceed = False If Scripts.Count = 0 Then Logger.Log(Logger.LogTypes.Warning, "ActionScript.vb: Illegal "":when"" construct. Terminating execution.") Exit While End If Dim s As Script = Scripts(0) Select Case s.ScriptType Case Script.ScriptTypes.select If first = False Then l.WhenIndex += 1 l.WaitingEndWhen(l.WhenIndex) = True l.Switched(l.WhenIndex) = True End If Case Script.ScriptTypes.Command If s.ScriptV2.Value.ToLower().StartsWith("options.show(") = True And first = False Then l.WhenIndex += 1 l.WaitingEndWhen(l.WhenIndex) = True l.Switched(l.WhenIndex) = True End If Case Script.ScriptTypes.SwitchWhen, Script.ScriptTypes.when If l.Switched(l.WhenIndex) = False Then Dim equal As Boolean = False Dim args() As String = Scripts(0).Value.Split(CChar(";")) For Each arg As String In args If (ScriptVersion2.ScriptComparer.EvaluateConstruct(arg).Equals(ScriptVersion2.ScriptComparer.EvaluateConstruct(Answer))) = True Then equal = True Exit For End If Next If equal = True Then l.WaitingEndWhen(l.WhenIndex) = False proceed = True Else l.WaitingEndWhen(l.WhenIndex) = True End If End If Case Script.ScriptTypes.SwitchEndWhen, Script.ScriptTypes.endwhen l.WaitingEndWhen(l.WhenIndex) = False l.Switched(l.WhenIndex) = False l.WhenIndex -= 1 If l.WaitingEndWhen(l.WhenIndex) = False Then proceed = True End If End Select Me.AddToWhileQuery(Scripts(0)) Scripts.RemoveAt(0) l.CurrentLine += 1 first = False End While End Sub Public Sub ChooseIf(ByVal T As Boolean) Dim l As ScriptLevel = ScriptLevels(ScriptLevelIndex) Dim proceed As Boolean = False While proceed = False If Scripts.Count = 0 Then Logger.Log(Logger.LogTypes.Warning, "ActionScript.vb: Illegal "":if"" construct. Terminating execution.") Exit While End If Dim s As Script = Scripts(0) Select Case s.ScriptType Case Script.ScriptTypes.if, Script.ScriptTypes.SwitchIf l.IfIndex += 1 If l.WaitingEndIf(l.IfIndex - 1) = True Then l.WaitingEndIf(l.IfIndex) = True l.CanTriggerElse(l.IfIndex) = False Else If T = True Then proceed = True l.WaitingEndIf(l.IfIndex) = False l.CanTriggerElse(l.IfIndex) = False Else l.WaitingEndIf(l.IfIndex) = True l.CanTriggerElse(l.IfIndex) = True End If End If Case Script.ScriptTypes.else, Script.ScriptTypes.SwitchElse If l.CanTriggerElse(l.IfIndex) = True Then l.WaitingEndIf(l.IfIndex) = False proceed = True Else l.WaitingEndIf(l.IfIndex) = True End If Case Script.ScriptTypes.endif, Script.ScriptTypes.SwitchEndIf l.IfIndex -= 1 If l.WaitingEndIf(l.IfIndex) = False Then proceed = True End If End Select Me.AddToWhileQuery(Scripts(0)) Scripts.RemoveAt(0) l.CurrentLine += 1 End While If Scripts.Count > 0 Then Scripts(0).Update() End If End Sub Public Sub AddToWhileQuery(ByVal RemovedScript As Script) If CSL().WhileQueryInitialized = True And CSL().ScriptVersion = 2 Then CSL().WhileQuery.Add(RemovedScript) If RemovedScript.ScriptV2.ScriptType = ScriptV2.ScriptTypes.endwhile Then Dim i As Integer = 0 For Each s As Script In CSL().WhileQuery Me.Scripts.Insert(i, s.Clone()) i += 1 Next CSL().WhileQuery.Clear() CSL().WhileQueryInitialized = False End If End If End Sub #Region "Registers" Public Shared Function IsRegistered(ByVal i As String) As Boolean CheckTimeBasedRegisters() If Core.Player.RegisterData.Contains(",") = True Then Dim Data() As String = Core.Player.RegisterData.Split(CChar(",")) For Each d As String In Data If d.StartsWith("[") = True And d.EndsWith("]") = False And d.Contains("]") = True Then d = d.Remove(0, d.IndexOf("]") + 1) If d = i Then Return True End If Else If d = i Then Return True End If End If Next Return False Else If Core.Player.RegisterData.StartsWith("[") = True And Core.Player.RegisterData.EndsWith("]") = False And Core.Player.RegisterData.Contains("]") = True Then Dim d As String = Core.Player.RegisterData.Remove(0, Core.Player.RegisterData.IndexOf("]") + 1) If d = i Then Return True End If Else If Core.Player.RegisterData = i Then Return True End If End If Return False End If End Function Private Shared Sub CheckTimeBasedRegisters() If Core.Player.RegisterData <> "" Then Dim Data As List(Of String) = {Core.Player.RegisterData}.ToList() If Core.Player.RegisterData.Contains(",") = True Then Data = Core.Player.RegisterData.Split(CChar(",")).ToList() End If Dim removedRegisters As Boolean = False For i = 0 To Data.Count - 1 If i <= Data.Count - 1 Then Dim d As String = Data(i) If d.StartsWith("[TIME|") = True Then Dim timeString As String = d.Remove(0, ("[TIME|").Length) timeString = timeString.Remove(timeString.IndexOf("]")) Dim timeData() As String = timeString.Split(CChar("|")) Dim regDate As Date = UnixToTime(timeData(0)) Dim value As Integer = CInt(timeData(1)) Dim format As String = timeData(2) Dim remove As Boolean = False Dim date1 = Date.Now Dim date2 = regDate Dim diff = date1 - date2 Select Case format Case "days", "day" If CInt(diff.TotalDays) >= value Then remove = True End If Case "minutes", "minute" If CInt(diff.TotalMinutes) >= value Then remove = True End If Case "seconds", "second" If CInt(diff.TotalSeconds) >= value Then remove = True End If Case "years", "year" If CInt(Math.Floor(diff.TotalDays / 365)) >= value Then remove = True End If Case "weeks", "week" If CInt(Math.Floor(diff.TotalDays / 7)) >= value Then remove = True End If Case "months", "month" If ((date1.Year - date2.Year) * 12) + date1.Month - date2.Month >= value Then remove = True End If Case "hours", "hour" If CInt(diff.TotalHours) >= value Then remove = True End If Case "dayofweek" If CInt(Math.Floor(diff.TotalDays / 7)) >= value Then remove = True End If End Select If remove = True Then Data.RemoveAt(i) i -= 1 removedRegisters = True End If End If End If Next If removedRegisters = True Then Dim s As String = "" If Data.Count > 0 Then For Each d As String In Data If s <> "" Then s &= "," End If s &= d Next End If Core.Player.RegisterData = s End If End If End Sub Public Shared Function UnixToTime(ByVal strUnixTime As String) As Date Dim unixDate = New Date(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc) strUnixTime = strUnixTime.Split(".")(0) Dim a = Convert.ToInt64(strUnixTime) unixDate = unixDate.AddSeconds(a) unixDate = unixDate.ToLocalTime() Return unixDate End Function Public Shared Function TimeToUnix(ByVal dteDate As Date) As String Dim invC = CultureInfo.InvariantCulture Return (dteDate.ToUniversalTime() - New Date(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc)).TotalSeconds.ToString(invC) End Function Public Shared Sub RegisterID(ByVal i As String) Dim Data As String = Core.Player.RegisterData If Data = "" Then Data = i Else Dim checkData() As String = Data.Split(CChar(",")) If checkData.Contains(i) = False Then Data &= "," & i End If End If Core.Player.RegisterData = Data End Sub Public Shared Sub RegisterID(ByVal name As String, ByVal type As String, ByVal value As String) Dim Data As String = Core.Player.RegisterData Dim reg As String = "[" & type.ToUpper() & "|" & value & "]" & name If Data = "" Then Data = reg Else Dim checkData() As String = Data.Split(CChar(",")) If checkData.Contains(reg) = False Then Data &= "," & reg End If End If Core.Player.RegisterData = Data End Sub Public Shared Sub UnregisterID(ByVal i As String) Dim checkData() As String = Core.Player.RegisterData.Split(CChar(",")) Dim Data As String = "" Dim checkList As List(Of String) = checkData.ToList() checkList.Remove(i) checkData = checkList.ToArray() For a = 0 To checkData.Count - 1 If a <> 0 Then Data &= "," End If Data &= checkData(a) Next Core.Player.RegisterData = Data End Sub Public Shared Sub UnregisterID(ByVal name As String, ByVal type As String) Dim Data() As String = Core.Player.RegisterData.Split(CChar(",")) Dim newData As String = "" For Each line As String In Data If line.StartsWith("[") = True And line.Contains("]") = True And line.EndsWith("]") = False Then Dim lName As String = line.Remove(0, line.IndexOf("]") + 1) Dim lType As String = line.Remove(0, 1) lType = lType.Remove(lType.IndexOf("|")) If lName <> name Or lType.ToLower() <> type.ToLower() Then If newData <> "" Then newData &= "," End If newData &= line End If Else If newData <> "" Then newData &= "," End If newData &= line End If Next Core.Player.RegisterData = newData End Sub Public Shared Sub ChangeRegister(ByVal name As String, ByVal newValue As String) Dim Data() As String = Core.Player.RegisterData.Split(CChar(",")) Dim newData As String = "" For Each line As String In Data If newData <> "" Then newData &= "," End If If line.StartsWith("[") = True And line.Contains("]") = True And line.EndsWith("]") = False Then Dim lName As String = line.Remove(0, line.IndexOf("]") + 1) Dim lType As String = line.Remove(0, 1) lType = lType.Remove(lType.IndexOf("|")) If lName.ToLower() = name.ToLower() Then newData &= "[" & lType & "|" & newValue & "]" & name Else newData &= line End If Else newData &= line End If Next Core.Player.RegisterData = newData End Sub ''' ''' Returns the Value and Type of a Register with value. {Value,Type} ''' ''' The name of the register. Public Shared Function GetRegisterValue(ByVal Name As String) As Object() Dim registers() As String = Core.Player.RegisterData.Split(CChar(",")) For Each line As String In registers If line.StartsWith("[") = True And line.Contains("]") = True And line.EndsWith("]") = False Then Dim lName As String = line.Remove(0, line.IndexOf("]") + 1) If lName.ToLower() = Name.ToLower() Then Dim lType As String = line.Remove(0, 1) lType = lType.Remove(lType.IndexOf("|")) Dim lValue As String = line.Remove(0, line.IndexOf("|") + 1) lValue = lValue.Remove(lValue.IndexOf("]")) Return {lValue, lType} End If End If Next Return {Nothing, Nothing} End Function #End Region End Class