-
Notifications
You must be signed in to change notification settings - Fork 110
/
Copy pathUpdate.bb
904 lines (740 loc) · 23.5 KB
/
Update.bb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
; ID: 1816
; Author: Andres
; Date: 2006-09-18 11:05:21
; Title: Remote File Engine
; Description: Easy way to download and read remote files via HTTP/FTP
Global UserAgent$ = "SCPCB" ; What ever you'd like to name your application
Global ResponseDelay% = 2000 ; How many millisecs to wait for HTTP response
Global NewLine$ = Chr(13) + Chr(10) ; Line break may differ
Const RFDebugMode% = False ; Debug mode
Global UpdateCheckEnabled% = GetINIInt(OptionFile, "options", "check for updates")
Type transporter
Field id%
Field code%
Field filename$
Field protocol$
End Type
Function OpenRemoteFile%(path$, port% = 80, variables$ = "", httpheader$ = "")
Local protocol$ = Lower(Sector$(path$, ":", 0))
Local host$ = Sector$(path$, "/", 2)
Local ip$ = "www." + Sector$(host$, ".", Sectors%(host$, ".") - 1) + "." + Sector$(host$, ".", Sectors%(host$, "."))
path$ = "/" + Sector$(path$, "/", 3, True)
Local header%, bank%, tim%, occ%
Local Stream% = OpenTCPStream(host$, port%)
If Not Stream% Then Stream% = OpenTCPStream(ip$, port%)
If Stream
Select protocol$
Case "http", "https" ; ---------------------------------------------------------------------------------------------------------------------------------------
; Send request
If Not Len(variables$) Then
WriteLine(Stream, "GET " + path$ + " HTTP/1.1")
Else
WriteLine(Stream, "POST " + path$ + " HTTP/1.1")
EndIf
WriteLine(Stream, "Host: " + host$)
WriteLine(Stream, "User-Agent: " + UserAgent$)
If Len(variables$) Then
WriteLine(Stream, "Content-Type: application/x-www-form-urlencoded")
WriteLine(Stream, "Content-Length: " + Len(variables$))
EndIf
If Len(httpheader$) Then WriteLine(Stream, httpheader$)
WriteLine(Stream, "Connection: Close")
WriteLine(Stream, "")
If Len(variables$) Then WriteLine(Stream, variables$)
; Debug mode
If RFDebugMode% Then
If Not Len(variables$) Then DebugLog ">>> GET " + path$ + " HTTP/1.1" Else DebugLog ">>> POST " + path$ + " HTTP/1.1"
DebugLog ">>> Host: " + host$
DebugLog ">>> User-Agent: " + UserAgent$
If Len(variables$) Then
DebugLog ">>> Content-Type: application/x-www-form-urlencoded"
DebugLog ">>> Content-Length: " + Len(variables$)
EndIf
If Len(httpheader$) Then DebugLog ">>> " + httpheader$
DebugLog ">>> Connection: Close"
DebugLog ">>> "
If Len(variables$) Then DebugLog ">>> " + variables$
EndIf
; Wait for response
tim = MilliSecs()
Repeat
Until (MilliSecs() - tim) => ResponseDelay% Or ReadAvail(Stream)
txt$ = ReadLine$(Stream%)
If RFDebugMode Then DebugLog "<<< " + txt$
If Sector$(txt$, " ", 0) = "HTTP/1.1" Or Sector$(txt$, " ", 0) = "HTTP/1.0"
code% = Int Sector$(txt$, " ", 1)
If (code% => 300) Then
CloseTCPStream Stream%
Return False
EndIf
EndIf
occ% = 0
header% = CreateBank(0)
bank% = CreateBank(12); Bank Int, Stream Int, Size Int
PokeInt(bank%, 0, header%)
PokeInt(bank%, 4, Stream%)
PokeInt(bank%, 8, -1)
this.transporter = New transporter
this\id% = bank%
this\code% = code%
this\filename$ = Sector$(path$, "/", Sectors%(path$, "/"))
this\protocol$ = "http"
; Received HTTP Header
Repeat
txt$ = ReadRemoteLine$(bank%)
value$ = Mid$(Sector$(txt$, ":", 1, True), 2)
If RFDebugMode Then DebugLog "<<< " + txt$
Select Sector$(txt$, ":", 0)
Case ""
Return bank%
Case "Content-Disposition"
For i = 0 To Sectors(value$, ";")
subtxt$ = Trim$(Sector$(value$, ";", i))
subvalue$ = Sector$(subtxt$, "=", 1)
Select Sector$(subtxt$, "=", 0)
Case "filename"
this\filename$ = subvalue$
DebugLog "[" + this\filename$ + "]"
End Select
Next
Case "Content-Length"
PokeInt bank%, 8, Int(value$)
End Select
Forever
Case "ftp" ; ---------------------------------------------------------------------------------------------------------------------------------------
header% = CreateBank(1)
bank% = CreateBank(16); Bank Int, Stream Int, Size Int
PokeInt(bank%, 0, header%)
PokeInt(bank%, 4, Stream%)
PokeInt(bank%, 8, -1)
PokeInt(bank%, 12, Stream%)
this.transporter = New transporter
this\id% = bank%
this\code% = "0"
this\filename$ = Sector$(path$, "/", Sectors(path$, "/"))
this\protocol$ = "ftp"
; Wait for response
tim = MilliSecs()
Repeat
Until (MilliSecs() - tim) => ResponseDelay% Or ReadAvail(Stream)
Repeat
If ReadAvail(Stream%)
txt$ = ReadLine(Stream%)
code% = Int Sector$(txt$, " ", 0)
value$ = Mid$(Sector$(txt$, " ", 1, True), 1)
If RFDebugMode Then DebugLog "<<< " + txt$
Else
txt$ = "":code% = 0:value$ = "":cmd$ = ""
EndIf
If Not ReadAvail(Stream%)
Select code%
Case 220
cmd$ = "USER " + variables$
Case 331
cmd$ = "PASS " + httpheader$
Case 230
cmd$ = "SIZE " + path$
Case 213
PokeInt(bank%, 8, Int value$)
cmd$ = "PASV"
Case 227
; Connect to PASV mode
txt$ = Sector(txt$, "(", 1)
host$ = Sector(txt$, ",", 0) + "." + Sector(txt$, ",", 1) + "." + Sector(txt$, ",", 2) + "." + Sector(txt$, ",", 3)
port% = (Int Sector(txt$, ",", 4)) * 256 + (Int Left$(Sector(txt$, ",", 5), Len(Sector(txt$, ",", 5)) - 1))
pasv_stream% = OpenTCPStream(host$, port%)
; Update stream
PokeInt(bank%, 4, pasv_stream%)
cmd$ = "RETR " + path$
Case 150
Return bank%
End Select
; ERROR
If code% => 400
If Stream% Then CloseTCPStream Stream%
If pasv_stream% Then CloseTCPStream pasv_stream%
If header% Then FreeBank header%
If bank% Then FreeBank bank%
Return 0
EndIf
EndIf
If Len(cmd$) Then
If RFDebugMode% Then DebugLog ">>> " + cmd$
WriteLine Stream%, cmd$
EndIf
Forever
Return bank%
End Select
EndIf
End Function
Function CloseRemoteFile(bank%)
If PeekInt(bank%, 0) Then FreeBank PeekInt(bank%, 0)
If PeekInt(bank%, 4) Then CloseTCPStream PeekInt(bank%, 4)
If BankSize(bank%) = 18 Then If PeekInt(bank%, 12)
WriteLine PeekInt(bank%, 12), "BYE"
If RFDebugMode% Then DebugLog ">>> BYE"
CloseTCPStream PeekInt(bank%, 12)
EndIf
FreeBank bank%
For this.transporter = Each transporter
If this\id% = bank%
Delete this
Exit
EndIf
Next
End Function
Function EORF(bank%)
If Not PeekInt(bank%, 4)
If BankSize(PeekInt(bank%, 0)) = 0 Then Return True
Else
If Eof(PeekInt(bank%, 4)) Then Return True
EndIf
End Function
Function RemoteFileSize%(bank%)
Return PeekInt(bank%, 8)
End Function
Function RemoteFileName$(bank%)
For this.transporter = Each transporter
If this\id% = bank% Return this\filename$
Next
End Function
Function RemoteFileCode%(bank%)
For this.transporter = Each transporter
If this\id% = bank% Return this\code%
Next
End Function
Function RemoteFileProtocol$(bank%)
For this.transporter = Each transporter
If this\id% = bank% Return this\protocol$
Next
End Function
Function ReadRemoteLine$(bank%)
Local avail%, rbank% = PeekInt(bank%, 0), stream% = PeekInt(bank%, 4)
; Update bank
UpdateRemoteFile(bank%)
; Read line
txt$ = ""
For i = 0 To BankSize(rbank%) - 1
char% = PeekByte(rbank%, i)
txt$ = txt$ + Chr(char%)
If Right$(txt$, Len(NewLine$)) = NewLine$ Then
Exit
ElseIf Right$(txt$,1) = Chr(10) Then
Exit
EndIf
Next
If Right$(txt$, 2) = NewLine$ Then
txt$ = Mid$(txt$, 1, Len(txt$) - Len(NewLine$))
ElseIf Right$(txt$, 1) = Right$(NewLine$, 1) Then
txt$ = Mid$(txt$, 1, Len(txt$) - (Len(NewLine$) - 1))
EndIf
; Resize bank
size% = BankSize(rbank%) - (Len(txt$) + Len(NewLine$))
If size% < 0 Then size% = 0
ResizeRemoteBank(bank%, size%)
Return txt$
End Function
Function ReadRemoteString$(bank%)
Local rbank% = PeekInt(bank%, 0)
UpdateRemoteFile(bank%)
a% = PeekInt(rbank%, 0)
txt$ = ""
For i = 0 To a% - 1
txt$ = txt$ + Chr(PeekByte(rbank%, 4 + i))
Next
ResizeRemoteBank(bank%, BankSize(rbank%) - (4 + a%))
Return txt$
End Function
Function ReadRemoteInt%(bank%)
Local rbank% = PeekInt(bank%, 0)
UpdateRemoteFile(bank%)
a% = PeekInt(rbank%, 0)
ResizeRemoteBank(bank%, BankSize(rbank%) - 4)
Return a%
End Function
Function ReadRemoteShort%(bank%)
Local rbank% = PeekInt(bank%, 0)
UpdateRemoteFile(bank%)
a% = PeekShort(rbank%, 0)
ResizeRemoteBank(bank%, BankSize(rbank%) - 2)
Return a%
End Function
Function ReadRemoteByte%(bank%)
Local rbank% = PeekInt(bank%, 0)
UpdateRemoteFile(bank%)
a% = PeekByte(rbank%, 0)
ResizeRemoteBank(bank%, BankSize(rbank%) - 1)
Return a%
End Function
Function WriteRemoteBytes(bank%, file%, offset%, count%)
Local rbank% = PeekInt(bank%, 0)
UpdateRemoteFile(bank%)
Local N% = WriteBytes(rbank%, file%, offset%, count%)
ResizeRemoteBank(bank%, BankSize(rbank%) - N%)
Return N%
End Function
Function RemoteReadAvail(bank%)
UpdateRemoteFile(bank%)
received% = BankSize(PeekInt(bank%, 0))
If PeekInt(bank%, 4) Then waiting% = ReadAvail(PeekInt(bank%, 4)) Else waiting% = 0
Return received% + waiting%
End Function
Function UpdateRemoteFile(bank%)
Local rbank% = PeekInt(bank%, 0), stream% = PeekInt(bank%, 4)
If stream% And rbank%
avail% = ReadAvail(stream%)
offset% = BankSize(rbank%)
ResizeBank(rbank%, offset% + avail%)
ReadBytes(rbank%, stream%, offset%, avail%)
If Eof(stream%) Then
CloseTCPStream stream%
PokeInt bank%, 4, 0
EndIf
EndIf
End Function
Function ResizeRemoteBank(bank%, size%)
Local rbank% = PeekInt(bank%, 0), start% = BankSize(rbank%) - size%
If BankSize(rbank%)
CopyBank(rbank%, start%, rbank%, 0, size%)
ResizeBank(rbank%, size%)
EndIf
End Function
Function Sector$(txt$, separator$, Sector%, toend% = False)
Local result$ = "", occ
For i = 1 To Len(txt$)
If Mid$(txt$, i, 1) = separator$
occ = occ + 1
If toend% And occ% > Sector% Then result$ = result$ + Mid$(txt$, i, 1)
Else
If occ => Sector Then result$ = result$ + Mid$(txt$, i, 1)
EndIf
If Not toend% Then If occ > Sector Then Exit
Next
Return result$
End Function
Function Sectors%(txt$, needle$)
occ% = 0
For i = 1 To Len(txt$) Step 1
If Instr(txt$, needle$, i)
occ% = occ% + 1
i = Instr(txt$, needle$, i)
Else
Exit
EndIf
Next
Return occ%
End Function
;=============================================================================================
;link$ - The link. You may enter the link just like you enter it
; in your browser. Very tolerant. No http:// required.
;savepath$ - The path where the file should be saved
;savefile$ - The filename of the saved file. When given "", it will
; be named like the file in the link$.
Const DOWNLOAD_SIZE% = 4096*2
Function Download(link$, savepath$ = "", savefile$ = "", latest$="")
;Strip protocol and return false if not "http"
inst = Instr(link$, "://")
If inst Then
If Lower(Trim(Left(link$, inst - 1))) <> "http" Then Return False
link$ = Right(link$, Len(link$) - inst - 2)
EndIf
;Seperate host from link
inst = Instr(link$, "/")
If inst = 0 Then Return False
host$ = Trim(Left(link$, inst - 1))
link$ = Trim(Right(link$, Len(link$) - inst + 1))
;Seperate path and file from the link
For i = Len(link$) To 1 Step -1
If Mid(link$, i, 1) = "/" Then
link_path$ = Trim(Left(link$, i))
link_file$ = Right(link$, Len(link$) - i)
Exit
EndIf
Next
If link_file$ = "" Then Return False
If savefile$ = "" Then savefile$ = link_file$
;Open TCP stream
tcp = OpenTCPStream(host$, 80)
If tcp = 0 Then Return False
WriteLine tcp, "GET " + link_path$ + link_file$ + " HTTP/1.1" + Chr(13) + Chr(10) + "Host: " + host$ + Chr(13) + Chr(10) + "User-Agent: Download_Function_By_DevilsChild" + Chr(13) + Chr(10)
;Download file
l$ = ReadLine(tcp)
inst1 = Instr(l$, " ")
inst2 = Instr(l$, " ", inst1 + 1)
num = Mid(l$, inst1, inst2 - inst1)
Select num
Case 200
conlen = -1
chunk = False
Repeat
l$ = Trim(ReadLine(tcp))
If l$ = "" Then Exit
inst = Instr(l$, ":")
l1$ = Trim(Left(l$, inst - 1))
l2$ = Trim(Right(l$, Len(l$) - inst))
Select Lower(l1$)
Case "content-length"
conlen = l2$
Case "transfer-encoding"
If Lower(l2$) = "chunked" Then chunk = True
End Select
Forever
If conlen = 0 Then
file = WriteFile(savepath$ + savefile$)
CloseFile file
CloseTCPStream tcp
Return False ;file doesn't exist ;True
ElseIf conlen > 0 Then
file = WriteFile(savepath$ + savefile$)
bnk = CreateBank(DOWNLOAD_SIZE)
pos = 0
Repeat
avail = conlen - pos
If avail > DOWNLOAD_SIZE Then
ReadBytes bnk, tcp, 0, DOWNLOAD_SIZE
WriteBytes bnk, file, 0, DOWNLOAD_SIZE
pos = pos + DOWNLOAD_SIZE
;draw the progress bar
SetBuffer BackBuffer()
Cls
Text 5,5,"Downloading "+latest
Color 255,255,255
Text 5,165,Str(Floor(((Float(pos)/1024.0)/1024.0)*100.0)/100.0)+"MB out of "+Str(Floor(((Float(conlen)/1024.0)/1024.0)*100.0)/100.0)+"MB downloaded"
Rect 14,198,614,18,False
For i=0 To Int((Float(pos)/Float(conlen))*61.0)-1
DrawImage(BlinkMeterIMG, (i*10)+17, 200)
Next
Text 320,230,Int((Float(pos)/Float(conlen))*100.0)+"%",True,False
If DrawButton2(270,400,100,20,"Cancel",False) Then
CloseTCPStream(tcp)
FreeBank bnk
CloseFile file
Return -1
EndIf
Flip False
Else
ReadBytes bnk, tcp, 0, avail
WriteBytes bnk, file, 0, avail
Exit
EndIf
Forever
FreeBank bnk
CloseFile file
CloseTCPStream tcp
Return True
ElseIf chunk Then
file = WriteFile(savepath$ + savefile$)
bnk = CreateBank(DOWNLOAD_SIZE)
Repeat
l$ = Trim(Upper(ReadLine(tcp)))
ln = 0
For i = 1 To Len(l$)
ln = 16 * ln + Instr("123456789ABCDEF", Mid$(l$, i, 1))
Next
If ln = 0 Then Exit
If BankSize(bnk) < ln Then ResizeBank bnk, ln
ReadBytes bnk, tcp, 0, ln
WriteBytes bnk, file, 0, ln
ReadShort(tcp)
Forever
FreeBank bnk
CloseFile file
CloseTCPStream tcp
Return True
Else
CloseTCPStream tcp
Return False
EndIf
Case 301, 302
Repeat
l$ = Trim(ReadLine(tcp))
If l$ = "" Then Exit
inst = Instr(l$, ":")
l1$ = Trim(Left(l$, inst - 1))
l2$ = Trim(Right(l$, Len(l$) - inst))
Select Lower(l1$)
Case "location"
CloseTCPStream tcp
Return Download(l2$, savepath$, savefile$)
End Select
Forever
Default
CloseTCPStream tcp
Return False
End Select
End Function
Global UpdaterBG
Type ChangeLogLines
Field txt$
End Type
Global UpdaterIMG
Global LinesAmount% = 0
Function CheckForUpdates()
;If GetINIInt(OptionFile,"box_of_horrors","check for updates")=False Then Return
AppTitle "SCP - Containment Breach Updater"
Local delExe$
delExe=StripPath(GetINIString(OptionFile,"updater","old_exe"))
If delExe<>"" Then ;delete the old executable
If FileSize(delExe)>0 Then DeleteFile delExe
PutINIValue(OptionFile,"updater","old_exe","")
EndIf
If Not UpdateCheckEnabled Then Return
SetBuffer BackBuffer()
Cls
Color 255,255,255
Text 320,240,"Checking for updates...",True,True
Flip
Local updateCheck% = OpenRemoteFile("http://www.scpcbgame.com/changelog.txt")
If updateCheck=0 Then Return ;remote file couldn't be opened
Local latest$ = "";
Local rl$ = ReadRemoteLine(updateCheck)
While Not EORF(updateCheck)
If Left(Lower(rl),1)="v" And Instr(Lower(rl),".")>0 Then
latest = Trim(Replace(rl,"v",""))
Exit
Else
rl = ReadRemoteLine(updateCheck)
EndIf
Wend
CloseRemoteFile(updateCheck)
If latest="" Then Return
If FileType("updates")=0
CreateDir "updates"
EndIf
DebugLog "LATEST VERSION: "+latest
Local ConfirmDownload%=0
Local DownloadURL$ = ""
If latest<>VersionNumber And latest<>"" Then ;a new version is available!
updateCheck% = OpenRemoteFile("http://www.scpcbgame.com/index.html")
If updateCheck=0 Then Return ;remote file couldn't be opened
DownloadURL$ = ""
rl$ = ReadRemoteLine(updateCheck)
While Not EORF(updateCheck)
If Instr(Lower(rl),"undertowgames.com/file/scp")>0 And Instr(Lower(rl),".zip")>0 Then
DownloadURL = Mid(rl,Instr(Lower(rl),"http://"),Instr(Lower(rl),".zip")-Instr(Lower(rl),"http://")+4)
DebugLog DownloadURL
Exit
Else
rl = ReadRemoteLine(updateCheck)
EndIf
Wend
CloseRemoteFile(updateCheck)
UpdaterBG = LoadImage_Strict("GFX\menu\updater.jpg")
UpdaterIMG = CreateImage(452,254)
Local ChangeLogURL$ = "http://www.scpcbgame.com/changelog.txt"
Download(ChangeLogURL$,"","Changelog_Prev.txt",latest)
Local ChangeLogFile = OpenFile("Changelog_Prev.txt")
Local ChangeLogLineAmount% = 0
While Not Eof(ChangeLogFile)
l$ = ReadLine(ChangeLogFile)
If Left(l,5)<>"-----"
chl.ChangeLogLines = New ChangeLogLines
If l = "v"+latest
chl\txt$ = "NEW UPDATE: "+l
Else
chl\txt$ = l
EndIf
ChangeLogLineAmount = ChangeLogLineAmount + 1
Else
Exit
EndIf
Wend
CloseFile(ChangeLogFile)
DeleteFile("Changelog_Prev.txt")
UpdaterFont = LoadFont("GFX\font\cour\Courier New.ttf",16,0,0,0)
Repeat
SetBuffer BackBuffer()
Cls
Color 255,255,255
MouseHit1 = MouseHit(1)
MouseDown1 = MouseDown(1)
DrawImage UpdaterBG,0,0
If DownloadURL="" Then
SetFont UpdaterFont
If LinesAmount > 13
Local y# = 200-(20*ScrollMenuHeight*ScrollBarY)
LinesAmount%=0
SetBuffer(ImageBuffer(UpdaterIMG))
DrawImage UpdaterBG,-20,-195
For chl.ChangeLogLines = Each ChangeLogLines
Color 0,0,0
If Right(chl\txt$,6) = "v"+latest
Color 200,0,0
EndIf
RowText2(chl\txt$,2,y#-195,430,254)
y# = y#+(20*GetLineAmount2(chl\txt$,430,254))
LinesAmount = LinesAmount + (GetLineAmount2(chl\txt$,430,254))
Next
SetBuffer BackBuffer()
DrawImage UpdaterIMG,20,195
Color 10,10,10
Rect 452,195,20,254,True
ScrollMenuHeight# = LinesAmount-13
ScrollBarY = DrawScrollBar(452,195,20,254,452,195+(254-(254-4*ScrollMenuHeight))*ScrollBarY,20,254-(4*ScrollMenuHeight),ScrollBarY,1)
Else
y# = 200
LinesAmount%=0
Color 0,0,0
For chl.ChangeLogLines = Each ChangeLogLines
RowText2(chl\txt$,20,y#,432,254)
y# = y#+(20*GetLineAmount2(chl\txt$,432,254))
LinesAmount = LinesAmount + (GetLineAmount2(chl\txt$,432,254))
Next
ScrollMenuHeight# = LinesAmount
EndIf
Color 255,255,255
Rect(480, 200, 155, 95)
Color 0,0,0
RowText2("However, a manual download is required to update the game.",482,210,150,90)
SetFont Font1
If DrawButton(LauncherWidth - 30 - 90, LauncherHeight - 50 - 110, 100, 30, "TRY AGAIN", False, False, False)
Delete Each ChangeLogLines
If UpdaterIMG <> 0 Then FreeImage UpdaterIMG
CheckForUpdates()
Return
EndIf
If DrawButton(LauncherWidth - 55 - 90, LauncherHeight - 50 - 55, 145, 30, "VISIT WEBSITE", False, False, False)
ExecFile("http://scpcbgame.com")
Delay 100
End
EndIf
If DrawButton(LauncherWidth - 30 - 90, LauncherHeight - 50, 100, 30, "IGNORE", False, False, False)
Delay 100
Exit
EndIf
Else
SetFont UpdaterFont
If LinesAmount > 13
y# = 200-(20*ScrollMenuHeight*ScrollBarY)
LinesAmount%=0
SetBuffer(ImageBuffer(UpdaterIMG))
DrawImage UpdaterBG,-20,-195
For chl.ChangeLogLines = Each ChangeLogLines
Color 0,0,0
If Right(chl\txt$,6) = "v"+latest
Color 200,0,0
EndIf
RowText2(chl\txt$,2,y#-195,430,254)
y# = y#+(20*GetLineAmount2(chl\txt$,430,254))
LinesAmount = LinesAmount + (GetLineAmount2(chl\txt$,430,254))
Next
SetBuffer BackBuffer()
DrawImage UpdaterIMG,20,195
Color 10,10,10
Rect 452,195,20,254,True
ScrollMenuHeight# = LinesAmount-13
ScrollBarY = DrawScrollBar(452,195,20,254,452,195+(254-(254-4*ScrollMenuHeight))*ScrollBarY,20,254-(4*ScrollMenuHeight),ScrollBarY,1)
Else
y# = 200
LinesAmount%=0
Color 0,0,0
For chl.ChangeLogLines = Each ChangeLogLines
RowText2(chl\txt$,20,y#,432,254)
y# = y#+(20*GetLineAmount2(chl\txt$,432,254))
LinesAmount = LinesAmount + (GetLineAmount2(chl\txt$,432,254))
Next
ScrollMenuHeight# = LinesAmount
EndIf
Color 255,255,255
SetFont Font1
If DrawButton(LauncherWidth - 30 - 90, LauncherHeight - 50 - 55, 100, 30, "UPDATE", False, False, False)
ConfirmDownload=True
Cls
Color 255,255,255
Text 320,240,"Starting download...",True,True
Flip
Delay 100
Exit
EndIf
If DrawButton(LauncherWidth - 30 - 90, LauncherHeight - 50, 100, 30, "IGNORE", False, False, False)
Delay 100
Exit
EndIf
EndIf
Flip
Delay 8
Forever
EndIf
If ConfirmDownload Then
Local temp%
temp=Download(DownloadURL$,"updates\",latest+".zip",latest)
If temp>0 Then
If FileSize("updates\"+latest+".zip")<>0 Then
Local newRun$ = ""
Local zipIn = ZipApi_Open("updates\"+latest+".zip")
DebugLog zipIn
;Local temp%
temp = ZipApi_GotoFirstFile(zipIn)+"a"
;Repeat
While (Not temp)
SetBuffer(BackBuffer())
Cls
Color 255,255,255
Local fileData$ = ""
Local fileInfo.ZIPAPI_UnzFileInfo = ZipApi_GetCurrentFileInfo(zipIn)
If fileInfo<>Null Then
fileData$ = fileInfo\FileName
DebugLog fileData
ZIPAPI_UnzFileInfo_Dispose(fileInfo)
If (Right(fileData,1)<>"/") And (Right(fileData,1)<>"\") Then ;fileData refers to a file, not a directory
If Instr(fileData,"zlibwapi.dll")<>0 Then
Text 320,240,"Can't extract zlibwapi.dll",True,True
Else
Text 320,240,"Extracting "+Chr(34)+fileData+Chr(34),True,True
If Instr(fileData,".exe")=0 Or Instr(fileData,"Map Creator")=0
ZipApi_ExtractFile(zipIn, fileData, Replace(fileData,".exe"," "+latest+".exe"))
Else
ZipApi_ExtractFile(zipIn, fileData, fileData)
EndIf
EndIf
Else If FileType(fileData)=0
CreateDir fileData
EndIf
If Instr(fileData,".exe")>0 Then
newRun=Chr$(34)+"SCP - Containment Breach "+latest+".exe"+Chr$(34)
EndIf
EndIf
Flip
temp%=ZipApi_GotoNextFile(zipIn)
DebugLog temp
Wend
ZipApi_Close(zipIn)
PutINIValue(OptionFile,"updater","old_exe",StripPath(GetSelfEXEName()))
DebugLog GetSelfEXEName()
If newRun<>"" Then ;run the new executable
DebugLog "running "+newRun
ExecFile(newRun)
EndIf
End ;close the game
EndIf
ElseIf temp=-1 ;download cancelled by user
Delay 100
Return
Else
SetBuffer BackBuffer()
Cls
Color 255,255,255
Text 320,240,"An error has occurred while downloading the update.",True,True
Flip
Delay 1000
Return
EndIf
EndIf
Delete Each ChangeLogLines
If UpdaterIMG <> 0 Then FreeImage UpdaterIMG
End Function
Function GetSelfEXEName$() ;use this to make the new version delete the old exe
Local lpFileName% = CreateBank(256)
Local str_len% = api_GetModuleFileName(0,lpFileName,BankSize(lpFileName))
Local exe_name$=""
If str_len > 0 Then
For grab_exe_name = 0 To str_len-1
exe_name$ = exe_name + Chr(PeekByte(lpFileName,grab_exe_name))
Next
EndIf
FreeBank lpFileName
Return exe_name
End Function
;~IDEal Editor Parameters:
;~F#B#12#C4#D6#DE#E2#E8#EE#F4#110#11F#128#131#13A#144#14B#15C#165#173#18E
;~C#Blitz3D