| 1 | UNIT Unit10_leveldb; | 
 
 
 
 
 | 2 | INTERFACE | 
 
 
 
 
 | 3 | USES | 
 
 
 
 
 | 4 | Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, | 
 
 
 
 
 | 5 | Dialogs, ComCtrls, StdCtrls, StrUtils; | 
 
 
 
 
 | 6 |  | 
 
 
 
 
 | 7 | TYPE | 
 
 
 
 
 | 8 | TForm10 = Class(TForm) | 
 
 
 
 
 | 9 | group_progress: TGroupBox; | 
 
 
 
 
 | 10 | progress: TProgressBar; | 
 
 
 
 
 | 11 | lbl_progress: TLabel; | 
 
 
 
 
 | 12 | btn_abortok: TButton; | 
 
 
 
 
 | 13 | lbl_estimation: TLabel; | 
 
 
 
 
 | 14 | PROCEDURE btn_abortokClick(Sender: TObject); | 
 
 
 
 
 | 15 | PRIVATE | 
 
 
 
 
 | 16 | PROCEDURE HandleFile(ext:String; fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 17 | PROCEDURE stop_convert; | 
 
 
 
 
 | 18 | PUBLIC | 
 
 
 
 
 | 19 | PROCEDURE CreateDatabase(source,target:String); | 
 
 
 
 
 | 20 | PROCEDURE CreateLevel(source,target:String); | 
 
 
 
 
 | 21 | END; | 
 
 
 
 
 | 22 |  | 
 
 
 
 
 | 23 |  | 
 
 
 
 
 | 24 | VAR | 
 
 
 
 
 | 25 | Form10: TForm10; | 
 
 
 
 
 | 26 |  | 
 
 
 
 
 | 27 | IMPLEMENTATION | 
 
 
 
 
 | 28 | {$R *.dfm} | 
 
 
 
 
 | 29 | USES ABSMain, ABSDecUtil, Unit1_main, Unit2_functions, Unit3_data, Unit9_data_structures, Unit15_Classes; | 
 
 
 
 
 | 30 |  | 
 
 
 
 
 | 31 | TYPE | 
 
 
 
 
 | 32 | THandler=PROCEDURE(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 33 | TConvertHandlers=RECORD | 
 
 
 
 
 | 34 | Ext:String[4]; | 
 
 
 
 
 | 35 | needed:Boolean; | 
 
 
 
 
 | 36 | Handler:THandler; | 
 
 
 
 
 | 37 | END; | 
 
 
 
 
 | 38 | VAR | 
 
 
 
 
 | 39 | ConvertHandlers:Array OF TConvertHandlers; | 
 
 
 
 
 | 40 | loaded_filename:String; | 
 
 
 
 
 | 41 | converting:Boolean=False; | 
 
 
 
 
 | 42 | abort:Boolean=False; | 
 
 
 
 
 | 43 | DataBase:TABSDatabase; | 
 
 
 
 
 | 44 | Query:TABSQuery; | 
 
 
 
 
 | 45 | MimeCoder: TStringFormat_MIME64; | 
 
 
 
 
 | 46 |  | 
 
 
 
 
 | 47 | PROCEDURE TForm10.HandleFile; | 
 
 
 
 
 | 48 | VAR | 
 
 
 
 
 | 49 | i:Byte; | 
 
 
 
 
 | 50 | BEGIN | 
 
 
 
 
 | 51 | FOR i:=1 TO Length(ConvertHandlers) DO | 
 
 
 
 
 | 52 | IF UpperCase(ConvertHandlers[i].Ext)=UpperCase(ext) THEN | 
 
 
 
 
 | 53 | IF ConvertHandlers[i].needed THEN BEGIN | 
 
 
 
 
 | 54 | ConvertHandlers[i].Handler(fileid, dir_dat2db); | 
 
 
 
 
 | 55 | Break; | 
 
 
 
 
 | 56 | END ELSE | 
 
 
 
 
 | 57 | Break; | 
 
 
 
 
 | 58 | END; | 
 
 
 
 
 | 59 |  | 
 
 
 
 
 | 60 | PROCEDURE TForm10.CreateLevel(source,target:String); | 
 
 
 
 
 | 61 | VAR | 
 
 
 
 
 | 62 | i:LongWord; | 
 
 
 
 
 | 63 | BEGIN | 
 
 
 
 
 | 64 | END; | 
 
 
 
 
 | 65 |  | 
 
 
 
 
 | 66 | PROCEDURE TForm10.CreateDatabase(source,target:String); | 
 
 
 
 
 | 67 | VAR | 
 
 
 
 
 | 68 | i,j:LongWord; | 
 
 
 
 
 | 69 | temps,temps2:String; | 
 
 
 
 
 | 70 | data:Tdata; | 
 
 
 
 
 | 71 | absolutebegintime,begintime:Double; | 
 
 
 
 
 | 72 | step:Byte; | 
 
 
 
 
 | 73 | rawlist:TRawList; | 
 
 
 
 
 | 74 | extlist:TExtensionsMap; | 
 
 
 
 
 | 75 | fileinfo:TFileInfo; | 
 
 
 
 
 | 76 | CONST | 
 
 
 
 
 | 77 | steps:Byte=4; | 
 
 
 
 
 | 78 | PROCEDURE DoStep(stepname:String); | 
 
 
 
 
 | 79 | BEGIN | 
 
 
 
 
 | 80 | Inc(step); | 
 
 
 
 
 | 81 | IF stepname<>'FIN' THEN | 
 
 
 
 
 | 82 | group_progress.Caption:='Creating DB (Step '+IntToStr(step)+'/'+IntToStr(steps)+': '+stepname+')' | 
 
 
 
 
 | 83 | ELSE | 
 
 
 
 
 | 84 | group_progress.Caption:='Creating DB (FINISHED)'; | 
 
 
 
 
 | 85 | END; | 
 
 
 
 
 | 86 | BEGIN | 
 
 
 
 
 | 87 | IF NOT CreateDataConnection(source,ODB_Dat) THEN BEGIN | 
 
 
 
 
 | 88 | ShowMessage('Could not connect to .dat-file'); | 
 
 
 
 
 | 89 | Exit; | 
 
 
 
 
 | 90 | END ELSE BEGIN | 
 
 
 
 
 | 91 | TOniDataDat(OniDataConnection).UnloadWhenUnused:=False; | 
 
 
 
 
 | 92 | END; | 
 
 
 
 
 | 93 |  | 
 
 
 
 
 | 94 | Form10.Visible:=True; | 
 
 
 
 
 | 95 | Form1.Visible:=False; | 
 
 
 
 
 | 96 | step:=0; | 
 
 
 
 
 | 97 | converting:=True; | 
 
 
 
 
 | 98 | abort:=False; | 
 
 
 
 
 | 99 | btn_abortok.Caption:='&Abort...'; | 
 
 
 
 
 | 100 | btn_abortok.Default:=False; | 
 
 
 
 
 | 101 | loaded_filename:=target; | 
 
 
 
 
 | 102 |  | 
 
 
 
 
 | 103 | absolutebegintime:=Time; | 
 
 
 
 
 | 104 |  | 
 
 
 
 
 | 105 | DataBase:=TABSDatabase.Create(Self); | 
 
 
 
 
 | 106 | DataBase.DatabaseName:='OLDB'; | 
 
 
 
 
 | 107 | DataBase.DatabaseFileName:=target; | 
 
 
 
 
 | 108 | DataBase.CreateDatabase; | 
 
 
 
 
 | 109 |  | 
 
 
 
 
 | 110 | DoStep('Creating tables'); | 
 
 
 
 
 | 111 | progress.Position:=0; | 
 
 
 
 
 | 112 | lbl_progress.Caption:=''; | 
 
 
 
 
 | 113 | lbl_estimation.Caption:='Estimated finishing time: unknown'; | 
 
 
 
 
 | 114 | Application.ProcessMessages; | 
 
 
 
 
 | 115 |  | 
 
 
 
 
 | 116 | Query:=TABSQuery.Create(Self); | 
 
 
 
 
 | 117 | Query.DatabaseName:='OLDB'; | 
 
 
 
 
 | 118 | Query.SQL.Text:='CREATE TABLE globals  ( id AUTOINC PRIMARY KEY, name STRING(128), value STRING(128) );'; | 
 
 
 
 
 | 119 | Query.ExecSQL; | 
 
 
 
 
 | 120 | Query.SQL.Text:='CREATE TABLE linkmap  ( id AUTOINC PRIMARY KEY, src_id INTEGER, src_link_offset INTEGER, target_id INTEGER );'; | 
 
 
 
 
 | 121 | Query.ExecSQL; | 
 
 
 
 
 | 122 | Query.SQL.Text:='CREATE TABLE rawmap  ( id AUTOINC PRIMARY KEY, src_id INTEGER, src_link_offset INTEGER, size INTEGER, data BLOB BlobCompressionMode 9 BlobBlockSize 1024 BlobCompressionAlgorithm ZLib );'; | 
 
 
 
 
 | 123 | //    Query.SQL.Text:='CREATE TABLE rawmap  ( id AUTOINC PRIMARY KEY, src_id INTEGER, src_link_offset INTEGER, size INTEGER, data BLOB BlobCompressionAlgorithm None );'; | 
 
 
 
 
 | 124 | Query.ExecSQL; | 
 
 
 
 
 | 125 | Query.SQL.Text:='CREATE TABLE datfiles  ( id INTEGER PRIMARY KEY, extension CHAR(4), name STRING(128), contenttype INTEGER, size INTEGER, data BLOB BlobCompressionMode 9 BlobBlockSize 1024 BlobCompressionAlgorithm ZLib );'; | 
 
 
 
 
 | 126 | //    Query.SQL.Text:='CREATE TABLE datfiles  ( id INTEGER PRIMARY KEY, extension CHAR(4), name STRING(128), contenttype INTEGER, size INTEGER, data BLOB BlobCompressionAlgorithm None );'; | 
 
 
 
 
 | 127 | Query.ExecSQL; | 
 
 
 
 
 | 128 | Query.SQL.Text:='CREATE TABLE extlist  ( id AUTOINC PRIMARY KEY, ext CHAR(4), ident CHAR(16) );'; | 
 
 
 
 
 | 129 | Query.ExecSQL; | 
 
 
 
 
 | 130 |  | 
 
 
 
 
 | 131 | Query.SQL.Text:='INSERT INTO globals (name,value) VALUES ("dbversion","'+dbversion+'");'; | 
 
 
 
 
 | 132 | Query.ExecSQL; | 
 
 
 
 
 | 133 | SetLength(data,Length(OniDataConnection.LevelInfo.Ident)); | 
 
 
 
 
 | 134 | FOR i:=0 TO High(OniDataConnection.LevelInfo.Ident) DO data[i]:=OniDataConnection.LevelInfo.Ident[i]; | 
 
 
 
 
 | 135 | temps:=CreateHexString(data,True); | 
 
 
 
 
 | 136 | Query.SQL.Text:='INSERT INTO globals (name,value) VALUES ("ident","'+temps+'");'; | 
 
 
 
 
 | 137 | Query.ExecSQL; | 
 
 
 
 
 | 138 | Query.SQL.Text:='INSERT INTO globals (name,value) VALUES ("lvl","'+IntToStr(OniDataConnection.LevelInfo.LevelNumber)+'");'; | 
 
 
 
 
 | 139 | Query.ExecSQL; | 
 
 
 
 
 | 140 | IF OniDataConnection.OSisMAC THEN | 
 
 
 
 
 | 141 | Query.SQL.Text:='INSERT INTO globals (name,value) VALUES ("os","MAC");' | 
 
 
 
 
 | 142 | ELSE | 
 
 
 
 
 | 143 | Query.SQL.Text:='INSERT INTO globals (name,value) VALUES ("os","PC");'; | 
 
 
 
 
 | 144 | Query.ExecSQL; | 
 
 
 
 
 | 145 |  | 
 
 
 
 
 | 146 | DoStep('Writing extensionslist'); | 
 
 
 
 
 | 147 | progress.Max:=Length(OniDataConnection.GetExtensionsList); | 
 
 
 
 
 | 148 | Application.ProcessMessages; | 
 
 
 
 
 | 149 |  | 
 
 
 
 
 | 150 | extlist:=OniDataConnection.GetExtendedExtensionsList; | 
 
 
 
 
 | 151 | FOR i:=0 TO High(extlist) DO BEGIN | 
 
 
 
 
 | 152 | SetLength(data,Length(extlist[i].Ident)); | 
 
 
 
 
 | 153 | FOR j:=0 TO High(extlist[i].Ident) DO data[j]:=extlist[i].Ident[j]; | 
 
 
 
 
 | 154 | temps:=CreateHexString(data,True); | 
 
 
 
 
 | 155 | temps2:=extlist[i].Extension[3]+extlist[i].Extension[2]+extlist[i].Extension[1]+extlist[i].Extension[0]; | 
 
 
 
 
 | 156 | Query.SQL.Text:='INSERT INTO extlist (ext,ident) VALUES ("'+temps2+'","'+temps+'");'; | 
 
 
 
 
 | 157 | Query.ExecSQL; | 
 
 
 
 
 | 158 | progress.Position:=i; | 
 
 
 
 
 | 159 | lbl_progress.Caption:='Extensions done: '+IntToStr(i)+'/'+IntToStr(Length(extlist)); | 
 
 
 
 
 | 160 | Application.ProcessMessages; | 
 
 
 
 
 | 161 | IF abort THEN BEGIN | 
 
 
 
 
 | 162 | stop_convert; | 
 
 
 
 
 | 163 | Exit; | 
 
 
 
 
 | 164 | END; | 
 
 
 
 
 | 165 | END; | 
 
 
 
 
 | 166 | lbl_progress.Caption:=''; | 
 
 
 
 
 | 167 |  | 
 
 
 
 
 | 168 | progress.Position:=0; | 
 
 
 
 
 | 169 | lbl_progress.Caption:='Files done: '+IntToStr(0)+'/'+IntToStr(OniDataConnection.GetFilesCount); | 
 
 
 
 
 | 170 | lbl_estimation.Caption:='Estimated finishing time: unknown'; | 
 
 
 
 
 | 171 |  | 
 
 
 
 
 | 172 | DoStep('Loading .dat into memory'); | 
 
 
 
 
 | 173 | Application.ProcessMessages; | 
 
 
 
 
 | 174 |  | 
 
 
 
 
 | 175 | progress.Max:=OniDataConnection.GetFilesCount; | 
 
 
 
 
 | 176 | begintime:=Time; | 
 
 
 
 
 | 177 | DoStep('Writing .dat-fileslist'); | 
 
 
 
 
 | 178 | Application.ProcessMessages; | 
 
 
 
 
 | 179 |  | 
 
 
 
 
 | 180 | Database.StartTransaction; | 
 
 
 
 
 | 181 | FOR i:=0 TO OniDataConnection.GetFilesCount-1 DO BEGIN | 
 
 
 
 
 | 182 | fileinfo:=OniDataConnection.GetFileInfo(i); | 
 
 
 
 
 | 183 | IF (fileinfo.FileType AND $02)=0 THEN BEGIN | 
 
 
 
 
 | 184 | mimecoder:=TStringFormat_MIME64.Create; | 
 
 
 
 
 | 185 | data:=OniDataConnection.LoadDatFile(i); | 
 
 
 
 
 | 186 | Query.SQL.Text:='INSERT INTO datfiles (id,extension,name,contenttype,size,data) VALUES ('+IntToStr(i)+',"'+fileinfo.Extension+'","'+fileinfo.Name+'","'+IntToHex(fileinfo.FileType,8)+'",'+IntToStr(fileinfo.Size)+',MimeToBin("'+MimeCoder.StrTo(@data[0], Length(data))+'") );'; | 
 
 
 
 
 | 187 | Query.ExecSQL; | 
 
 
 
 
 | 188 | mimecoder.Free; | 
 
 
 
 
 | 189 |  | 
 
 
 
 
 | 190 | rawlist:=OniDataConnection.GetRawList(i); | 
 
 
 
 
 | 191 | IF Length(rawlist)>0 THEN BEGIN | 
 
 
 
 
 | 192 | FOR j:=0 TO High(rawlist) DO BEGIN | 
 
 
 
 
 | 193 | IF rawlist[j].raw_size>0 THEN BEGIN | 
 
 
 
 
 | 194 | SetLength(data, rawlist[j].raw_size); | 
 
 
 
 
 | 195 | OniDataConnection.LoadRawFile(i,rawlist[j].src_offset,data); | 
 
 
 
 
 | 196 | mimecoder:=TStringFormat_MIME64.Create; | 
 
 
 
 
 | 197 | Query.SQL.Text:='INSERT INTO rawmap (src_id,src_link_offset,size,data) VALUES ('+IntToStr(i)+','+IntToStr(rawlist[j].src_offset)+','+IntToStr(rawlist[j].raw_size)+',MimeToBin("'+MimeCoder.StrTo(@data[0], rawlist[j].raw_size)+'") );'; | 
 
 
 
 
 | 198 | Query.ExecSQL; | 
 
 
 
 
 | 199 | mimecoder.Free; | 
 
 
 
 
 | 200 | END ELSE BEGIN | 
 
 
 
 
 | 201 | Query.SQL.Text:='INSERT INTO rawmap (src_id,src_link_offset,size) VALUES ('+IntToStr(i)+','+IntToStr(rawlist[j].src_offset)+',0);'; | 
 
 
 
 
 | 202 | Query.ExecSQL; | 
 
 
 
 
 | 203 | END; | 
 
 
 
 
 | 204 | END; | 
 
 
 
 
 | 205 | END; | 
 
 
 
 
 | 206 |  | 
 
 
 
 
 | 207 | HandleFile(fileinfo.Extension,i,True); | 
 
 
 
 
 | 208 | END ELSE BEGIN | 
 
 
 
 
 | 209 | Query.SQL.Text:='INSERT INTO datfiles (id,extension,name,contenttype,size) VALUES ('+IntToStr(i)+',"'+fileinfo.Extension+'","'+fileinfo.Name+'","'+IntToHex(fileinfo.FileType,8)+'",0);'; | 
 
 
 
 
 | 210 | Query.ExecSQL; | 
 
 
 
 
 | 211 | END; | 
 
 
 
 
 | 212 | IF ( (i MOD 100)=0 ) AND (i>0) THEN BEGIN | 
 
 
 
 
 | 213 | Database.Commit(False); | 
 
 
 
 
 | 214 | Database.StartTransaction; | 
 
 
 
 
 | 215 | END; | 
 
 
 
 
 | 216 | IF ( (i MOD 25)=0 ) AND (i>=100) THEN | 
 
 
 
 
 | 217 | lbl_estimation.Caption:='Estimated finishing time: '+TimeToStr((Time-begintime)/i*progress.Max+begintime); | 
 
 
 
 
 | 218 | progress.Position:=i; | 
 
 
 
 
 | 219 | lbl_progress.Caption:='Files done: '+IntToStr(i)+'/'+IntToStr(progress.Max); | 
 
 
 
 
 | 220 | Application.ProcessMessages; | 
 
 
 
 
 | 221 | IF abort THEN BEGIN | 
 
 
 
 
 | 222 | stop_convert; | 
 
 
 
 
 | 223 | Exit; | 
 
 
 
 
 | 224 | END; | 
 
 
 
 
 | 225 | END; | 
 
 
 
 
 | 226 | Database.Commit(False); | 
 
 
 
 
 | 227 | progress.Position:=progress.Max; | 
 
 
 
 
 | 228 | lbl_progress.Caption:='Files done: '+IntToStr(progress.Max)+'/'+IntToStr(progress.Max); | 
 
 
 
 
 | 229 | lbl_estimation.Caption:='FINISHED (duration: '+TimeToStr(Time-absolutebegintime)+')'; | 
 
 
 
 
 | 230 |  | 
 
 
 
 
 | 231 | DoStep('FIN'); | 
 
 
 
 
 | 232 | btn_abortok.Caption:='&OK'; | 
 
 
 
 
 | 233 | btn_abortok.Default:=True; | 
 
 
 
 
 | 234 |  | 
 
 
 
 
 | 235 | converting:=False; | 
 
 
 
 
 | 236 |  | 
 
 
 
 
 | 237 | database.Close; | 
 
 
 
 
 | 238 | database.Free; | 
 
 
 
 
 | 239 |  | 
 
 
 
 
 | 240 | CloseDataConnection; | 
 
 
 
 
 | 241 | END; | 
 
 
 
 
 | 242 |  | 
 
 
 
 
 | 243 | PROCEDURE TForm10.stop_convert; | 
 
 
 
 
 | 244 | BEGIN | 
 
 
 
 
 | 245 | btn_abortok.Caption:='&Close'; | 
 
 
 
 
 | 246 | btn_abortok.Default:=True; | 
 
 
 
 
 | 247 | converting:=False; | 
 
 
 
 
 | 248 | lbl_estimation.Caption:='ABORTED'; | 
 
 
 
 
 | 249 | group_progress.Caption:='Creating DB (ABORTED)'; | 
 
 
 
 
 | 250 | DataBase.Close; | 
 
 
 
 
 | 251 | IF MessageBox(Self.Handle, PChar('Delete the unfinished DB-file?'), PChar('Delete file?'), MB_YESNO)=IDYES THEN BEGIN | 
 
 
 
 
 | 252 | DeleteFile(loaded_filename); | 
 
 
 
 
 | 253 | END; | 
 
 
 
 
 | 254 | END; | 
 
 
 
 
 | 255 |  | 
 
 
 
 
 | 256 | PROCEDURE TForm10.btn_abortokClick(Sender: TObject); | 
 
 
 
 
 | 257 | BEGIN | 
 
 
 
 
 | 258 | IF converting THEN BEGIN | 
 
 
 
 
 | 259 | IF MessageBox(Self.Handle, PChar('Do you really want to cancel the convert-progress?'), PChar('Warning: Converting'), MB_YESNO)=IDYES THEN | 
 
 
 
 
 | 260 | abort:=True; | 
 
 
 
 
 | 261 | END ELSE BEGIN | 
 
 
 
 
 | 262 | Form10.Visible:=False; | 
 
 
 
 
 | 263 | Form1.Visible:=True; | 
 
 
 
 
 | 264 | END; | 
 
 
 
 
 | 265 | END; | 
 
 
 
 
 | 266 |  | 
 
 
 
 
 | 267 | PROCEDURE InsertDatLinkToDB(fileid:LongWord; offset:LongWord); | 
 
 
 
 
 | 268 | VAR | 
 
 
 
 
 | 269 | link:LongWord; | 
 
 
 
 
 | 270 | BEGIN | 
 
 
 
 
 | 271 | OniDataConnection.LoadDatFilePart(fileid,offset,4,@link); | 
 
 
 
 
 | 272 | IF link=0 THEN | 
 
 
 
 
 | 273 | link:=$FFFFFFFF | 
 
 
 
 
 | 274 | ELSE | 
 
 
 
 
 | 275 | link:=link DIV 256; | 
 
 
 
 
 | 276 | Query.SQL.Text:='INSERT INTO linkmap (src_id,src_link_offset,target_id) VALUES ('+IntToStr(fileid)+','+IntToStr(offset)+','+IntToStr(link)+');'; | 
 
 
 
 
 | 277 | Query.ExecSQL; | 
 
 
 
 
 | 278 | END; | 
 
 
 
 
 | 279 | (* | 
 
 
 
 
 | 280 | PROCEDURE InsertRawFileToDB(fileid:LongWord; src_offset,raw_addr,size:LongWord); | 
 
 
 
 
 | 281 | VAR | 
 
 
 
 
 | 282 | localmem:TMemoryStream; | 
 
 
 
 
 | 283 | //    temps:String; | 
 
 
 
 
 | 284 | BEGIN | 
 
 
 
 
 | 285 | IF size>0 THEN BEGIN | 
 
 
 
 
 | 286 | localmem:=TMemoryStream.Create; | 
 
 
 
 
 | 287 | filestream:=TFileStream.Create(raw_filename,fmOpenRead); | 
 
 
 
 
 | 288 | filestream.Seek(raw_addr,soFromBeginning); | 
 
 
 
 
 | 289 | localmem.CopyFrom(filestream,size); | 
 
 
 
 
 | 290 | filestream.Free; | 
 
 
 
 
 | 291 | mimecoder:=TStringFormat_MIME64.Create; | 
 
 
 
 
 | 292 | Query.SQL.Text:='INSERT INTO rawmap (src_id,src_link_offset,size,data) VALUES ('+IntToStr(fileid)+','+IntToStr(src_offset)+','+IntToStr(size)+',MimeToBin("'+MimeCoder.StrTo(localmem.Memory, localmem.Size)+'") );'; | 
 
 
 
 
 | 293 | Query.ExecSQL; | 
 
 
 
 
 | 294 | localmem.Free; | 
 
 
 
 
 | 295 | mimecoder.Free; | 
 
 
 
 
 | 296 | END ELSE BEGIN | 
 
 
 
 
 | 297 | Query.SQL.Text:='INSERT INTO rawmap (src_id,src_link_offset,size) VALUES ('+IntToStr(fileid)+','+IntToStr(src_offset)+',0);'; | 
 
 
 
 
 | 298 | Query.ExecSQL; | 
 
 
 
 
 | 299 | END; | 
 
 
 
 
 | 300 | {    IF (raw_addr MOD 32)>0 THEN BEGIN | 
 
 
 
 
 | 301 | temps:='FileID='+FormatNumber(fileid,5,'0')+' - dat-Offset=0x'+IntToHex(src_offset,8)+' - raw-address=0x'+IntToHex(raw_addr,8)+#13+#10; | 
 
 
 
 
 | 302 | filestream:=TFileStream.Create('D:\not32.txt',fmOpenReadWrite); | 
 
 
 
 
 | 303 | filestream.Seek(0,soFromEnd); | 
 
 
 
 
 | 304 | filestream.Write(temps[1],Length(temps)); | 
 
 
 
 
 | 305 | filestream.Free; | 
 
 
 
 
 | 306 | END; } | 
 
 
 
 
 | 307 | END; | 
 
 
 
 
 | 308 | *) | 
 
 
 
 
 | 309 |  | 
 
 
 
 
 | 310 |  | 
 
 
 
 
 | 311 | PROCEDURE AKEV(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 312 | VAR | 
 
 
 
 
 | 313 | i:LongWord; | 
 
 
 
 
 | 314 | BEGIN | 
 
 
 
 
 | 315 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 316 | FOR i:=0 TO 16 DO InsertDatLinkToDB(fileid,$8+i*4); | 
 
 
 
 
 | 317 | END ELSE BEGIN | 
 
 
 
 
 | 318 | END; | 
 
 
 
 
 | 319 | END; | 
 
 
 
 
 | 320 | PROCEDURE AKOT(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 321 | VAR | 
 
 
 
 
 | 322 | i:LongWord; | 
 
 
 
 
 | 323 | BEGIN | 
 
 
 
 
 | 324 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 325 | FOR i:=0 TO 4 DO InsertDatLinkToDB(fileid,$8+i*4); | 
 
 
 
 
 | 326 | END ELSE BEGIN | 
 
 
 
 
 | 327 | END; | 
 
 
 
 
 | 328 | END; | 
 
 
 
 
 | 329 | PROCEDURE CBPI(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 330 | VAR | 
 
 
 
 
 | 331 | i:LongWord; | 
 
 
 
 
 | 332 | BEGIN | 
 
 
 
 
 | 333 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 334 | FOR i:=0 TO 56 DO InsertDatLinkToDB(fileid,$8+i*4); | 
 
 
 
 
 | 335 | END ELSE BEGIN | 
 
 
 
 
 | 336 | END; | 
 
 
 
 
 | 337 | END; | 
 
 
 
 
 | 338 | PROCEDURE CBPM(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 339 | VAR | 
 
 
 
 
 | 340 | i:LongWord; | 
 
 
 
 
 | 341 | BEGIN | 
 
 
 
 
 | 342 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 343 | FOR i:=0 TO 18 DO InsertDatLinkToDB(fileid,$8+i*4); | 
 
 
 
 
 | 344 | END ELSE BEGIN | 
 
 
 
 
 | 345 | END; | 
 
 
 
 
 | 346 | END; | 
 
 
 
 
 | 347 | PROCEDURE CONS(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 348 | VAR | 
 
 
 
 
 | 349 | i:LongWord; | 
 
 
 
 
 | 350 | BEGIN | 
 
 
 
 
 | 351 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 352 | FOR i:=0 TO 1 DO InsertDatLinkToDB(fileid,$24+i*4); | 
 
 
 
 
 | 353 | END ELSE BEGIN | 
 
 
 
 
 | 354 | END; | 
 
 
 
 
 | 355 | END; | 
 
 
 
 
 | 356 | PROCEDURE CRSA(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 357 | VAR | 
 
 
 
 
 | 358 | packages:LongWord; | 
 
 
 
 
 | 359 | i:LongWord; | 
 
 
 
 
 | 360 | BEGIN | 
 
 
 
 
 | 361 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 362 | OniDataConnection.LoadDatFilePart(fileid,$14,4,@packages); | 
 
 
 
 
 | 363 | IF packages>0 THEN | 
 
 
 
 
 | 364 | FOR i:=0 TO packages-1 DO InsertDatLinkToDB(fileid,$20+i*1100+$A0); | 
 
 
 
 
 | 365 | END ELSE BEGIN | 
 
 
 
 
 | 366 | END; | 
 
 
 
 
 | 367 | END; | 
 
 
 
 
 | 368 | PROCEDURE DOOR(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 369 | BEGIN | 
 
 
 
 
 | 370 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 371 | InsertDatLinkToDB(fileid,$08); | 
 
 
 
 
 | 372 | InsertDatLinkToDB(fileid,$10); | 
 
 
 
 
 | 373 | END ELSE BEGIN | 
 
 
 
 
 | 374 | END; | 
 
 
 
 
 | 375 | END; | 
 
 
 
 
 | 376 | PROCEDURE DPGE(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 377 | BEGIN | 
 
 
 
 
 | 378 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 379 | InsertDatLinkToDB(fileid,$40); | 
 
 
 
 
 | 380 | END ELSE BEGIN | 
 
 
 
 
 | 381 | END; | 
 
 
 
 
 | 382 | END; | 
 
 
 
 
 | 383 | PROCEDURE HPGE(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 384 | BEGIN | 
 
 
 
 
 | 385 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 386 | InsertDatLinkToDB(fileid,$0C); | 
 
 
 
 
 | 387 | END ELSE BEGIN | 
 
 
 
 
 | 388 | END; | 
 
 
 
 
 | 389 | END; | 
 
 
 
 
 | 390 | PROCEDURE IGHH(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 391 | BEGIN | 
 
 
 
 
 | 392 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 393 | InsertDatLinkToDB(fileid,$24); | 
 
 
 
 
 | 394 | InsertDatLinkToDB(fileid,$28); | 
 
 
 
 
 | 395 | END ELSE BEGIN | 
 
 
 
 
 | 396 | END; | 
 
 
 
 
 | 397 | END; | 
 
 
 
 
 | 398 | PROCEDURE IGPA(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 399 | VAR | 
 
 
 
 
 | 400 | links:LongWord; | 
 
 
 
 
 | 401 | i:LongWord; | 
 
 
 
 
 | 402 | BEGIN | 
 
 
 
 
 | 403 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 404 | OniDataConnection.LoadDatFilePart(fileid,$1C,4,@links); | 
 
 
 
 
 | 405 | IF links>0 THEN | 
 
 
 
 
 | 406 | FOR i:=0 TO links-1 DO InsertDatLinkToDB(fileid,$20+i*4); | 
 
 
 
 
 | 407 | END ELSE BEGIN | 
 
 
 
 
 | 408 | END; | 
 
 
 
 
 | 409 | END; | 
 
 
 
 
 | 410 | PROCEDURE IGPG(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 411 | VAR | 
 
 
 
 
 | 412 | i:LongWord; | 
 
 
 
 
 | 413 | BEGIN | 
 
 
 
 
 | 414 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 415 | FOR i:=0 TO 1 DO InsertDatLinkToDB(fileid,$1C+i*4); | 
 
 
 
 
 | 416 | END ELSE BEGIN | 
 
 
 
 
 | 417 | END; | 
 
 
 
 
 | 418 | END; | 
 
 
 
 
 | 419 | PROCEDURE IGSA(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 420 | VAR | 
 
 
 
 
 | 421 | links:LongWord; | 
 
 
 
 
 | 422 | i:LongWord; | 
 
 
 
 
 | 423 | BEGIN | 
 
 
 
 
 | 424 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 425 | OniDataConnection.LoadDatFilePart(fileid,$1C,4,@links); | 
 
 
 
 
 | 426 | IF links>0 THEN | 
 
 
 
 
 | 427 | FOR i:=0 TO links-1 DO InsertDatLinkToDB(fileid,$20+i*4); | 
 
 
 
 
 | 428 | END ELSE BEGIN | 
 
 
 
 
 | 429 | END; | 
 
 
 
 
 | 430 | END; | 
 
 
 
 
 | 431 | PROCEDURE IMPT(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 432 | BEGIN | 
 
 
 
 
 | 433 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 434 | InsertDatLinkToDB(fileid,$10); | 
 
 
 
 
 | 435 | END ELSE BEGIN | 
 
 
 
 
 | 436 | END; | 
 
 
 
 
 | 437 | END; | 
 
 
 
 
 | 438 | PROCEDURE IPGE(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 439 | BEGIN | 
 
 
 
 
 | 440 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 441 | InsertDatLinkToDB(fileid,$0C); | 
 
 
 
 
 | 442 | END ELSE BEGIN | 
 
 
 
 
 | 443 | END; | 
 
 
 
 
 | 444 | END; | 
 
 
 
 
 | 445 | PROCEDURE KEYI(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 446 | VAR | 
 
 
 
 
 | 447 | i:LongWord; | 
 
 
 
 
 | 448 | BEGIN | 
 
 
 
 
 | 449 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 450 | FOR i:=0 TO 9 DO InsertDatLinkToDB(fileid,$08+i*4); | 
 
 
 
 
 | 451 | END ELSE BEGIN | 
 
 
 
 
 | 452 | END; | 
 
 
 
 
 | 453 | END; | 
 
 
 
 
 | 454 | PROCEDURE M3GA(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 455 | VAR | 
 
 
 
 
 | 456 | links:LongWord; | 
 
 
 
 
 | 457 | i:LongWord; | 
 
 
 
 
 | 458 | BEGIN | 
 
 
 
 
 | 459 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 460 | OniDataConnection.LoadDatFilePart(fileid,$1C,4,@links); | 
 
 
 
 
 | 461 | IF links>0 THEN | 
 
 
 
 
 | 462 | FOR i:=0 TO links-1 DO InsertDatLinkToDB(fileid,$20+i*4); | 
 
 
 
 
 | 463 | END ELSE BEGIN | 
 
 
 
 
 | 464 | END; | 
 
 
 
 
 | 465 | END; | 
 
 
 
 
 | 466 | PROCEDURE M3GM(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 467 | VAR | 
 
 
 
 
 | 468 | i:LongWord; | 
 
 
 
 
 | 469 | BEGIN | 
 
 
 
 
 | 470 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 471 | FOR i:=0 TO 6 DO InsertDatLinkToDB(fileid,$0C+i*4); | 
 
 
 
 
 | 472 | END ELSE BEGIN | 
 
 
 
 
 | 473 | END; | 
 
 
 
 
 | 474 | END; | 
 
 
 
 
 | 475 | PROCEDURE MTRL(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 476 | BEGIN | 
 
 
 
 
 | 477 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 478 | InsertDatLinkToDB(fileid,$10); | 
 
 
 
 
 | 479 | END ELSE BEGIN | 
 
 
 
 
 | 480 | END; | 
 
 
 
 
 | 481 | END; | 
 
 
 
 
 | 482 | PROCEDURE OBOA(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 483 | VAR | 
 
 
 
 
 | 484 | packages:Word; | 
 
 
 
 
 | 485 | i:LongWord; | 
 
 
 
 
 | 486 | BEGIN | 
 
 
 
 
 | 487 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 488 | OniDataConnection.LoadDatFilePart(fileid,$1E,2,@packages); | 
 
 
 
 
 | 489 | IF packages>0 THEN | 
 
 
 
 
 | 490 | FOR i:=0 TO packages-1 DO InsertDatLinkToDB(fileid,$20+i*240); | 
 
 
 
 
 | 491 | END ELSE BEGIN | 
 
 
 
 
 | 492 | END; | 
 
 
 
 
 | 493 | END; | 
 
 
 
 
 | 494 | PROCEDURE OFGA(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 495 | VAR | 
 
 
 
 
 | 496 | packages:LongWord; | 
 
 
 
 
 | 497 | i:LongWord; | 
 
 
 
 
 | 498 | BEGIN | 
 
 
 
 
 | 499 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 500 | OniDataConnection.LoadDatFilePart(fileid,$1C,4,@packages); | 
 
 
 
 
 | 501 | IF packages>0 THEN | 
 
 
 
 
 | 502 | FOR i:=0 TO packages-1 DO InsertDatLinkToDB(fileid,$20+i*12+$04); | 
 
 
 
 
 | 503 | END ELSE BEGIN | 
 
 
 
 
 | 504 | END; | 
 
 
 
 
 | 505 | END; | 
 
 
 
 
 | 506 | PROCEDURE ONCC(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 507 | VAR | 
 
 
 
 
 | 508 | i:LongWord; | 
 
 
 
 
 | 509 | BEGIN | 
 
 
 
 
 | 510 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 511 | END ELSE BEGIN | 
 
 
 
 
 | 512 | END; | 
 
 
 
 
 | 513 | END; | 
 
 
 
 
 | 514 | PROCEDURE ONCV(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 515 | BEGIN | 
 
 
 
 
 | 516 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 517 | InsertDatLinkToDB(fileid,$08); | 
 
 
 
 
 | 518 | END ELSE BEGIN | 
 
 
 
 
 | 519 | END; | 
 
 
 
 
 | 520 | END; | 
 
 
 
 
 | 521 | PROCEDURE ONLV(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 522 | VAR | 
 
 
 
 
 | 523 | i:LongWord; | 
 
 
 
 
 | 524 | BEGIN | 
 
 
 
 
 | 525 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 526 | FOR i:=0 TO 5 DO InsertDatLinkToDB(fileid,$48+i*4); | 
 
 
 
 
 | 527 | FOR i:=0 TO 5 DO InsertDatLinkToDB(fileid,$64+i*4); | 
 
 
 
 
 | 528 | InsertDatLinkToDB(fileid,$300); | 
 
 
 
 
 | 529 | END ELSE BEGIN | 
 
 
 
 
 | 530 | END; | 
 
 
 
 
 | 531 | END; | 
 
 
 
 
 | 532 | PROCEDURE ONOA(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 533 | VAR | 
 
 
 
 
 | 534 | packages:LongWord; | 
 
 
 
 
 | 535 | i:LongWord; | 
 
 
 
 
 | 536 | BEGIN | 
 
 
 
 
 | 537 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 538 | OniDataConnection.LoadDatFilePart(fileid,$1C,4,@packages); | 
 
 
 
 
 | 539 | IF packages>0 THEN | 
 
 
 
 
 | 540 | FOR i:=0 TO packages-1 DO InsertDatLinkToDB(fileid,$20+i*8+$04); | 
 
 
 
 
 | 541 | END ELSE BEGIN | 
 
 
 
 
 | 542 | END; | 
 
 
 
 
 | 543 | END; | 
 
 
 
 
 | 544 | PROCEDURE ONSK(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 545 | BEGIN | 
 
 
 
 
 | 546 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 547 | InsertDatLinkToDB(fileid,$08); | 
 
 
 
 
 | 548 | InsertDatLinkToDB(fileid,$0C); | 
 
 
 
 
 | 549 | InsertDatLinkToDB(fileid,$10); | 
 
 
 
 
 | 550 | InsertDatLinkToDB(fileid,$14); | 
 
 
 
 
 | 551 | InsertDatLinkToDB(fileid,$18); | 
 
 
 
 
 | 552 | InsertDatLinkToDB(fileid,$20); | 
 
 
 
 
 | 553 | InsertDatLinkToDB(fileid,$44); | 
 
 
 
 
 | 554 | END ELSE BEGIN | 
 
 
 
 
 | 555 | END; | 
 
 
 
 
 | 556 | END; | 
 
 
 
 
 | 557 | PROCEDURE ONVL(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 558 | VAR | 
 
 
 
 
 | 559 | packages:LongWord; | 
 
 
 
 
 | 560 | i:LongWord; | 
 
 
 
 
 | 561 | BEGIN | 
 
 
 
 
 | 562 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 563 | OniDataConnection.LoadDatFilePart(fileid,$1C,4,@packages); | 
 
 
 
 
 | 564 | IF packages>0 THEN | 
 
 
 
 
 | 565 | FOR i:=0 TO packages-1 DO InsertDatLinkToDB(fileid,$20+i*4); | 
 
 
 
 
 | 566 | END ELSE BEGIN | 
 
 
 
 
 | 567 | END; | 
 
 
 
 
 | 568 | END; | 
 
 
 
 
 | 569 | PROCEDURE ONWC(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 570 | BEGIN | 
 
 
 
 
 | 571 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 572 | InsertDatLinkToDB(fileid,$28); | 
 
 
 
 
 | 573 | InsertDatLinkToDB(fileid,$34); | 
 
 
 
 
 | 574 | InsertDatLinkToDB(fileid,$54); | 
 
 
 
 
 | 575 | InsertDatLinkToDB(fileid,$58); | 
 
 
 
 
 | 576 | InsertDatLinkToDB(fileid,$5C); | 
 
 
 
 
 | 577 | InsertDatLinkToDB(fileid,$60); | 
 
 
 
 
 | 578 | InsertDatLinkToDB(fileid,$6FC); | 
 
 
 
 
 | 579 | InsertDatLinkToDB(fileid,$700); | 
 
 
 
 
 | 580 | END ELSE BEGIN | 
 
 
 
 
 | 581 | END; | 
 
 
 
 
 | 582 | END; | 
 
 
 
 
 | 583 | PROCEDURE OPGE(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 584 | BEGIN | 
 
 
 
 
 | 585 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 586 | InsertDatLinkToDB(fileid,$1C); | 
 
 
 
 
 | 587 | END ELSE BEGIN | 
 
 
 
 
 | 588 | END; | 
 
 
 
 
 | 589 | END; | 
 
 
 
 
 | 590 | PROCEDURE PSPC(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 591 | BEGIN | 
 
 
 
 
 | 592 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 593 | InsertDatLinkToDB(fileid,$50); | 
 
 
 
 
 | 594 | END ELSE BEGIN | 
 
 
 
 
 | 595 | END; | 
 
 
 
 
 | 596 | END; | 
 
 
 
 
 | 597 | PROCEDURE PSPL(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 598 | VAR | 
 
 
 
 
 | 599 | packages:LongWord; | 
 
 
 
 
 | 600 | i:LongWord; | 
 
 
 
 
 | 601 | BEGIN | 
 
 
 
 
 | 602 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 603 | OniDataConnection.LoadDatFilePart(fileid,$1C,4,@packages); | 
 
 
 
 
 | 604 | IF packages>0 THEN | 
 
 
 
 
 | 605 | FOR i:=0 TO packages-1 DO InsertDatLinkToDB(fileid,$24+i*8); | 
 
 
 
 
 | 606 | END ELSE BEGIN | 
 
 
 
 
 | 607 | END; | 
 
 
 
 
 | 608 | END; | 
 
 
 
 
 | 609 | PROCEDURE PSUI(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 610 | VAR | 
 
 
 
 
 | 611 | i:LongWord; | 
 
 
 
 
 | 612 | BEGIN | 
 
 
 
 
 | 613 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 614 | FOR i:=0 TO 43 DO InsertDatLinkToDB(fileid,$08+i*4); | 
 
 
 
 
 | 615 | END ELSE BEGIN | 
 
 
 
 
 | 616 | END; | 
 
 
 
 
 | 617 | END; | 
 
 
 
 
 | 618 | PROCEDURE STNA(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 619 | VAR | 
 
 
 
 
 | 620 | packages:Word; | 
 
 
 
 
 | 621 | i:LongWord; | 
 
 
 
 
 | 622 | BEGIN | 
 
 
 
 
 | 623 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 624 | OniDataConnection.LoadDatFilePart(fileid,$1E,2,@packages); | 
 
 
 
 
 | 625 | IF packages>0 THEN | 
 
 
 
 
 | 626 | FOR i:=0 TO packages-1 DO InsertDatLinkToDB(fileid,$20+i*4); | 
 
 
 
 
 | 627 | END ELSE BEGIN | 
 
 
 
 
 | 628 | END; | 
 
 
 
 
 | 629 | END; | 
 
 
 
 
 | 630 | PROCEDURE TRAC(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 631 | VAR | 
 
 
 
 
 | 632 | packages:Word; | 
 
 
 
 
 | 633 | i:LongWord; | 
 
 
 
 
 | 634 | BEGIN | 
 
 
 
 
 | 635 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 636 | InsertDatLinkToDB(fileid,$18); | 
 
 
 
 
 | 637 | OniDataConnection.LoadDatFilePart(fileid,$1E,2,@packages); | 
 
 
 
 
 | 638 | IF packages>0 THEN | 
 
 
 
 
 | 639 | FOR i:=0 TO packages-1 DO InsertDatLinkToDB(fileid,$20+i*12+8); | 
 
 
 
 
 | 640 | END ELSE BEGIN | 
 
 
 
 
 | 641 | END; | 
 
 
 
 
 | 642 | END; | 
 
 
 
 
 | 643 | PROCEDURE TRAM(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 644 | BEGIN | 
 
 
 
 
 | 645 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 646 | InsertDatLinkToDB(fileid,$40); | 
 
 
 
 
 | 647 | InsertDatLinkToDB(fileid,$44); | 
 
 
 
 
 | 648 | END ELSE BEGIN | 
 
 
 
 
 | 649 | END; | 
 
 
 
 
 | 650 | END; | 
 
 
 
 
 | 651 | PROCEDURE TRAS(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 652 | BEGIN | 
 
 
 
 
 | 653 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 654 | InsertDatLinkToDB(fileid,$08); | 
 
 
 
 
 | 655 | END ELSE BEGIN | 
 
 
 
 
 | 656 | END; | 
 
 
 
 
 | 657 | END; | 
 
 
 
 
 | 658 | PROCEDURE TRBS(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 659 | VAR | 
 
 
 
 
 | 660 | i:LongWord; | 
 
 
 
 
 | 661 | BEGIN | 
 
 
 
 
 | 662 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 663 | FOR i:=0 TO 4 DO InsertDatLinkToDB(fileid,$08+i*4); | 
 
 
 
 
 | 664 | END ELSE BEGIN | 
 
 
 
 
 | 665 | END; | 
 
 
 
 
 | 666 | END; | 
 
 
 
 
 | 667 | PROCEDURE TRCM(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 668 | VAR | 
 
 
 
 
 | 669 | i:LongWord; | 
 
 
 
 
 | 670 | BEGIN | 
 
 
 
 
 | 671 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 672 | FOR i:=0 TO 2 DO InsertDatLinkToDB(fileid,$5C+i*4); | 
 
 
 
 
 | 673 | END ELSE BEGIN | 
 
 
 
 
 | 674 | END; | 
 
 
 
 
 | 675 | END; | 
 
 
 
 
 | 676 | PROCEDURE TRGA(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 677 | VAR | 
 
 
 
 
 | 678 | i:LongWord; | 
 
 
 
 
 | 679 | packages:Word; | 
 
 
 
 
 | 680 | BEGIN | 
 
 
 
 
 | 681 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 682 | OniDataConnection.LoadDatFilePart(fileid,$1E,2,@packages); | 
 
 
 
 
 | 683 | IF packages>0 THEN | 
 
 
 
 
 | 684 | FOR i:=0 TO packages-1 DO InsertDatLinkToDB(fileid,$20+i*4); | 
 
 
 
 
 | 685 | END ELSE BEGIN | 
 
 
 
 
 | 686 | END; | 
 
 
 
 
 | 687 | END; | 
 
 
 
 
 | 688 | PROCEDURE TRGE(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 689 | BEGIN | 
 
 
 
 
 | 690 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 691 | InsertDatLinkToDB(fileid,$20); | 
 
 
 
 
 | 692 | END ELSE BEGIN | 
 
 
 
 
 | 693 | END; | 
 
 
 
 
 | 694 | END; | 
 
 
 
 
 | 695 | PROCEDURE TRIG(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 696 | BEGIN | 
 
 
 
 
 | 697 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 698 | InsertDatLinkToDB(fileid,$18); | 
 
 
 
 
 | 699 | InsertDatLinkToDB(fileid,$24); | 
 
 
 
 
 | 700 | InsertDatLinkToDB(fileid,$28); | 
 
 
 
 
 | 701 | END ELSE BEGIN | 
 
 
 
 
 | 702 | END; | 
 
 
 
 
 | 703 | END; | 
 
 
 
 
 | 704 | PROCEDURE TRMA(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 705 | VAR | 
 
 
 
 
 | 706 | i:LongWord; | 
 
 
 
 
 | 707 | packages:Word; | 
 
 
 
 
 | 708 | BEGIN | 
 
 
 
 
 | 709 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 710 | OniDataConnection.LoadDatFilePart(fileid,$1E,2,@packages); | 
 
 
 
 
 | 711 | IF packages>0 THEN | 
 
 
 
 
 | 712 | FOR i:=0 TO packages-1 DO InsertDatLinkToDB(fileid,$20+i*4); | 
 
 
 
 
 | 713 | END ELSE BEGIN | 
 
 
 
 
 | 714 | END; | 
 
 
 
 
 | 715 | END; | 
 
 
 
 
 | 716 | PROCEDURE TRSC(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 717 | VAR | 
 
 
 
 
 | 718 | i:LongWord; | 
 
 
 
 
 | 719 | packages:Word; | 
 
 
 
 
 | 720 | BEGIN | 
 
 
 
 
 | 721 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 722 | OniDataConnection.LoadDatFilePart(fileid,$1E,2,@packages); | 
 
 
 
 
 | 723 | IF packages>0 THEN | 
 
 
 
 
 | 724 | FOR i:=0 TO packages-1 DO InsertDatLinkToDB(fileid,$20+i*4); | 
 
 
 
 
 | 725 | END ELSE BEGIN | 
 
 
 
 
 | 726 | END; | 
 
 
 
 
 | 727 | END; | 
 
 
 
 
 | 728 | PROCEDURE TSFF(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 729 | VAR | 
 
 
 
 
 | 730 | i:LongWord; | 
 
 
 
 
 | 731 | packages:LongWord; | 
 
 
 
 
 | 732 | BEGIN | 
 
 
 
 
 | 733 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 734 | OniDataConnection.LoadDatFilePart(fileid,$1C,4,@packages); | 
 
 
 
 
 | 735 | IF packages>0 THEN | 
 
 
 
 
 | 736 | FOR i:=0 TO packages-1 DO InsertDatLinkToDB(fileid,$20+i*4); | 
 
 
 
 
 | 737 | END ELSE BEGIN | 
 
 
 
 
 | 738 | END; | 
 
 
 
 
 | 739 | END; | 
 
 
 
 
 | 740 | PROCEDURE TSFT(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 741 | BEGIN | 
 
 
 
 
 | 742 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 743 | InsertDatLinkToDB(fileid,$1C); | 
 
 
 
 
 | 744 | END ELSE BEGIN | 
 
 
 
 
 | 745 | END; | 
 
 
 
 
 | 746 | END; | 
 
 
 
 
 | 747 | PROCEDURE TURR(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 748 | BEGIN | 
 
 
 
 
 | 749 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 750 | InsertDatLinkToDB(fileid,$60); | 
 
 
 
 
 | 751 | InsertDatLinkToDB(fileid,$6C); | 
 
 
 
 
 | 752 | InsertDatLinkToDB(fileid,$74); | 
 
 
 
 
 | 753 | END ELSE BEGIN | 
 
 
 
 
 | 754 | END; | 
 
 
 
 
 | 755 | END; | 
 
 
 
 
 | 756 | PROCEDURE TXAN(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 757 | VAR | 
 
 
 
 
 | 758 | i:LongWord; | 
 
 
 
 
 | 759 | packages:LongWord; | 
 
 
 
 
 | 760 | BEGIN | 
 
 
 
 
 | 761 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 762 | OniDataConnection.LoadDatFilePart(fileid,$1C,4,@packages); | 
 
 
 
 
 | 763 | IF packages>0 THEN | 
 
 
 
 
 | 764 | FOR i:=0 TO packages-1 DO InsertDatLinkToDB(fileid,$20+i*4); | 
 
 
 
 
 | 765 | END ELSE BEGIN | 
 
 
 
 
 | 766 | END; | 
 
 
 
 
 | 767 | END; | 
 
 
 
 
 | 768 | PROCEDURE TXMA(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 769 | VAR | 
 
 
 
 
 | 770 | i:LongWord; | 
 
 
 
 
 | 771 | packages:LongWord; | 
 
 
 
 
 | 772 | BEGIN | 
 
 
 
 
 | 773 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 774 | OniDataConnection.LoadDatFilePart(fileid,$1C,4,@packages); | 
 
 
 
 
 | 775 | IF packages>0 THEN | 
 
 
 
 
 | 776 | FOR i:=0 TO packages-1 DO InsertDatLinkToDB(fileid,$20+i*4); | 
 
 
 
 
 | 777 | END ELSE BEGIN | 
 
 
 
 
 | 778 | END; | 
 
 
 
 
 | 779 | END; | 
 
 
 
 
 | 780 | PROCEDURE TXMB(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 781 | VAR | 
 
 
 
 
 | 782 | i:LongWord; | 
 
 
 
 
 | 783 | packages:LongWord; | 
 
 
 
 
 | 784 | BEGIN | 
 
 
 
 
 | 785 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 786 | OniDataConnection.LoadDatFilePart(fileid,$1C,4,@packages); | 
 
 
 
 
 | 787 | IF packages>0 THEN | 
 
 
 
 
 | 788 | FOR i:=0 TO packages-1 DO InsertDatLinkToDB(fileid,$20+i*4); | 
 
 
 
 
 | 789 | END ELSE BEGIN | 
 
 
 
 
 | 790 | END; | 
 
 
 
 
 | 791 | END; | 
 
 
 
 
 | 792 | PROCEDURE TXMP(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 793 | BEGIN | 
 
 
 
 
 | 794 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 795 | InsertDatLinkToDB(fileid,$94); | 
 
 
 
 
 | 796 | InsertDatLinkToDB(fileid,$98); | 
 
 
 
 
 | 797 | END ELSE BEGIN | 
 
 
 
 
 | 798 | END; | 
 
 
 
 
 | 799 | END; | 
 
 
 
 
 | 800 | PROCEDURE TXTC(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 801 | BEGIN | 
 
 
 
 
 | 802 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 803 | InsertDatLinkToDB(fileid,$08); | 
 
 
 
 
 | 804 | END ELSE BEGIN | 
 
 
 
 
 | 805 | END; | 
 
 
 
 
 | 806 | END; | 
 
 
 
 
 | 807 | PROCEDURE WMCL(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 808 | BEGIN | 
 
 
 
 
 | 809 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 810 | InsertDatLinkToDB(fileid,$24); | 
 
 
 
 
 | 811 | END ELSE BEGIN | 
 
 
 
 
 | 812 | END; | 
 
 
 
 
 | 813 | END; | 
 
 
 
 
 | 814 | PROCEDURE WMMB(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 815 | VAR | 
 
 
 
 
 | 816 | i:LongWord; | 
 
 
 
 
 | 817 | packages:LongWord; | 
 
 
 
 
 | 818 | BEGIN | 
 
 
 
 
 | 819 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 820 | OniDataConnection.LoadDatFilePart(fileid,$1C,4,@packages); | 
 
 
 
 
 | 821 | IF packages>0 THEN | 
 
 
 
 
 | 822 | FOR i:=0 TO packages-1 DO InsertDatLinkToDB(fileid,$20+i*4); | 
 
 
 
 
 | 823 | END ELSE BEGIN | 
 
 
 
 
 | 824 | END; | 
 
 
 
 
 | 825 | END; | 
 
 
 
 
 | 826 | PROCEDURE WPGE(fileid:LongWord; dir_dat2db:Boolean); | 
 
 
 
 
 | 827 | BEGIN | 
 
 
 
 
 | 828 | IF dir_dat2db THEN BEGIN | 
 
 
 
 
 | 829 | InsertDatLinkToDB(fileid,$08); | 
 
 
 
 
 | 830 | InsertDatLinkToDB(fileid,$0C); | 
 
 
 
 
 | 831 | END ELSE BEGIN | 
 
 
 
 
 | 832 | END; | 
 
 
 
 
 | 833 | END; | 
 
 
 
 
 | 834 |  | 
 
 
 
 
 | 835 | PROCEDURE InsertHandler(ext:String; needed:Boolean; handler:THandler); | 
 
 
 
 
 | 836 | BEGIN | 
 
 
 
 
 | 837 | SetLength(ConvertHandlers,Length(ConvertHandlers)+1); | 
 
 
 
 
 | 838 | ConvertHandlers[High(ConvertHandlers)].Ext:=ext; | 
 
 
 
 
 | 839 | ConvertHandlers[High(ConvertHandlers)].needed:=needed; | 
 
 
 
 
 | 840 | ConvertHandlers[High(ConvertHandlers)].handler:=handler; | 
 
 
 
 
 | 841 | END; | 
 
 
 
 
 | 842 |  | 
 
 
 
 
 | 843 | BEGIN | 
 
 
 
 
 | 844 | InsertHandler('ABNA',False,NIL); | 
 
 
 
 
 | 845 | //  InsertHandler('AGDB',True,AGDB); | 
 
 
 
 
 | 846 | InsertHandler('AGDB',False,NIL); | 
 
 
 
 
 | 847 | InsertHandler('AGQC',False,NIL); | 
 
 
 
 
 | 848 | InsertHandler('AGQG',False,NIL); | 
 
 
 
 
 | 849 | InsertHandler('AGQR',False,NIL); | 
 
 
 
 
 | 850 | InsertHandler('AISA',False,NIL); | 
 
 
 
 
 | 851 | InsertHandler('AITR',False,NIL); | 
 
 
 
 
 | 852 | InsertHandler('AKAA',False,NIL); | 
 
 
 
 
 | 853 | InsertHandler('AKBA',False,NIL); | 
 
 
 
 
 | 854 | InsertHandler('AKBP',False,NIL); | 
 
 
 
 
 | 855 | InsertHandler('AKDA',False,NIL); | 
 
 
 
 
 | 856 | InsertHandler('AKEV',True,AKEV); | 
 
 
 
 
 | 857 | InsertHandler('AKOT',True,AKOT); | 
 
 
 
 
 | 858 | InsertHandler('AKVA',False,NIL); | 
 
 
 
 
 | 859 | InsertHandler('BINA',False,NIL); | 
 
 
 
 
 | 860 | InsertHandler('CBPI',True,CBPI); | 
 
 
 
 
 | 861 | InsertHandler('CBPM',True,CBPM); | 
 
 
 
 
 | 862 | InsertHandler('CONS',True,CONS); | 
 
 
 
 
 | 863 | InsertHandler('CRSA',True,CRSA); | 
 
 
 
 
 | 864 | InsertHandler('DOOR',True,DOOR); | 
 
 
 
 
 | 865 | InsertHandler('DPGE',True,DPGE); | 
 
 
 
 
 | 866 | InsertHandler('ENVP',False,NIL); | 
 
 
 
 
 | 867 | InsertHandler('FILM',False,NIL); | 
 
 
 
 
 | 868 | InsertHandler('HPGE',True,HPGE); | 
 
 
 
 
 | 869 | InsertHandler('IDXA',False,NIL); | 
 
 
 
 
 | 870 | InsertHandler('IGHH',True,IGHH); | 
 
 
 
 
 | 871 | InsertHandler('IGPA',True,IGPA); | 
 
 
 
 
 | 872 | InsertHandler('IGPG',True,IGPG); | 
 
 
 
 
 | 873 | InsertHandler('IGSA',True,IGSA); | 
 
 
 
 
 | 874 | InsertHandler('IMPT',True,IMPT); | 
 
 
 
 
 | 875 | InsertHandler('IPGE',True,IPGE); | 
 
 
 
 
 | 876 | InsertHandler('KEYI',True,KEYI); | 
 
 
 
 
 | 877 | InsertHandler('M3GA',True,M3GA); | 
 
 
 
 
 | 878 | InsertHandler('M3GM',True,M3GM); | 
 
 
 
 
 | 879 | InsertHandler('MTRL',True,MTRL); | 
 
 
 
 
 | 880 | InsertHandler('OBAN',False,NIL); | 
 
 
 
 
 | 881 | InsertHandler('OBDC',False,NIL); | 
 
 
 
 
 | 882 | InsertHandler('OBOA',True,OBOA); | 
 
 
 
 
 | 883 | InsertHandler('OFGA',True,OFGA); | 
 
 
 
 
 | 884 | InsertHandler('ONCC',True,ONCC); | 
 
 
 
 
 | 885 | InsertHandler('ONCP',False,NIL); | 
 
 
 
 
 | 886 | InsertHandler('ONCV',True,ONCV); | 
 
 
 
 
 | 887 | InsertHandler('ONFA',False,NIL); | 
 
 
 
 
 | 888 | InsertHandler('ONGS',False,NIL); | 
 
 
 
 
 | 889 | InsertHandler('ONIA',False,NIL); | 
 
 
 
 
 | 890 | InsertHandler('ONLD',False,NIL); | 
 
 
 
 
 | 891 | InsertHandler('ONLV',True,ONLV); | 
 
 
 
 
 | 892 | InsertHandler('ONMA',False,NIL); | 
 
 
 
 
 | 893 | InsertHandler('ONOA',True,ONOA); | 
 
 
 
 
 | 894 | InsertHandler('ONSA',False,NIL); | 
 
 
 
 
 | 895 | InsertHandler('ONSK',True,ONSK); | 
 
 
 
 
 | 896 | InsertHandler('ONTA',False,NIL); | 
 
 
 
 
 | 897 | InsertHandler('ONVL',True,ONVL); | 
 
 
 
 
 | 898 | InsertHandler('ONWC',True,ONWC); | 
 
 
 
 
 | 899 | InsertHandler('OPGE',True,OPGE); | 
 
 
 
 
 | 900 | InsertHandler('OSBD',False,NIL); | 
 
 
 
 
 | 901 | InsertHandler('OTIT',False,NIL); | 
 
 
 
 
 | 902 | InsertHandler('OTLF',False,NIL); | 
 
 
 
 
 | 903 | InsertHandler('PLEA',False,NIL); | 
 
 
 
 
 | 904 | InsertHandler('PNTA',False,NIL); | 
 
 
 
 
 | 905 | InsertHandler('PSPC',True,PSPC); | 
 
 
 
 
 | 906 | InsertHandler('PSPL',True,PSPL); | 
 
 
 
 
 | 907 | InsertHandler('PSUI',True,PSUI); | 
 
 
 
 
 | 908 | InsertHandler('QTNA',False,NIL); | 
 
 
 
 
 | 909 | InsertHandler('SNDD',False,NIL); | 
 
 
 
 
 | 910 | InsertHandler('STNA',True,STNA); | 
 
 
 
 
 | 911 | InsertHandler('SUBT',False,NIL); | 
 
 
 
 
 | 912 | InsertHandler('TRAC',True,TRAC); | 
 
 
 
 
 | 913 | InsertHandler('TRAM',True,TRAM); | 
 
 
 
 
 | 914 | InsertHandler('TRAS',True,TRAS); | 
 
 
 
 
 | 915 | InsertHandler('TRBS',True,TRBS); | 
 
 
 
 
 | 916 | InsertHandler('TRCM',True,TRCM); | 
 
 
 
 
 | 917 | InsertHandler('TRGA',True,TRGA); | 
 
 
 
 
 | 918 | InsertHandler('TRGE',True,TRGE); | 
 
 
 
 
 | 919 | InsertHandler('TRIA',False,NIL); | 
 
 
 
 
 | 920 | InsertHandler('TRIG',True,TRIG); | 
 
 
 
 
 | 921 | InsertHandler('TRMA',True,TRMA); | 
 
 
 
 
 | 922 | InsertHandler('TRSC',True,TRSC); | 
 
 
 
 
 | 923 | InsertHandler('TRTA',False,NIL); | 
 
 
 
 
 | 924 | InsertHandler('TSFF',True,TSFF); | 
 
 
 
 
 | 925 | InsertHandler('TSFL',False,NIL); | 
 
 
 
 
 | 926 | InsertHandler('TSFT',True,TSFT); | 
 
 
 
 
 | 927 | InsertHandler('TSGA',False,NIL); | 
 
 
 
 
 | 928 | InsertHandler('TSTR',False,NIL); | 
 
 
 
 
 | 929 | InsertHandler('TURR',True,TURR); | 
 
 
 
 
 | 930 | InsertHandler('TXAN',True,TXAN); | 
 
 
 
 
 | 931 | InsertHandler('TXCA',False,NIL); | 
 
 
 
 
 | 932 | InsertHandler('TXMA',True,TXMA); | 
 
 
 
 
 | 933 | InsertHandler('TXMB',True,TXMB); | 
 
 
 
 
 | 934 | InsertHandler('TXMP',True,TXMP); | 
 
 
 
 
 | 935 | InsertHandler('TXTC',True,TXTC); | 
 
 
 
 
 | 936 | InsertHandler('VCRA',False,NIL); | 
 
 
 
 
 | 937 | InsertHandler('WMCL',True,WMCL); | 
 
 
 
 
 | 938 | InsertHandler('WMDD',False,NIL); | 
 
 
 
 
 | 939 | InsertHandler('WMM_',False,NIL); | 
 
 
 
 
 | 940 | InsertHandler('WMMB',True,WMMB); | 
 
 
 
 
 | 941 | InsertHandler('WPGE',True,WPGE); | 
 
 
 
 
 | 942 | END. |