mirror of
https://git.do.srb2.org/STJr/SRB2.git
synced 2025-01-18 23:42:11 +00:00
391 lines
12 KiB
Text
391 lines
12 KiB
Text
VERSION 5.00
|
|
Begin VB.Form frmUnlockablesEdit
|
|
Caption = "Unlockables Edit"
|
|
ClientHeight = 3675
|
|
ClientLeft = 60
|
|
ClientTop = 345
|
|
ClientWidth = 8130
|
|
Icon = "frmUnlockablesEdit.frx":0000
|
|
LinkTopic = "Form1"
|
|
MaxButton = 0 'False
|
|
ScaleHeight = 3675
|
|
ScaleWidth = 8130
|
|
StartUpPosition = 3 'Windows Default
|
|
Begin VB.CheckBox chkGrade
|
|
Caption = "Must have beaten Ultimate"
|
|
Height = 255
|
|
Index = 4
|
|
Left = 5400
|
|
TabIndex = 20
|
|
Tag = "1024"
|
|
Top = 2160
|
|
Width = 2655
|
|
End
|
|
Begin VB.CheckBox chkGrade
|
|
Caption = "Must have beaten Very Hard"
|
|
Height = 255
|
|
Index = 3
|
|
Left = 5400
|
|
TabIndex = 19
|
|
Tag = "128"
|
|
Top = 1800
|
|
Width = 2655
|
|
End
|
|
Begin VB.CheckBox chkGrade
|
|
Caption = "Must have all emblems"
|
|
Height = 255
|
|
Index = 2
|
|
Left = 5400
|
|
TabIndex = 18
|
|
Tag = "16"
|
|
Top = 1440
|
|
Width = 2055
|
|
End
|
|
Begin VB.CheckBox chkGrade
|
|
Caption = "Must have gotten all 7 emeralds"
|
|
Height = 255
|
|
Index = 1
|
|
Left = 5400
|
|
TabIndex = 17
|
|
Tag = "8"
|
|
Top = 1080
|
|
Width = 2655
|
|
End
|
|
Begin VB.CheckBox chkGrade
|
|
Caption = "Game must be completed"
|
|
Height = 255
|
|
Index = 0
|
|
Left = 5400
|
|
TabIndex = 16
|
|
Tag = "1"
|
|
Top = 720
|
|
Width = 2175
|
|
End
|
|
Begin VB.TextBox txtVar
|
|
Height = 285
|
|
Left = 4320
|
|
TabIndex = 14
|
|
Top = 2640
|
|
Width = 615
|
|
End
|
|
Begin VB.ComboBox cmbType
|
|
Height = 315
|
|
ItemData = "frmUnlockablesEdit.frx":0442
|
|
Left = 3360
|
|
List = "frmUnlockablesEdit.frx":044C
|
|
TabIndex = 12
|
|
Top = 2160
|
|
Width = 1575
|
|
End
|
|
Begin VB.TextBox txtNeededTime
|
|
Height = 285
|
|
Left = 4080
|
|
TabIndex = 10
|
|
Top = 1680
|
|
Width = 855
|
|
End
|
|
Begin VB.TextBox txtNeededEmblems
|
|
Height = 285
|
|
Left = 4440
|
|
TabIndex = 9
|
|
Top = 1200
|
|
Width = 495
|
|
End
|
|
Begin VB.TextBox txtObjective
|
|
Height = 285
|
|
Left = 3240
|
|
TabIndex = 7
|
|
Top = 720
|
|
Width = 1695
|
|
End
|
|
Begin VB.TextBox txtName
|
|
Height = 285
|
|
Left = 3240
|
|
TabIndex = 5
|
|
Top = 240
|
|
Width = 1695
|
|
End
|
|
Begin VB.CommandButton cmdDelete
|
|
Caption = "&Delete from SOC"
|
|
Height = 375
|
|
Left = 3480
|
|
TabIndex = 3
|
|
Top = 3120
|
|
Width = 1575
|
|
End
|
|
Begin VB.CommandButton cmdSave
|
|
Caption = "&Save Changes"
|
|
Height = 375
|
|
Left = 1800
|
|
TabIndex = 2
|
|
Top = 3120
|
|
Width = 1575
|
|
End
|
|
Begin VB.ListBox lstUnlockables
|
|
Height = 2985
|
|
ItemData = "frmUnlockablesEdit.frx":046A
|
|
Left = 120
|
|
List = "frmUnlockablesEdit.frx":049B
|
|
TabIndex = 0
|
|
Top = 480
|
|
Width = 1215
|
|
End
|
|
Begin VB.Label lblNote
|
|
Caption = "Note: All requirements are combinable."
|
|
Height = 495
|
|
Left = 6000
|
|
TabIndex = 22
|
|
Top = 2760
|
|
Width = 1695
|
|
End
|
|
Begin VB.Label lblOtherReqs
|
|
Caption = "Other Requirements:"
|
|
Height = 255
|
|
Left = 5400
|
|
TabIndex = 21
|
|
Top = 360
|
|
Width = 1935
|
|
End
|
|
Begin VB.Label lblVar
|
|
Alignment = 1 'Right Justify
|
|
Caption = "Map # to warp to:"
|
|
Height = 255
|
|
Left = 2880
|
|
TabIndex = 15
|
|
Top = 2640
|
|
Width = 1335
|
|
End
|
|
Begin VB.Label lblType
|
|
Alignment = 1 'Right Justify
|
|
Caption = "Type of Unlockable:"
|
|
Height = 255
|
|
Left = 1800
|
|
TabIndex = 13
|
|
Top = 2160
|
|
Width = 1455
|
|
End
|
|
Begin VB.Label lblNeededTime
|
|
Alignment = 1 'Right Justify
|
|
Caption = "Needed time on Time Attack rank (in seconds):"
|
|
Height = 375
|
|
Left = 1440
|
|
TabIndex = 11
|
|
Top = 1560
|
|
Width = 2535
|
|
End
|
|
Begin VB.Label lblNeededEmblems
|
|
Alignment = 1 'Right Justify
|
|
Caption = "# of Emblems Needed:"
|
|
Height = 255
|
|
Left = 2640
|
|
TabIndex = 8
|
|
Top = 1200
|
|
Width = 1695
|
|
End
|
|
Begin VB.Label lblObjective
|
|
Alignment = 1 'Right Justify
|
|
Caption = "Objective:"
|
|
Height = 255
|
|
Left = 2400
|
|
TabIndex = 6
|
|
Top = 720
|
|
Width = 735
|
|
End
|
|
Begin VB.Label lblName
|
|
Alignment = 1 'Right Justify
|
|
Caption = "Name:"
|
|
Height = 255
|
|
Left = 2640
|
|
TabIndex = 4
|
|
Top = 240
|
|
Width = 495
|
|
End
|
|
Begin VB.Label lblHUDItems
|
|
Caption = "Unlockables:"
|
|
Height = 255
|
|
Left = 120
|
|
TabIndex = 1
|
|
Top = 240
|
|
Width = 975
|
|
End
|
|
End
|
|
Attribute VB_Name = "frmUnlockablesEdit"
|
|
Attribute VB_GlobalNameSpace = False
|
|
Attribute VB_Creatable = False
|
|
Attribute VB_PredeclaredId = True
|
|
Attribute VB_Exposed = False
|
|
Option Explicit
|
|
|
|
Private Sub cmdDelete_Click()
|
|
Call WriteUnlockableItem(True)
|
|
End Sub
|
|
|
|
Private Sub cmdSave_Click()
|
|
Call WriteUnlockableItem(False)
|
|
End Sub
|
|
|
|
Private Sub Form_Load()
|
|
Call Reload
|
|
End Sub
|
|
|
|
Private Sub Reload()
|
|
txtName.Text = ""
|
|
txtObjective.Text = ""
|
|
txtNeededEmblems.Text = ""
|
|
txtNeededTime.Text = ""
|
|
cmbType.Text = ""
|
|
txtVar.Text = ""
|
|
|
|
Dim i As Integer
|
|
|
|
For i = 0 To chkGrade.Count - 1
|
|
chkGrade(i).Value = 0
|
|
Next i
|
|
|
|
lstUnlockables.ListIndex = 0
|
|
End Sub
|
|
|
|
Private Sub lstUnlockables_Click()
|
|
Call ReadSOC(lstUnlockables.ListIndex + 1)
|
|
End Sub
|
|
|
|
Private Sub ReadSOC(UnlockableNum As Integer)
|
|
Dim myFSO As New Scripting.FileSystemObject
|
|
Dim ts As TextStream
|
|
Dim line As String
|
|
Dim word As String
|
|
Dim word2 As String
|
|
|
|
Set ts = myFSO.OpenTextFile(SOCFile, ForReading, False)
|
|
|
|
SOCLoad:
|
|
Do While Not ts.AtEndOfStream
|
|
line = ts.ReadLine
|
|
|
|
If Left(line, 1) = "#" Then GoTo SOCLoad
|
|
|
|
If Left(line, 1) = vbCrLf Then GoTo SOCLoad
|
|
|
|
If Len(line) < 1 Then GoTo SOCLoad
|
|
|
|
word = FirstToken(line)
|
|
word2 = SecondToken(line)
|
|
|
|
If UCase(word) = "UNLOCKABLE" And Val(word2) = UnlockableNum Then
|
|
Do While Len(line) > 0 And Not ts.AtEndOfStream
|
|
line = ts.ReadLine
|
|
word = UCase(FirstToken(line))
|
|
word2 = UCase(SecondTokenEqual(line))
|
|
|
|
If word = "NAME" Then
|
|
txtName.Text = word2
|
|
ElseIf word = "OBJECTIVE" Then
|
|
txtObjective.Text = word2
|
|
ElseIf word = "NEEDEDEMBLEMS" Then
|
|
txtNeededEmblems.Text = Val(word2)
|
|
ElseIf word = "NEEDEDTIME" Then
|
|
txtNeededTime.Text = Val(word2)
|
|
ElseIf word = "TYPE" Then
|
|
cmbType.ListIndex = Val(word2)
|
|
ElseIf word = "VAR" Then
|
|
txtVar.Text = Val(word2)
|
|
ElseIf word = "NEEDEDGRADE" Then
|
|
Dim i As Integer
|
|
|
|
For i = 0 To chkGrade.Count - 1
|
|
If Val(word2) And chkGrade(i).Tag Then
|
|
chkGrade(i).Tag = True
|
|
End If
|
|
Next i
|
|
ElseIf Len(line) > 0 And Left(line, 1) <> "#" Then
|
|
MsgBox "Error in SOC!" & vbCrLf & "Unknown line: " & line
|
|
End If
|
|
Loop
|
|
Exit Do
|
|
End If
|
|
Loop
|
|
|
|
ts.Close
|
|
Set myFSO = Nothing
|
|
End Sub
|
|
|
|
Private Sub WriteUnlockableItem(Remove As Boolean)
|
|
Dim myFSOSource As New Scripting.FileSystemObject
|
|
Dim tsSource As TextStream
|
|
Dim myFSOTarget As New Scripting.FileSystemObject
|
|
Dim tsTarget As TextStream
|
|
Dim line As String
|
|
Dim word As String
|
|
Dim word2 As String
|
|
Dim unlockableremoved As Boolean
|
|
|
|
unlockableremoved = False
|
|
|
|
Set tsSource = myFSOSource.OpenTextFile(SOCFile, ForReading, False)
|
|
Set tsTarget = myFSOTarget.OpenTextFile(SOCTemp, ForWriting, True)
|
|
|
|
Do While Not tsSource.AtEndOfStream
|
|
line = tsSource.ReadLine
|
|
word = UCase(FirstToken(line))
|
|
word2 = UCase(SecondToken(line))
|
|
|
|
'If the current item exists in the SOC, delete it.
|
|
If word = "UNLOCKABLE" And Val(word2) = lstUnlockables.ListIndex + 1 Then
|
|
unlockableremoved = True
|
|
Do While Len(TrimComplete(tsSource.ReadLine)) > 0 And Not tsSource.AtEndOfStream
|
|
Loop
|
|
Else
|
|
tsTarget.WriteLine line
|
|
End If
|
|
Loop
|
|
|
|
tsSource.Close
|
|
Set myFSOSource = Nothing
|
|
|
|
If Remove = False Then
|
|
If line <> "" Then tsTarget.WriteLine ""
|
|
|
|
tsTarget.WriteLine "UNLOCKABLE " & lstUnlockables.ListIndex + 1
|
|
txtName.Text = TrimComplete(txtName.Text)
|
|
txtObjective.Text = TrimComplete(txtObjective.Text)
|
|
txtNeededEmblems.Text = TrimComplete(txtNeededEmblems.Text)
|
|
txtNeededTime.Text = TrimComplete(txtNeededTime.Text)
|
|
txtVar.Text = TrimComplete(txtVar.Text)
|
|
|
|
If txtName.Text <> "" Then tsTarget.WriteLine "NAME = " & txtName.Text
|
|
If txtObjective.Text <> "" Then tsTarget.WriteLine "OBJECTIVE = " & txtObjective.Text
|
|
If txtNeededEmblems.Text <> "" Then tsTarget.WriteLine "NEEDEDEMBLEMS = " & txtNeededEmblems.Text
|
|
If txtNeededTime.Text <> "" Then tsTarget.WriteLine "NEEDEDTIME = " & txtNeededTime.Text
|
|
If cmbType.ListIndex <> -1 Then tsTarget.WriteLine "TYPE = " & cmbType.ListIndex
|
|
If txtVar.Text <> "" Then tsTarget.WriteLine "VAR = " & txtVar.Text
|
|
|
|
Dim writegrade As Long
|
|
Dim i As Integer
|
|
writegrade = 0
|
|
|
|
For i = 0 To chkGrade.Count - 1
|
|
If chkGrade(i).Value = 1 Then
|
|
writegrade = writegrade + chkGrade(i).Tag
|
|
End If
|
|
Next i
|
|
|
|
If writegrade > 0 Then tsTarget.WriteLine "NEEDEDGRADE = " & writegrade
|
|
End If
|
|
|
|
tsTarget.Close
|
|
Set myFSOTarget = Nothing
|
|
|
|
FileCopy SOCTemp, SOCFile
|
|
|
|
Kill SOCTemp
|
|
|
|
If Remove = True Then
|
|
If unlockableremoved = True Then
|
|
MsgBox "Unlockable deleted from SOC."
|
|
Else
|
|
MsgBox "Couldn't find Unlockable in SOC."
|
|
End If
|
|
Else
|
|
MsgBox "Unlockable Saved."
|
|
End If
|
|
End Sub
|