ViewVC Help
View File | Revision Log | View Changeset | Root Listing
root/Oni2/oup/current/Helper/LevelDB.pas
(Generate patch)

Comparing:
oup/rewrite/Helper/Helper_LevelDB.pas (file contents), Revision 97 by alloc, Mon Jan 22 23:05:45 2007 UTC vs.
oup/current/Helper/LevelDB.pas (file contents), Revision 150 by alloc, Sun Apr 1 18:26:35 2007 UTC

# Line 1 | Line 1
1 < unit Helper_LevelDB;
2 <
1 > unit LevelDB;
2   interface
4
3   uses
4    Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
5    Dialogs, ComCtrls, StdCtrls, StrUtils;
# Line 14 | Line 12 | type
12      btn_abortok:  TButton;
13      lbl_estimation: TLabel;
14      procedure btn_abortokClick(Sender: TObject);
17  private
18    procedure HandleFile(ext: String; fileid: Integer; dir_dat2db: Boolean);
19    procedure stop_convert;
15    public
16      procedure CreateDatabase(Source, Target: String);
17      procedure CreateLevel(Source, Target: String);
# Line 27 | Line 22 | var
22    Form_LevelDB: TForm_LevelDB;
23  
24   implementation
30
25   {$R *.dfm}
26 + uses ABSMain, ABSDecUtil, Main,
27 +    ConnectionManager, TypeDefs, DataAccess, OniImgClass, Data, RawList;
28  
29 < uses ABSMain, ABSDecUtil, Main, Functions, Data, OniImgClass, DataStructures, ConnectionManager;
29 > var
30 >  Converting:  Boolean = False;
31 >  Abort:       Boolean = False;
32  
35 type
36  THandler = procedure(fileid: LongWord; dir_dat2db: Boolean);
33  
34 <  TConvertHandlers = record
35 <    Ext:     String[4];
36 <    needed:  Boolean;
37 <    Handler: THandler;
34 > function GetOpenMsg(msg: TStatusMessages): String;
35 > begin
36 >  case msg of
37 >    SM_AlreadyOpened:    Result := 'File already opened.';
38 >    SM_FileNotFound:     Result := 'File not found.';
39 >    SM_UnknownExtension: Result := 'Unknown extension.';
40 >    SM_IncompatibleFile: Result := 'Incompatible file format.';
41 >    SM_UnknownError:     Result := 'Unknown error.';
42    end;
43 + end;
44  
44 var
45  ConvertHandlers: array of TConvertHandlers;
46  loaded_filename: String;
47  converting: Boolean = False;
48  abort:     Boolean = False;
49  DataBase:  TABSDatabase;
50  Query:     TABSQuery;
51  MimeCoder: TStringFormat_MIME64;
45  
46 + procedure TForm_LevelDB.CreateLevel(Source, Target: String);
47 + const
48 +  EmptyBytes: Array[0..31] of Byte = (
49 +      0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 );
50   var
51 <  DatHeader:   THeader;
52 <  FilesHeader: TFilesMap;
51 >  DatHeader:        THeader;
52 >  FilesHeader:      TFilesMap;
53    NamedFilesHeader: TNamedFilesMap;
54    ExtensionsHeader: TExtensionsMap;
58  Stream_Body, Stream_Names: TMemoryStream;
59  Stream_Dat, Stream_Raw, Stream_Sep: TFileStream;
60  OniDataConnection: TOniData;
61
55  
56 +  Stream_Body, Stream_Names:          TMemoryStream;
57 +  Stream_Dat, Stream_Raw, Stream_Sep: TFileStream;
58  
59 +  BeginTime, FileTime: Double;
60 +  Step:     Integer;
61 +  LevelID:    Integer;
62 +  TimeFormat: TFormatSettings;
63 +
64 +  ConID:      Integer;
65 +  Connection: TDataAccess;
66 +  ConRepMsg:  TStatusMessages;
67 +
68 +  FileID:     Integer;
69 +
70 +  Strings:    TStrings;
71 +  i, j:       Integer;
72 +  temps:      String;
73 +  tempi:      Integer;
74 +  tempb:      Byte;
75 +  FileInfo:   TFileInfo;
76 +  DatLinks:   TDatLinkList;
77 +  RawLinks:   TRawDataList;
78  
79 < procedure TForm_LevelDB.CreateLevel(Source, target: String);
66 < var
67 <  files: LongWord;
68 <
69 <  i, j:     LongWord;
70 <  temps, temps2: String;
71 <  Data, rawdata: Tdata;
72 <  absolutebegintime, begintime: Double;
73 <  step:     Byte;
74 <  rawlist:  TRawList;
75 <  extlist:  TExtensionsMap;
76 <  fileinfo: TFileInfo;
77 <  datlinks: TDatLinks;
78 <  OniImage: TOniImage;
79 <  levelid:  LongWord;
80 <  timeformat: TFormatSettings;
81 <
82 <  conIndex: Integer;
83 <  connection: TOniData;
79 >  DatFileStream, RawFileStream: TMemoryStream;
80   const
81 <  steps: Byte = 3;
81 >  Steps: Byte = 3;
82  
83  
84 <
89 <
90 <  procedure DoStep(stepname: String);
84 >  procedure DoStep(StepName: String);
85    begin
86 <    Inc(step);
87 <    if stepname <> 'FIN' then
86 >    Inc(Step);
87 >    if StepName <> 'FIN' then
88        group_progress.Caption :=
89 <        'Creating Dat (Step ' + IntToStr(step) + '/' + IntToStr(steps) + ': ' + stepname + ')'
89 >        'Creating Dat (Step ' + IntToStr(Step) + '/' + IntToStr(Steps) + ': ' + StepName + ')'
90      else
91        group_progress.Caption := 'Creating Dat (FINISHED)';
92    end;
93  
94 +  procedure StopConvert;
95 +  begin
96 +    btn_abortok.Caption := '&Close';
97 +    btn_abortok.Default := True;
98 +    converting := False;
99 +    lbl_estimation.Caption := 'ABORTED';
100 +    group_progress.Caption := 'Creating Level (ABORTED)';
101 +
102 +    Stream_Body.Free;
103 +    Stream_Names.Free;
104 +    DatFileStream.Free;
105 +    RawFileStream.Free;
106 +    
107 +    Stream_Dat.Free;
108 +    Stream_Raw.Free;
109 +    if Connection.DataOS in [DOS_WINDEMO, DOS_MAC, DOS_MACBETA] then
110 +      Stream_Sep.Free;
111 +    
112 +    if MessageBox(Self.Handle, PChar('Delete the unfinished level-files?'),
113 +      PChar('Delete files?'), MB_YESNO) = idYes then
114 +    begin
115 +      DeleteFile(target);
116 +      DeleteFile(AnsiReplaceStr(Target, '.dat', '.raw'));
117 +      if Connection.DataOS in [DOS_WINDEMO, DOS_MAC, DOS_MACBETA] then
118 +        DeleteFile(AnsiReplaceStr(Target, '.dat', '.sep'));
119 +    end;
120 +  end;
121 +
122   begin
123  
124    //
125    // FILE EXISTS CHECK FÜR DAT/RAW/SEP!!!
126    //
127  
128 <  timeformat.ShortTimeFormat := 'hh:nn:ss';
129 <  timeformat.LongTimeFormat := 'hh:nn:ss';
130 <  timeformat.TimeSeparator := ':';
128 >  TimeFormat.ShortTimeFormat := 'hh:nn:ss';
129 >  TimeFormat.LongTimeFormat  := 'hh:nn:ss';
130 >  TimeFormat.TimeSeparator   := ':';
131  
132 <  connection := ConnectionExists(target);
133 <  if connection <> nil then
132 >  ConID := ConManager.OpenConnection(Source, ConRepMsg);
133 >  if not (ConRepMsg in [SM_OK, SM_AlreadyOpened]) then
134    begin
135 <    ShowMessage('Destination-file is opened, close it in order to proceed conversion?');
135 >    ShowMessage('Source-file couldn''t be opened! Aborting' + CrLf + GetOpenMsg(ConRepMsg));
136      Exit;
137 <  end;
137 >  end else
138 >    Connection := ConManager.Connection[ConID];
139  
140 <  connection := ConnectionExists(source);
141 <  if connection <> nil then
140 >  ConID := ConManager.FileOpened(Target);
141 >  if ConID >= 0 then
142    begin
143 <    ShowMessage('Source-file is opened, close it in order to proceed conversion?');
144 <    Exit;
143 >    if MessageBox(Self.Handle, PChar('Destination-file is opened, close it in ' +
144 >          'order to proceed conversion?'), PChar('Destination-file opened'),
145 >          MB_YESNO + MB_ICONQUESTION) = ID_YES then
146 >    begin
147 >      if Form_Main.CheckConnectionCloseable(ConID) then
148 >        if not ConManager.CloseConnection(ConID, ConRepMsg) then
149 >        begin
150 >          ShowMessage('Couldn''t close destination-file. Aborting');
151 >          Exit;
152 >        end;
153 >    end else begin
154 >      ShowMessage('Aborting');
155 >      Exit;
156 >    end;
157    end;
158  
159 <
125 <  if CreateDataConnection(Source, ODB_ADB) = nil then
159 >  if FileExists(Target) then
160    begin
161 <    ShowMessage('Could not connect to .oldb-file');
162 <    Exit;
161 >    if MessageBox(Self.Handle, PChar('Destination-file exists. ' +
162 >          'Overwrite it?'), PChar('Destination-file exists'),
163 >          MB_YESNO + MB_ICONWARNING) = ID_YES then
164 >    begin
165 >      if not DeleteFile(Target) then
166 >      begin
167 >        ShowMessage('Couldn''t delete file. Aborting');
168 >        Exit;
169 >      end;
170 >      if FileExists(AnsiReplaceStr(Target, '.dat', '.raw')) then
171 >        if not DeleteFile(AnsiReplaceStr(Target, '.dat', '.raw')) then
172 >        begin
173 >          ShowMessage('Couldn''t delete file. Aborting');
174 >          Exit;
175 >        end;
176 >      if FileExists(AnsiReplaceStr(Target, '.dat', '.sep')) then
177 >        if Connection.DataOS in [DOS_WINDEMO, DOS_MAC, DOS_MACBETA] then
178 >          if not DeleteFile(AnsiReplaceStr(Target, '.dat', '.sep')) then
179 >          begin
180 >            ShowMessage('Couldn''t delete file. Aborting');
181 >            Exit;
182 >          end;
183 >    end else begin
184 >      ShowMessage('Aborting');
185 >      Exit;
186 >    end;
187    end;
130  levelid  := OniDataConnection.LevelInfo.LevelNumber;
131  levelid  := (levelid * 2) * 256 * 256 * 256 + $01;
132  OniImage := TOniImage.Create;
188  
189 <  absolutebegintime := Time;
189 >  LevelID  := Connection.LevelNumber;
190 >  LevelID  := (LevelID * 2) * 256 * 256 * 256 + $01;
191  
192    Self.Visible := True;
193    Form_Main.Visible := False;
194 <  step  := 0;
195 <  converting := True;
196 <  abort := False;
194 >  Step := 0;
195 >  Converting := True;
196 >  Abort := False;
197    btn_abortok.Caption := '&Abort...';
198    btn_abortok.Default := False;
199 <  absolutebegintime := Time;
199 >  BeginTime := Time;
200  
201    Stream_Body  := TMemoryStream.Create;
202    Stream_Names := TMemoryStream.Create;
203 <  Stream_Dat   := TFileStream.Create(target, fmCreate);
204 <  Stream_Raw   := TFileStream.Create(AnsiReplaceStr(target, '.dat', '.raw'), fmCreate);
205 <  if OniDataConnection.OSisMac then
206 <    Stream_Sep := TFileStream.Create(AnsiReplaceStr(target, '.dat', '.sep'), fmCreate);
203 >  Stream_Dat   := TFileStream.Create(Target, fmCreate);
204 >  Stream_Raw   := TFileStream.Create(AnsiReplaceStr(Target, '.dat', '.raw'), fmCreate);
205 >  if Connection.DataOS in [DOS_WINDEMO, DOS_MAC, DOS_MACBETA] then
206 >    Stream_Sep := TFileStream.Create(AnsiReplaceStr(Target, '.dat', '.sep'), fmCreate);
207  
208    DoStep('Creating header');
209    progress.Position      := 0;
# Line 155 | Line 211 | begin
211    lbl_estimation.Caption := 'Estimated finishing time: unknown';
212    Application.ProcessMessages;
213  
214 <  NamedFilesHeader := TOniDataADB(OniDataConnection).GetNamedFilesMap;
215 <  extlist := OniDataConnection.GetExtendedExtensionsList;
216 <  for i := 0 to High(DatHeader.Ident) do
217 <    DatHeader.Ident[i] := OniDataConnection.LevelInfo.Ident[i];
218 <  DatHeader.Files := OniDataConnection.GetFilesCount;
214 >  SetLength(NamedFilesHeader, 0);
215 >  Strings := TStringList.Create;
216 >  Strings := Connection.GetFilesList('', '', False, ST_ExtNameAsc);
217 >  for i := 0 to Strings.Count - 1 do
218 >  begin
219 >    if MidStr(Strings.Strings[i],
220 >          Pos('-', Strings.Strings[i]) + 1,
221 >          Length(Strings.Strings[i]) -
222 >            Pos('.', ReverseString(Strings.Strings[i])) -
223 >            Pos('-', Strings.Strings[i])
224 >        ) <> '' then
225 >    begin
226 >      SetLength(NamedFilesHeader, Length(NamedFilesHeader) + 1);
227 >      NamedFilesHeader[High(NamedFilesHeader)].FileNumber := StrToInt(MidStr(Strings.Strings[i], 1, 5));
228 >      NamedFilesHeader[High(NamedFilesHeader)].blubb := 0;
229 >    end;
230 >  end;
231 >
232 >  for i := 0 to High(DatHeader.OSIdent) do
233 >    case Connection.DataOS of
234 >      DOS_WIN: DatHeader.OSIdent[i] := HeaderOSIdentWin[i];
235 >      DOS_MAC: DatHeader.OSIdent[i] := HeaderOSIdentMac[i];
236 >      DOS_MACBETA: DatHeader.OSIdent[i] := HeaderOSIdentMacBeta[i];
237 >    end;
238 >  for i := 0 to High(DatHeader.GlobalIdent) do
239 >    DatHeader.GlobalIdent[i] := HeaderGlobalIdent[i];
240 >  DatHeader.Files := Connection.GetFileCount;
241    DatHeader.NamedFiles := Length(NamedFilesHeader);
242 <  DatHeader.Extensions := Length(extlist);
242 >
243 >  Strings := Connection.GetExtensionsList(EF_ExtCount);
244 >
245 >  DatHeader.Extensions := Strings.Count;
246    DatHeader.DataAddr   := 0;
247    DatHeader.DataSize   := 0;
248    DatHeader.NamesAddr  := 0;
# Line 171 | Line 252 | begin
252    SetLength(FilesHeader, DatHeader.Files);
253    SetLength(ExtensionsHeader, DatHeader.Extensions);
254  
255 +
256    DoStep('Writing extensions-header');
257 <  progress.Max := Length(OniDataConnection.GetExtensionsList);
257 >  progress.Max := Strings.Count;
258    Application.ProcessMessages;
259 <
178 <  for i := 0 to High(ExtensionsHeader) do
259 >  for i := 0 to Strings.Count - 1 do
260    begin
261 <    ExtensionsHeader[i].Ident     := extlist[i].Ident;
262 <    ExtensionsHeader[i].Extension := extlist[i].Extension;
263 <    SetLength(temps, 4);
261 >    temps := Strings.Strings[i];
262 >    ExtensionsHeader[i].ExtCount := StrToInt( MidStr(
263 >            temps,
264 >            Pos('(', temps) + 1,
265 >            Pos(')', temps) - Pos('(', temps) - 1 ) );
266 >    temps := MidStr(temps, 1, 4);
267      for j := 0 to 3 do
268 <      temps[j + 1] := ExtensionsHeader[i].Extension[3 - j];
269 <    ExtensionsHeader[i].ExtCount :=
270 <      Length(OniDataConnection.GetFilesList(temps, '', False, stIDAsc));
268 >      ExtensionsHeader[i].Extension[j] := temps[4-j];
269 >    for j := 0 to High(FileTypes) do
270 >      if FileTypes[j].Extension = temps then
271 >        Break;
272 >    if j < Length(FileTypes) then
273 >    begin
274 >      case Connection.DataOS of
275 >        DOS_WIN:     ExtensionsHeader[i].Ident := FileTypes[j].IdentWin;
276 >        DOS_WINDEMO: ExtensionsHeader[i].Ident := FileTypes[j].IdentMac;
277 >        DOS_MAC:     ExtensionsHeader[i].Ident := FileTypes[j].IdentMac;
278 >        DOS_MACBETA: ExtensionsHeader[i].Ident := FileTypes[j].IdentMac;
279 >      end;
280 >    end else begin
281 >      ShowMessage('Unknown Extension: ' + Strings.Strings[i]);
282 >      Exit;
283 >    end;
284      progress.Position    := i + 1;
285      lbl_progress.Caption := 'Extensions done: ' + IntToStr(i + 1) + '/' +
286 <      IntToStr(Length(extlist));
286 >      IntToStr(Strings.Count);
287      Application.ProcessMessages;
288    end;
289  
# Line 197 | Line 294 | begin
294    lbl_estimation.Caption := 'Estimated finishing time: unknown';
295    Application.ProcessMessages;
296  
297 <  begintime := Time;
298 <  for i := 0 to DatHeader.Files - 1 do
297 >  FileTime := Time;
298 >  for FileID := 0 to DatHeader.Files - 1 do
299    begin
300 <    fileinfo := OniDataConnection.GetFileInfo(i);
300 >    FileInfo := Connection.GetFileInfo(FileID);
301      for j := 0 to 3 do
302 <      FilesHeader[i].Extension[j] := fileinfo.Extension[4 - j];
303 <    if fileinfo.Size > 0 then
302 >      FilesHeader[FileID].Extension[j] := FileInfo.Extension[4 - j];
303 >    if FileInfo.Size > 0 then
304      begin
305 <      //        DatLinks:=;
306 <      FilesHeader[i].DataAddr := Stream_Body.Size + 8;
307 <      Data    := OniDataConnection.LoadDatFile(i);
308 <      Data[4] := (levelid) and $FF;
309 <      Data[5] := (levelid shr 8) and $FF;
310 <      Data[6] := (levelid shr 16) and $FF;
311 <      Data[7] := (levelid shr 24) and $FF;
305 >      FilesHeader[FileID].DataAddr := Stream_Body.Size + 8;
306 >      DatFileStream := TMemoryStream.Create;
307 >      Connection.LoadDatFile(FileID, TStream(DatFileStream));
308 >      DatFileStream.Seek(0, soFromBeginning);
309 >      tempi := FileID * 256 + 1;
310 >      DatFileStream.Write(tempi, 4);
311 >      DatFileStream.Write(LevelID, 4);
312  
313 <      if (Pos(UpperCase(fileinfo.Extension), UpperCase(raws)) mod 4) = 1 then
313 >      DatLinks := Connection.GetDatLinks(FileID);
314 >      if Length(DatLinks) > 0 then
315        begin
316 <        rawlist := OniDataConnection.GetRawList(i);
219 <        if Length(rawlist) > 0 then
316 >        for i := 0 to High(DatLinks) do
317          begin
318 <          for j := 0 to High(rawlist) do
318 >          DatFileStream.Seek(DatLinks[i].SrcOffset, soFromBeginning);
319 >          if DatLinks[i].DestID < 0 then
320 >            tempi := 0
321 >          else
322 >            tempi := DatLinks[i].DestID * 256 + 1;
323 >          DatFileStream.Write(tempi, 4);
324 >        end;
325 >      end;
326 >
327 >      RawLinks := Connection.GetRawList(FileID);
328 >      if Length(RawLinks) > 0 then
329 >      begin
330 >        for i := 0 to High(RawLinks) do
331 >        begin
332 >          if RawLinks[i].RawSize > 0 then
333            begin
334 <            if rawlist[j].raw_size > 0 then
334 >            RawFileStream := TMemoryStream.Create;
335 >            Connection.LoadRawFile(FileID, RawLinks[i].SrcOffset, TStream(RawFileStream));
336 >            RawFileStream.Seek(0, soFromBeginning);
337 >            if RawLinks[i].LocSep then
338              begin
339 <              if (UpperCase(fileinfo.Extension) = 'TXMP') and
340 <                ((Data[$88] and $01) > 0) then
341 <              begin
342 <                OniImage.LoadFromTXMP(Connection, i);
343 <                OniImage.GetMipMappedImage(rawdata);
344 <                rawlist[j].raw_size := OniImage.GetImageDataSize(True);
345 <                Data[$90] := $08;
346 <                Data[$89] := 32;
347 < {                  if data[$90]<>OniImage.StoreType then begin
348 <                    data[$90]:=OniImage.StoreType;
349 <                    data[$89]:=(data[$89] and $CF) or $20;
350 <                  end;
351 < }                end
352 <              else
239 <              begin
240 <                SetLength(rawdata, rawlist[j].raw_size);
241 <                OniDataConnection.LoadRawFile(i, rawlist[j].src_offset, @rawdata[0]);
242 <              end;
243 <              //                data[$88]:=data[$88] and $FE;
244 <
245 <              if rawlist[j].loc_sep then
246 <              begin
247 <                rawlist[j].raw_addr := Stream_Sep.Size;
248 <                Stream_Sep.Write(rawdata[0], Length(rawdata));
249 <              end
250 <              else
251 <              begin
252 <                rawlist[j].raw_addr := Stream_Raw.Size;
253 <                Stream_Raw.Write(rawdata[0], Length(rawdata));
254 <              end;
255 <            end
256 <            else
257 <              rawlist[j].raw_addr := 0;
258 <            Data[rawlist[j].src_offset + 0] := (rawlist[j].raw_addr) and $FF;
259 <            Data[rawlist[j].src_offset + 1] := (rawlist[j].raw_addr shr 8) and $FF;
260 <            Data[rawlist[j].src_offset + 2] := (rawlist[j].raw_addr shr 16) and $FF;
261 <            Data[rawlist[j].src_offset + 3] := (rawlist[j].raw_addr shr 24) and $FF;
262 <          end;
339 >              RawLinks[i].RawAddr := Stream_Sep.Size;
340 >              Stream_sep.CopyFrom(RawFileStream, RawFileStream.Size);
341 >              if (Stream_Sep.Size mod 32) > 0 then
342 >                Stream_Sep.Write(EmptyBytes[0], 32 - (Stream_Sep.Size mod 32));
343 >            end else begin
344 >              RawLinks[i].RawAddr := Stream_Raw.Size;
345 >              Stream_Raw.CopyFrom(RawFileStream, RawFileStream.Size);
346 >              if (Stream_Raw.Size mod 32) > 0 then
347 >                Stream_Raw.Write(EmptyBytes[0], 32 - (Stream_Raw.Size mod 32));
348 >            end;
349 >          end else
350 >            RawLinks[i].RawAddr := 0;
351 >          DatFileStream.Seek(RawLinks[i].SrcOffset, soFromBeginning);
352 >          DatFileStream.Write(RawLinks[i].RawAddr, 4);
353          end;
354        end;
355 <
356 <      Stream_Body.Write(Data[0], Length(Data));
357 <      //
355 >      DatFileStream.Seek(0, soFromBeginning);
356 >      Stream_Body.CopyFrom(DatFileStream, DatFileStream.Size);
357 >      if (Stream_Body.Size mod 32) > 0 then
358 >      begin
359 >        ShowMessage(
360 >            IntToStr(FileID) + '-' + FileInfo.Name + '.' + FileInfo.Extension + #13#10 +
361 >            IntToStr(Stream_Body.Size));
362 >        Stream_Body.Write(EmptyBytes[0], 32 - (Stream_Body.Size mod 32));
363 >      end;
364      end
365      else
366 <      FilesHeader[i].DataAddr := 0;
366 >      FilesHeader[FileID].DataAddr := 0;
367      if Length(fileinfo.Name) > 0 then
368      begin
369 <      FilesHeader[i].NameAddr := Stream_Names.Size;
369 >      FilesHeader[FileID].NameAddr := Stream_Names.Size;
370        temps := fileinfo.Extension + fileinfo.Name + Chr(0);
371        Stream_Names.Write(temps[1], Length(temps));
372      end
373      else
374 <      FilesHeader[i].NameAddr := 0;
375 <    FilesHeader[i].FileSize := fileinfo.Size;
376 <    FilesHeader[i].FileType := fileinfo.FileType;
374 >      FilesHeader[FileID].NameAddr := 0;
375 >    FilesHeader[FileID].FileSize := fileinfo.Size;
376 >    FilesHeader[FileID].FileType := fileinfo.FileType;
377  
378 <    if ((i mod 10) = 0) and (i >= 100) then
378 >    if ((FileID mod 10) = 0) and (FileID >= 100) then
379        lbl_estimation.Caption := 'Estimated time left: ' + TimeToStr(
380 <        (Time - begintime) / i * (progress.Max - i + 1) * 1.1, timeformat );
381 <    progress.Position := i + 1;
382 <    lbl_progress.Caption := 'Files done: ' + IntToStr(i + 1) + '/' + IntToStr(progress.Max);
380 >        (Time - FileTime) / FileID * (progress.Max - FileID + 1) * 1.1, TimeFormat );
381 >    progress.Position := FileID + 1;
382 >    lbl_progress.Caption := 'Files done: ' + IntToStr(FileID + 1) + '/' + IntToStr(progress.Max);
383      Application.ProcessMessages;
384    end;
385  
# Line 295 | Line 391 | begin
391    for i := 0 to High(ExtensionsHeader) do
392      Stream_Dat.Write(ExtensionsHeader[i], SizeOf(ExtensionsHeader[i]));
393  
394 +  if (Stream_Dat.Size mod 32) > 0 then
395 +    Stream_Dat.Write(EmptyBytes[0], 32 - (Stream_Dat.Size mod 32));
396 +
397    DatHeader.DataSize  := Stream_Body.Size;
398    DatHeader.NamesSize := Stream_Names.Size;
399    DatHeader.DataAddr  := Stream_Dat.Size;
400 +
401    Stream_Body.Seek(0, soFromBeginning);
402    Stream_Dat.CopyFrom(Stream_Body, Stream_Body.Size);
403 +
404 +  if (Stream_Dat.Size mod 32) > 0 then
405 +    Stream_Dat.Write(EmptyBytes[0], 32 - (Stream_Dat.Size mod 32));
406 +
407    DatHeader.NamesAddr := Stream_Dat.Size;
408    Stream_Names.Seek(0, soFromBeginning);
409    Stream_Dat.CopyFrom(Stream_Names, Stream_Names.Size);
# Line 311 | Line 415 | begin
415    Stream_Body.Free;
416    Stream_Names.Free;
417    Stream_Raw.Free;
418 <  if OniDataConnection.OSisMac then
418 >
419 >  if Connection.DataOS in [DOS_WINDEMO, DOS_MAC, DOS_MACBETA] then
420      Stream_Sep.Free;
421  
422    progress.Position      := progress.Max;
423    lbl_progress.Caption   := 'Files done: ' + IntToStr(progress.Max) + '/' +
424      IntToStr(progress.Max);
425 <  lbl_estimation.Caption := 'FINISHED (duration: ' + TimeToStr(Time - absolutebegintime, timeformat) + ')';
425 >  lbl_estimation.Caption := 'FINISHED (duration: ' + TimeToStr(Time - Begintime, TimeFormat) + ')';
426  
427    DoStep('FIN');
428    btn_abortok.Caption := '&OK';
429    btn_abortok.Default := True;
430  
326  OniImage.Free;
327
431    converting := False;
432  
433 <  CloseDataConnection(DataConnections[conIndex]);
331 < end;
332 <
333 <
334 <
335 <
336 < procedure TForm_LevelDB.HandleFile;
337 < var
338 <  i: Byte;
339 < begin
340 <  for i := 1 to Length(ConvertHandlers) do
341 <    if UpperCase(ConvertHandlers[i].Ext) = UpperCase(ext) then
342 <      if ConvertHandlers[i].needed then
343 <      begin
344 <        ConvertHandlers[i].Handler(fileid, dir_dat2db);
345 <        Break;
346 <      end
347 <      else
348 <        Break;
433 > //  CloseDataConnection(DataConnections[conIndex]);
434   end;
435  
436  
# Line 353 | Line 438 | end;
438  
439   procedure TForm_LevelDB.CreateDatabase(Source, target: String);
440   var
441 <  i, j:     LongWord;
442 <  temps, temps2: String;
443 <  Data:     Tdata;
359 <  absolutebegintime, begintime: Double;
360 <  step:     Byte;
361 <  rawlist:  TRawList;
362 <  extlist:  TExtensionsMap;
363 <  fileinfo: TFileInfo;
364 <  timeformat: TFormatSettings;
441 >  DataBase:  TABSDatabase;
442 >  Query:     TABSQuery;
443 >  MimeCoder: TStringFormat_MIME64;
444  
445 <  conIndex: Integer;
445 >  BeginTime, FileTime: Double;
446 >  Step:       Integer;
447 >  TimeFormat: TFormatSettings;
448 >
449 >  ConID:      Integer;
450 >  Connection: TDataAccess;
451 >  ConRepMsg:  TStatusMessages;
452 >
453 >  FileID:     Integer;
454 >
455 >  i:          Integer;
456 >  temps:      String;
457 >  tempdata:   TByteData;
458 >  FileInfo:   TFileInfo;
459 >  DatLinks:   TDatLinkList;
460 >  RawLinks:   TRawDataList;
461   const
462 <  steps: Byte = 4;
369 <
370 <
371 <
462 >  steps: Byte = 2;
463  
464    procedure DoStep(stepname: String);
465    begin
# Line 380 | Line 471 | const
471        group_progress.Caption := 'Creating DB (FINISHED)';
472    end;
473  
474 +  procedure StopConvert;
475 +  begin
476 +    btn_abortok.Caption := '&Close';
477 +    btn_abortok.Default := True;
478 +    converting := False;
479 +    lbl_estimation.Caption := 'ABORTED';
480 +    group_progress.Caption := 'Creating DB (ABORTED)';
481 +    DataBase.Close;
482 +    if MessageBox(Self.Handle, PChar('Delete the unfinished DB-file?'),
483 +      PChar('Delete file?'), MB_YESNO) = idYes then
484 +    begin
485 +      DeleteFile(target);
486 +    end;
487 + end;
488 +
489 +
490 +
491   begin
492 <  if CreateDataConnection(Source, ODB_Dat) = nil then
492 >
493 >  //
494 >  // FILE EXISTS CHECK FÜR DAT/RAW/SEP!!!
495 >  //
496 >
497 >  TimeFormat.ShortTimeFormat := 'hh:nn:ss';
498 >  TimeFormat.LongTimeFormat  := 'hh:nn:ss';
499 >  TimeFormat.TimeSeparator   := ':';
500 >
501 >  ConID := ConManager.OpenConnection(Source, ConRepMsg);
502 >  if not (ConRepMsg in [SM_OK, SM_AlreadyOpened]) then
503    begin
504 <    ShowMessage('Could not connect to .dat-file');
504 >    ShowMessage('Source-file couldn''t be opened! Aborting' + CrLf + GetOpenMsg(ConRepMsg));
505      Exit;
506 <  end
507 <  else
506 >  end else
507 >    Connection := ConManager.Connection[ConID];
508 >
509 >  ConID := ConManager.FileOpened(Target);
510 >  if ConID >= 0 then
511    begin
512 <    TOniDataDat(OniDataConnection).UnloadWhenUnused := False;
512 >    if MessageBox(Self.Handle, PChar('Destination-file is opened, close it in ' +
513 >          'order to proceed conversion?'), PChar('Destination-file opened'),
514 >          MB_YESNO + MB_ICONQUESTION) = ID_YES then
515 >    begin
516 >      if Form_Main.CheckConnectionCloseable(ConID) then
517 >        if not ConManager.CloseConnection(ConID, ConRepMsg) then
518 >        begin
519 >          ShowMessage('Couldn''t close destination-file. Aborting');
520 >          Exit;
521 >        end;
522 >    end else begin
523 >      ShowMessage('Aborting');
524 >      Exit;
525 >    end;
526    end;
527  
528 <  timeformat.LongTimeFormat := 'hh:nn:ss';
529 <  timeformat.ShortTimeFormat := 'hh:nn:ss';
530 <  timeformat.TimeSeparator := ':';
528 >  if FileExists(Target) then
529 >  begin
530 >    if MessageBox(Self.Handle, PChar('Destination-file exists. ' +
531 >          'Overwrite it?'), PChar('Destination-file exists'),
532 >          MB_YESNO + MB_ICONWARNING) = ID_YES then
533 >    begin
534 >      if not DeleteFile(Target) then
535 >      begin
536 >        ShowMessage('Couldn''t delete file. Aborting');
537 >        Exit;
538 >      end;
539 >    end else begin
540 >      ShowMessage('Aborting');
541 >      Exit;
542 >    end;
543 >  end;
544  
545    Self.Visible := True;
546    Form_Main.Visible := False;
# Line 402 | Line 549 | begin
549    abort := False;
550    btn_abortok.Caption := '&Abort...';
551    btn_abortok.Default := False;
405  loaded_filename := target;
552  
553 <  absolutebegintime := Time;
553 >  BeginTime := Time;
554  
555    DataBase := TABSDatabase.Create(Self);
556 +  DataBase.MaxConnections := 1;
557 +  DataBase.PageSize := 8112;
558 +  DataBase.PageCountInExtent := 8;
559 +
560    DataBase.DatabaseName := 'OLDB';
561    DataBase.DatabaseFileName := target;
562    DataBase.CreateDatabase;
# Line 420 | Line 570 | begin
570    Query := TABSQuery.Create(Self);
571    Query.DatabaseName := 'OLDB';
572    Query.SQL.Text :=
573 <    'CREATE TABLE globals  ( id AUTOINC PRIMARY KEY, name STRING(128), value STRING(128) );';
573 >    'CREATE TABLE globals  ( id AUTOINC PRIMARY KEY, name STRING(128), ' +
574 >    'value STRING(128) );';
575    Query.ExecSQL;
576    Query.SQL.Text :=
577 <    'CREATE TABLE linkmap  ( id AUTOINC PRIMARY KEY, src_id INTEGER, src_link_offset INTEGER, target_id INTEGER );';
577 >    'CREATE TABLE linkmap  ( id AUTOINC PRIMARY KEY, src_id INTEGER, ' +
578 >    'src_link_offset INTEGER, target_id INTEGER);';
579 >  Query.ExecSQL;
580 >  Query.SQL.Text := 'CREATE INDEX idsrcid ON linkmap (src_id);';
581 >  Query.ExecSQL;
582 >  Query.SQL.Text := 'CREATE INDEX idtargetid ON linkmap (target_id);';
583    Query.ExecSQL;
584    Query.SQL.Text :=
585 <    'CREATE TABLE rawmap  ( id AUTOINC PRIMARY KEY, src_id INTEGER, src_link_offset INTEGER, sep BOOLEAN, size INTEGER, data BLOB BlobCompressionMode 9 BlobBlockSize 1024 BlobCompressionAlgorithm ZLib );';
585 >    'CREATE TABLE rawmap  ( id AUTOINC PRIMARY KEY, src_id INTEGER, ' +
586 >    'src_link_offset INTEGER, sep BOOLEAN, size INTEGER, ' +
587 >    'data BLOB BlobCompressionMode 9 BlobBlockSize 1024 BlobCompressionAlgorithm ZLib);';
588    //    Query.SQL.Text:='CREATE TABLE rawmap  ( id AUTOINC PRIMARY KEY, src_id INTEGER, src_link_offset INTEGER, size INTEGER, data BLOB BlobCompressionAlgorithm None );';
589    Query.ExecSQL;
590 <  Query.SQL.Text :=
433 <    '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 );';
434 <  //    Query.SQL.Text:='CREATE TABLE datfiles  ( id INTEGER PRIMARY KEY, extension CHAR(4), name STRING(128), contenttype INTEGER, size INTEGER, data BLOB BlobCompressionAlgorithm None );';
590 >  Query.SQL.Text := 'CREATE INDEX idsrcid ON rawmap (src_id);';
591    Query.ExecSQL;
592    Query.SQL.Text :=
593 <    'CREATE TABLE extlist  ( id AUTOINC PRIMARY KEY, ext CHAR(4), ident CHAR(16) );';
593 >    'CREATE TABLE datfiles  ( id INTEGER PRIMARY KEY, extension CHAR(4), ' +
594 >    'name STRING(128), contenttype INTEGER, size INTEGER, ' +
595 >    'data BLOB BlobCompressionMode 9 BlobBlockSize 1024 BlobCompressionAlgorithm ZLib );';
596 >  //    Query.SQL.Text:='CREATE TABLE datfiles  ( id INTEGER PRIMARY KEY, extension CHAR(4), name STRING(128), contenttype INTEGER, size INTEGER, data BLOB BlobCompressionAlgorithm None );';
597    Query.ExecSQL;
598 + //  Query.SQL.Text :=
599 + //    'CREATE TABLE extlist  ( id AUTOINC PRIMARY KEY, ext CHAR(4), ident CHAR(16) );';
600 + //  Query.ExecSQL;
601  
602    Query.SQL.Text := 'INSERT INTO globals (name,value) VALUES ("dbversion","' +
603      dbversion + '");';
604    Query.ExecSQL;
605 <  SetLength(Data, Length(OniDataConnection.LevelInfo.Ident));
444 <  for i := 0 to High(OniDataConnection.LevelInfo.Ident) do
445 <    Data[i] := OniDataConnection.LevelInfo.Ident[i];
446 <  temps := CreateHexString(Data, True);
447 <  Query.SQL.Text := 'INSERT INTO globals (name,value) VALUES ("ident","' + temps + '");';
448 <  Query.ExecSQL;
605 >
606    Query.SQL.Text := 'INSERT INTO globals (name,value) VALUES ("lvl","' +
607 <    IntToStr(OniDataConnection.LevelInfo.LevelNumber) + '");';
607 >    IntToStr(Connection.LevelNumber) + '");';
608    Query.ExecSQL;
609 <  if OniDataConnection.OSisMAC then
610 <    Query.SQL.Text := 'INSERT INTO globals (name,value) VALUES ("os","MAC");'
611 <  else
612 <    Query.SQL.Text := 'INSERT INTO globals (name,value) VALUES ("os","PC");';
613 <  Query.ExecSQL;
457 <
458 <  DoStep('Writing extensionslist');
459 <  progress.Max := Length(OniDataConnection.GetExtensionsList);
460 <  Application.ProcessMessages;
461 <
462 <  extlist := OniDataConnection.GetExtendedExtensionsList;
463 <  for i := 0 to High(extlist) do
464 <  begin
465 <    SetLength(Data, Length(extlist[i].Ident));
466 <    for j := 0 to High(extlist[i].Ident) do
467 <      Data[j] := extlist[i].Ident[j];
468 <    temps := CreateHexString(Data, True);
469 <    temps2 := extlist[i].Extension[3] + extlist[i].Extension[2] +
470 <      extlist[i].Extension[1] + extlist[i].Extension[0];
471 <    Query.SQL.Text := 'INSERT INTO extlist (ext,ident) VALUES ("' +
472 <      temps2 + '","' + temps + '");';
473 <    Query.ExecSQL;
474 <    progress.Position    := i;
475 <    lbl_progress.Caption := 'Extensions done: ' + IntToStr(i) + '/' +
476 <      IntToStr(Length(extlist));
477 <    Application.ProcessMessages;
478 <    if abort then
479 <    begin
480 <      stop_convert;
481 <      Exit;
482 <    end;
609 >  case Connection.DataOS of
610 >    DOS_WIN: temps := 'WIN';
611 >    DOS_WINDEMO: temps := 'WINDEMO';
612 >    DOS_MAC: temps := 'MAC';
613 >    DOS_MACBETA: temps := 'MACBETA';
614    end;
615 <  lbl_progress.Caption := '';
615 >  Query.SQL.Text := 'INSERT INTO globals (name,value) VALUES ("os","' + temps + '");';
616 >  Query.ExecSQL;
617  
618    progress.Position      := 0;
619    lbl_progress.Caption   := 'Files done: ' + IntToStr(0) + '/' + IntToStr(
620 <    OniDataConnection.GetFilesCount);
620 >    Connection.GetFileCount);
621    lbl_estimation.Caption := 'Estimated finishing time: unknown';
622  
623 <  DoStep('Loading .dat into memory');
492 <  Application.ProcessMessages;
493 <
494 <  progress.Max := OniDataConnection.GetFilesCount;
623 >  progress.Max := Connection.GetFileCount;
624    begintime    := Time;
625    DoStep('Writing .dat-fileslist');
626    Application.ProcessMessages;
627  
628 +  FileTime := Time;
629    Database.StartTransaction;
630 <  for i := 0 to OniDataConnection.GetFilesCount - 1 do
630 >  for FileID := 0 to Connection.GetFileCount - 1 do
631    begin
632 <    fileinfo := OniDataConnection.GetFileInfo(i);
632 >    fileinfo := Connection.GetFileInfo(FileID);
633      if (fileinfo.FileType and $02) = 0 then
634      begin
635        mimecoder := TStringFormat_MIME64.Create;
636 <      Data      := OniDataConnection.LoadDatFile(i);
636 >      Connection.LoadDatFile(FileID, tempdata);
637        Query.SQL.Text :=
638          'INSERT INTO datfiles (id,extension,name,contenttype,size,data) VALUES (' +
639 <        IntToStr(i) + ',"' + fileinfo.Extension + '","' + fileinfo.Name + '","' + IntToHex(
639 >        IntToStr(FileID) + ',"' + fileinfo.Extension + '","' + fileinfo.Name + '","' + IntToHex(
640          fileinfo.FileType, 8) + '",' + IntToStr(fileinfo.Size) + ',MimeToBin("' +
641 <        MimeCoder.StrTo(@Data[0], Length(Data)) + '") );';
641 >        MimeCoder.StrTo(@tempdata[0], Length(tempdata)) + '") );';
642        Query.ExecSQL;
643        mimecoder.Free;
644  
645 <      rawlist := OniDataConnection.GetRawList(i);
646 <      if Length(rawlist) > 0 then
645 >      RawLinks := Connection.GetRawList(FileID);
646 >      if Length(RawLinks) > 0 then
647        begin
648 <        for j := 0 to High(rawlist) do
648 >        for i := 0 to High(RawLinks) do
649          begin
650 <          if rawlist[j].raw_size > 0 then
650 >          if RawLinks[i].RawSize > 0 then
651            begin
652 <            SetLength(Data, rawlist[j].raw_size);
653 <            OniDataConnection.LoadRawFile(i, rawlist[j].src_offset, Data);
652 >            SetLength(tempdata, RawLinks[i].RawSize);
653 >            Connection.LoadRawFile(FileID, RawLinks[i].SrcOffset, tempdata);
654              mimecoder      := TStringFormat_MIME64.Create;
655              Query.SQL.Text :=
656                'INSERT INTO rawmap (src_id,src_link_offset,sep,size,data) VALUES (' +
657 <              IntToStr(i) + ',' + IntToStr(rawlist[j].src_offset) + ',' + BoolToStr(
658 <              rawlist[j].loc_sep) + ',' + IntToStr(rawlist[j].raw_size) + ',MimeToBin("' +
659 <              MimeCoder.StrTo(@Data[0], rawlist[j].raw_size) + '") );';
657 >              IntToStr(FileID) + ', ' + IntToStr(RawLinks[i].SrcOffset) + ',' +
658 >              BoolToStr(RawLinks[i].LocSep) + ', ' +
659 >              IntToStr(RawLinks[i].RawSize) + ', ' +
660 >              'MimeToBin("' + MimeCoder.StrTo(@tempdata[0], RawLinks[i].RawSize) + '") );';
661              Query.ExecSQL;
662              mimecoder.Free;
663            end
# Line 534 | Line 665 | begin
665            begin
666              Query.SQL.Text :=
667                'INSERT INTO rawmap (src_id,src_link_offset,sep,size) VALUES (' +
668 <              IntToStr(i) + ',' + IntToStr(rawlist[j].src_offset) + ',' + BoolToStr(rawlist[j].loc_sep) + ',0);';
668 >              IntToStr(FileID) + ', ' + IntToStr(RawLinks[i].SrcOffset) + ', ' +
669 >              BoolToStr(RawLinks[i].LocSep) + ', 0);';
670              Query.ExecSQL;
671            end;
672          end;
673        end;
674  
675 <      HandleFile(fileinfo.Extension, i, True);
675 >      DatLinks := Connection.GetDatLinks(FileID);
676 >      if Length(DatLinks) > 0 then
677 >      begin
678 >        for i := 0 to High(DatLinks) do
679 >        begin
680 >          Query.SQL.Text :=
681 >            'INSERT INTO linkmap (src_id, src_link_offset, target_id) VALUES (' +
682 >            IntToStr(FileID) + ', ' + IntToStr(DatLinks[i].SrcOffset) + ', ' +
683 >            IntToStr(DatLinks[i].DestID) + ');';
684 >          Query.ExecSQL;
685 >        end;
686 >      end;
687      end
688      else
689      begin
690        Query.SQL.Text :=
691          'INSERT INTO datfiles (id,extension,name,contenttype,size) VALUES (' +
692 <        IntToStr(i) + ',"' + fileinfo.Extension + '","' + fileinfo.Name + '","' + IntToHex(
693 <        fileinfo.FileType, 8) + '",0);';
692 >        IntToStr(FileID) + ', "' + fileinfo.Extension + '", ' +
693 >        '"' + fileinfo.Name + '", "' + IntToHex(fileinfo.FileType, 8) + '", 0);';
694        Query.ExecSQL;
695      end;
696 <    if ((i mod 100) = 0) and (i > 0) then
696 >    if ((FileID mod 100) = 0) and (FileID > 0) then
697      begin
698        Database.Commit(False);
699        Database.StartTransaction;
700      end;
701 <    if ((i mod 10) = 0) and (i >= 100) then
701 >    if ((FileID mod 10) = 0) and (FileID >= 100) then
702        lbl_estimation.Caption := 'Estimated time left: ' + TimeToStr(
703 <        (Time - begintime) / i * (progress.Max - i + 1) * 1.1, timeformat );
704 <    progress.Position := i;
705 <    lbl_progress.Caption := 'Files done: ' + IntToStr(i) + '/' + IntToStr(progress.Max);
703 >        (Time - FileTime) / FileID * (progress.Max - FileID + 1) * 1.1, timeformat );
704 >    progress.Position := FileID;
705 >    lbl_progress.Caption := 'Files done: ' + IntToStr(FileID) + '/' + IntToStr(progress.Max);
706      Application.ProcessMessages;
707      if abort then
708      begin
709 <      stop_convert;
709 >      StopConvert;
710        Exit;
711      end;
712    end;
# Line 572 | Line 715 | begin
715    lbl_progress.Caption   := 'Files done: ' + IntToStr(progress.Max) + '/' +
716      IntToStr(progress.Max);
717  
718 <  lbl_estimation.Caption := 'FINISHED (duration: ' + TimeToStr(Time - absolutebegintime, timeformat) + ')';
718 >  lbl_estimation.Caption := 'FINISHED (duration: ' + TimeToStr(Time - BeginTime, timeformat) + ')';
719  
720    DoStep('FIN');
721    btn_abortok.Caption := '&OK';
# Line 580 | Line 723 | begin
723  
724    converting := False;
725  
726 <  database.Close;
727 <  database.Free;
585 <
586 <  CloseDataConnection(DataConnections[conIndex]);
587 < end;
588 <
589 <
590 <
591 <
592 < procedure TForm_LevelDB.stop_convert;
593 < begin
594 <  btn_abortok.Caption := '&Close';
595 <  btn_abortok.Default := True;
596 <  converting := False;
597 <  lbl_estimation.Caption := 'ABORTED';
598 <  group_progress.Caption := 'Creating DB (ABORTED)';
726 >  Query.Close;
727 >  Query.Free;
728    DataBase.Close;
729 <  if MessageBox(Self.Handle, PChar('Delete the unfinished DB-file?'),
601 <    PChar('Delete file?'), MB_YESNO) = idYes then
602 <  begin
603 <    DeleteFile(loaded_filename);
604 <  end;
729 >  DataBase.Free;
730   end;
731  
732  
# Line 624 | Line 749 | begin
749   end;
750  
751  
627
628
629 procedure InsertDatLinkToDB(fileid: LongWord; offset: LongWord);
630 var
631  link: LongWord;
632 begin
633  OniDataConnection.LoadDatFilePart(fileid, offset, 4, @link);
634  if link = 0 then
635    link := $FFFFFFFF
636  else
637    link := link div 256;
638  Query.SQL.Text := 'INSERT INTO linkmap (src_id,src_link_offset,target_id) VALUES (' +
639    IntToStr(fileid) + ',' + IntToStr(offset) + ',' + IntToStr(link) + ');';
640  Query.ExecSQL;
641 end;
642
643
644
645
646 procedure AISA(fileid: LongWord; dir_dat2db: Boolean);
647 var
648  packages: Word;
649  i: LongWord;
650 begin
651  if dir_dat2db then
652  begin
653    OniDataConnection.LoadDatFilePart(fileid, $1E, 2, @packages);
654    if packages > 0 then
655    begin
656      for i := 0 to packages - 1 do
657        InsertDatLinkToDB(fileid, $20 + i * $160 + $28);
658      for i := 0 to packages - 1 do
659        InsertDatLinkToDB(fileid, $20 + i * $160 + $150);
660    end;
661  end
662  else
663  begin
664  end;
665 end;
666
667
668
669
670 procedure AKEV(fileid: LongWord; dir_dat2db: Boolean);
671 var
672  i: LongWord;
673 begin
674  if dir_dat2db then
675  begin
676    for i := 0 to 16 do
677      InsertDatLinkToDB(fileid, $8 + i * 4);
678  end
679  else
680  begin
681  end;
682 end;
683
684
685
686
687 procedure AKOT(fileid: LongWord; dir_dat2db: Boolean);
688 var
689  i: LongWord;
690 begin
691  if dir_dat2db then
692  begin
693    for i := 0 to 4 do
694      InsertDatLinkToDB(fileid, $8 + i * 4);
695  end
696  else
697  begin
698  end;
699 end;
700
701
702
703
704 procedure CBPI(fileid: LongWord; dir_dat2db: Boolean);
705 var
706  i: LongWord;
707 begin
708  if dir_dat2db then
709  begin
710    for i := 0 to 56 do
711      InsertDatLinkToDB(fileid, $8 + i * 4);
712  end
713  else
714  begin
715  end;
716 end;
717
718
719
720
721 procedure CBPM(fileid: LongWord; dir_dat2db: Boolean);
722 var
723  i: LongWord;
724 begin
725  if dir_dat2db then
726  begin
727    for i := 0 to 18 do
728      InsertDatLinkToDB(fileid, $8 + i * 4);
729  end
730  else
731  begin
732  end;
733 end;
734
735
736
737
738 procedure CONS(fileid: LongWord; dir_dat2db: Boolean);
739 var
740  i: LongWord;
741 begin
742  if dir_dat2db then
743  begin
744    for i := 0 to 1 do
745      InsertDatLinkToDB(fileid, $24 + i * 4);
746  end
747  else
748  begin
749  end;
750 end;
751
752
753
754
755 procedure CRSA(fileid: LongWord; dir_dat2db: Boolean);
756 var
757  packages: LongWord;
758  i: LongWord;
759 begin
760  if dir_dat2db then
761  begin
762    OniDataConnection.LoadDatFilePart(fileid, $14, 4, @packages);
763    if packages > 0 then
764      for i := 0 to packages - 1 do
765        InsertDatLinkToDB(fileid, $20 + i * 1100 + $A0);
766  end
767  else
768  begin
769  end;
770 end;
771
772
773
774
775 procedure DOOR(fileid: LongWord; dir_dat2db: Boolean);
776 begin
777  if dir_dat2db then
778  begin
779    InsertDatLinkToDB(fileid, $08);
780    InsertDatLinkToDB(fileid, $10);
781  end
782  else
783  begin
784  end;
785 end;
786
787
788
789
790 procedure DPGE(fileid: LongWord; dir_dat2db: Boolean);
791 begin
792  if dir_dat2db then
793  begin
794    InsertDatLinkToDB(fileid, $40);
795  end
796  else
797  begin
798  end;
799 end;
800
801
802
803
804 procedure HPGE(fileid: LongWord; dir_dat2db: Boolean);
805 begin
806  if dir_dat2db then
807  begin
808    InsertDatLinkToDB(fileid, $0C);
809  end
810  else
811  begin
812  end;
813 end;
814
815
816
817
818 procedure IGHH(fileid: LongWord; dir_dat2db: Boolean);
819 begin
820  if dir_dat2db then
821  begin
822    InsertDatLinkToDB(fileid, $24);
823    InsertDatLinkToDB(fileid, $28);
824  end
825  else
826  begin
827  end;
828 end;
829
830
831
832
833 procedure IGPA(fileid: LongWord; dir_dat2db: Boolean);
834 var
835  links: LongWord;
836  i:     LongWord;
837 begin
838  if dir_dat2db then
839  begin
840    OniDataConnection.LoadDatFilePart(fileid, $1C, 4, @links);
841    if links > 0 then
842      for i := 0 to links - 1 do
843        InsertDatLinkToDB(fileid, $20 + i * 4);
844  end
845  else
846  begin
847  end;
848 end;
849
850
851
852
853 procedure IGPG(fileid: LongWord; dir_dat2db: Boolean);
854 var
855  i: LongWord;
856 begin
857  if dir_dat2db then
858  begin
859    for i := 0 to 1 do
860      InsertDatLinkToDB(fileid, $1C + i * 4);
861  end
862  else
863  begin
864  end;
865 end;
866
867
868
869
870 procedure IGSA(fileid: LongWord; dir_dat2db: Boolean);
871 var
872  links: LongWord;
873  i:     LongWord;
874 begin
875  if dir_dat2db then
876  begin
877    OniDataConnection.LoadDatFilePart(fileid, $1C, 4, @links);
878    if links > 0 then
879      for i := 0 to links - 1 do
880        InsertDatLinkToDB(fileid, $20 + i * 4);
881  end
882  else
883  begin
884  end;
885 end;
886
887
888
889
890 procedure IMPT(fileid: LongWord; dir_dat2db: Boolean);
891 begin
892  if dir_dat2db then
893  begin
894    InsertDatLinkToDB(fileid, $10);
895  end
896  else
897  begin
898  end;
899 end;
900
901
902
903
904 procedure IPGE(fileid: LongWord; dir_dat2db: Boolean);
905 begin
906  if dir_dat2db then
907  begin
908    InsertDatLinkToDB(fileid, $0C);
909  end
910  else
911  begin
912  end;
913 end;
914
915
916
917
918 procedure KEYI(fileid: LongWord; dir_dat2db: Boolean);
919 var
920  i: LongWord;
921 begin
922  if dir_dat2db then
923  begin
924    for i := 0 to 9 do
925      InsertDatLinkToDB(fileid, $08 + i * 4);
926  end
927  else
928  begin
929  end;
930 end;
931
932
933
934
935 procedure M3GA(fileid: LongWord; dir_dat2db: Boolean);
936 var
937  links: LongWord;
938  i:     LongWord;
939 begin
940  if dir_dat2db then
941  begin
942    OniDataConnection.LoadDatFilePart(fileid, $1C, 4, @links);
943    if links > 0 then
944      for i := 0 to links - 1 do
945        InsertDatLinkToDB(fileid, $20 + i * 4);
946  end
947  else
948  begin
949  end;
950 end;
951
952
953
954
955 procedure M3GM(fileid: LongWord; dir_dat2db: Boolean);
956 var
957  i: LongWord;
958 begin
959  if dir_dat2db then
960  begin
961    for i := 0 to 6 do
962      InsertDatLinkToDB(fileid, $0C + i * 4);
963  end
964  else
965  begin
966  end;
967 end;
968
969
970
971
972 procedure MTRL(fileid: LongWord; dir_dat2db: Boolean);
973 begin
974  if dir_dat2db then
975  begin
976    InsertDatLinkToDB(fileid, $10);
977  end
978  else
979  begin
980  end;
981 end;
982
983
984
985
986 procedure OBDC(fileid: LongWord; dir_dat2db: Boolean);
987 var
988  packages: Word;
989  i: LongWord;
990 begin
991  if dir_dat2db then
992  begin
993    OniDataConnection.LoadDatFilePart(fileid, $1E, 2, @packages);
994    if packages > 0 then
995      for i := 0 to packages - 1 do
996        InsertDatLinkToDB(fileid, $20 + i * $18 + $4);
997  end
998  else
999  begin
1000  end;
1001 end;
1002
1003
1004
1005
1006 procedure OBOA(fileid: LongWord; dir_dat2db: Boolean);
1007 var
1008  packages: Word;
1009  i: LongWord;
1010 begin
1011  if dir_dat2db then
1012  begin
1013    OniDataConnection.LoadDatFilePart(fileid, $1E, 2, @packages);
1014    if packages > 0 then
1015      for i := 0 to packages - 1 do
1016      begin
1017        InsertDatLinkToDB(fileid, $20 + i * 240 + $0);
1018        InsertDatLinkToDB(fileid, $20 + i * 240 + $4);
1019        InsertDatLinkToDB(fileid, $20 + i * 240 + $8);
1020      end;
1021  end
1022  else
1023  begin
1024  end;
1025 end;
1026
1027
1028
1029
1030 procedure OFGA(fileid: LongWord; dir_dat2db: Boolean);
1031 var
1032  packages: LongWord;
1033  i: LongWord;
1034 begin
1035  if dir_dat2db then
1036  begin
1037    OniDataConnection.LoadDatFilePart(fileid, $1C, 4, @packages);
1038    if packages > 0 then
1039      for i := 0 to packages - 1 do
1040        InsertDatLinkToDB(fileid, $20 + i * 12 + $04);
1041  end
1042  else
1043  begin
1044  end;
1045 end;
1046
1047
1048
1049
1050 procedure ONCC(fileid: LongWord; dir_dat2db: Boolean);
1051 var
1052  i: LongWord;
1053 begin
1054  if dir_dat2db then
1055  begin
1056    InsertDatLinkToDB(fileid, $28);
1057    InsertDatLinkToDB(fileid, $434);
1058    InsertDatLinkToDB(fileid, $438);
1059    InsertDatLinkToDB(fileid, $43C);
1060    InsertDatLinkToDB(fileid, $C3C);
1061    InsertDatLinkToDB(fileid, $C40);
1062    InsertDatLinkToDB(fileid, $C44);
1063    InsertDatLinkToDB(fileid, $C48);
1064    InsertDatLinkToDB(fileid, $C88);
1065    InsertDatLinkToDB(fileid, $C8C);
1066  end
1067  else
1068  begin
1069  end;
1070 end;
1071
1072
1073
1074
1075 procedure ONCV(fileid: LongWord; dir_dat2db: Boolean);
1076 begin
1077  if dir_dat2db then
1078  begin
1079    InsertDatLinkToDB(fileid, $08);
1080  end
1081  else
1082  begin
1083  end;
1084 end;
1085
1086
1087
1088
1089 procedure ONLV(fileid: LongWord; dir_dat2db: Boolean);
1090 var
1091  i: LongWord;
1092 begin
1093  if dir_dat2db then
1094  begin
1095    for i := 0 to 5 do
1096      InsertDatLinkToDB(fileid, $48 + i * 4);
1097    for i := 0 to 5 do
1098      InsertDatLinkToDB(fileid, $64 + i * 4);
1099    InsertDatLinkToDB(fileid, $300);
1100  end
1101  else
1102  begin
1103  end;
1104 end;
1105
1106
1107
1108
1109 procedure ONOA(fileid: LongWord; dir_dat2db: Boolean);
1110 var
1111  packages: LongWord;
1112  i: LongWord;
1113 begin
1114  if dir_dat2db then
1115  begin
1116    OniDataConnection.LoadDatFilePart(fileid, $1C, 4, @packages);
1117    if packages > 0 then
1118      for i := 0 to packages - 1 do
1119        InsertDatLinkToDB(fileid, $20 + i * 8 + $04);
1120  end
1121  else
1122  begin
1123  end;
1124 end;
1125
1126
1127
1128
1129 procedure ONSK(fileid: LongWord; dir_dat2db: Boolean);
1130 begin
1131  if dir_dat2db then
1132  begin
1133    InsertDatLinkToDB(fileid, $08);
1134    InsertDatLinkToDB(fileid, $0C);
1135    InsertDatLinkToDB(fileid, $10);
1136    InsertDatLinkToDB(fileid, $14);
1137    InsertDatLinkToDB(fileid, $18);
1138    InsertDatLinkToDB(fileid, $20);
1139    InsertDatLinkToDB(fileid, $44);
1140  end
1141  else
1142  begin
1143  end;
1144 end;
1145
1146
1147
1148
1149 procedure ONVL(fileid: LongWord; dir_dat2db: Boolean);
1150 var
1151  packages: LongWord;
1152  i: LongWord;
1153 begin
1154  if dir_dat2db then
1155  begin
1156    OniDataConnection.LoadDatFilePart(fileid, $1C, 4, @packages);
1157    if packages > 0 then
1158      for i := 0 to packages - 1 do
1159        InsertDatLinkToDB(fileid, $20 + i * 4);
1160  end
1161  else
1162  begin
1163  end;
1164 end;
1165
1166
1167
1168
1169 procedure ONWC(fileid: LongWord; dir_dat2db: Boolean);
1170 begin
1171  if dir_dat2db then
1172  begin
1173    InsertDatLinkToDB(fileid, $28);
1174    InsertDatLinkToDB(fileid, $34);
1175    InsertDatLinkToDB(fileid, $40);
1176    InsertDatLinkToDB(fileid, $54);
1177    InsertDatLinkToDB(fileid, $58);
1178    InsertDatLinkToDB(fileid, $5C);
1179    InsertDatLinkToDB(fileid, $60);
1180    InsertDatLinkToDB(fileid, $6FC);
1181    InsertDatLinkToDB(fileid, $700);
1182  end
1183  else
1184  begin
1185  end;
1186 end;
1187
1188
1189
1190
1191 procedure OPGE(fileid: LongWord; dir_dat2db: Boolean);
1192 begin
1193  if dir_dat2db then
1194  begin
1195    InsertDatLinkToDB(fileid, $0C);
1196  end
1197  else
1198  begin
1199  end;
1200 end;
1201
1202
1203
1204
1205 procedure PSPC(fileid: LongWord; dir_dat2db: Boolean);
1206 begin
1207  if dir_dat2db then
1208  begin
1209    InsertDatLinkToDB(fileid, $50);
1210  end
1211  else
1212  begin
1213  end;
1214 end;
1215
1216
1217
1218
1219 procedure PSPL(fileid: LongWord; dir_dat2db: Boolean);
1220 var
1221  packages: LongWord;
1222  i: LongWord;
1223 begin
1224  if dir_dat2db then
1225  begin
1226    OniDataConnection.LoadDatFilePart(fileid, $1C, 4, @packages);
1227    if packages > 0 then
1228      for i := 0 to packages - 1 do
1229        InsertDatLinkToDB(fileid, $20 + i * 8 + $4);
1230  end
1231  else
1232  begin
1233  end;
1234 end;
1235
1236
1237
1238
1239 procedure PSUI(fileid: LongWord; dir_dat2db: Boolean);
1240 var
1241  i: LongWord;
1242 begin
1243  if dir_dat2db then
1244  begin
1245    for i := 0 to 43 do
1246      InsertDatLinkToDB(fileid, $08 + i * 4);
1247  end
1248  else
1249  begin
1250  end;
1251 end;
1252
1253
1254
1255
1256 procedure STNA(fileid: LongWord; dir_dat2db: Boolean);
1257 var
1258  packages: Word;
1259  i: LongWord;
1260 begin
1261  if dir_dat2db then
1262  begin
1263    OniDataConnection.LoadDatFilePart(fileid, $1E, 2, @packages);
1264    if packages > 0 then
1265      for i := 0 to packages - 1 do
1266        InsertDatLinkToDB(fileid, $20 + i * 4);
1267  end
1268  else
1269  begin
1270  end;
1271 end;
1272
1273
1274
1275
1276 procedure TRAC(fileid: LongWord; dir_dat2db: Boolean);
1277 var
1278  packages: Word;
1279  i: LongWord;
1280 begin
1281  if dir_dat2db then
1282  begin
1283    InsertDatLinkToDB(fileid, $18);
1284    OniDataConnection.LoadDatFilePart(fileid, $1E, 2, @packages);
1285    if packages > 0 then
1286      for i := 0 to packages - 1 do
1287        InsertDatLinkToDB(fileid, $20 + i * 12 + 8);
1288  end
1289  else
1290  begin
1291  end;
1292 end;
1293
1294
1295
1296
1297 procedure TRAM(fileid: LongWord; dir_dat2db: Boolean);
1298 begin
1299  if dir_dat2db then
1300  begin
1301    InsertDatLinkToDB(fileid, $40);
1302    InsertDatLinkToDB(fileid, $44);
1303  end
1304  else
1305  begin
1306  end;
1307 end;
1308
1309
1310
1311
1312 procedure TRAS(fileid: LongWord; dir_dat2db: Boolean);
1313 begin
1314  if dir_dat2db then
1315  begin
1316    InsertDatLinkToDB(fileid, $08);
1317  end
1318  else
1319  begin
1320  end;
1321 end;
1322
1323
1324
1325
1326 procedure TRBS(fileid: LongWord; dir_dat2db: Boolean);
1327 var
1328  i: LongWord;
1329 begin
1330  if dir_dat2db then
1331  begin
1332    for i := 0 to 4 do
1333      InsertDatLinkToDB(fileid, $08 + i * 4);
1334  end
1335  else
1336  begin
1337  end;
1338 end;
1339
1340
1341
1342
1343 procedure TRCM(fileid: LongWord; dir_dat2db: Boolean);
1344 var
1345  i: LongWord;
1346 begin
1347  if dir_dat2db then
1348  begin
1349    for i := 0 to 2 do
1350      InsertDatLinkToDB(fileid, $5C + i * 4);
1351  end
1352  else
1353  begin
1354  end;
1355 end;
1356
1357
1358
1359
1360 procedure TRGA(fileid: LongWord; dir_dat2db: Boolean);
1361 var
1362  i: LongWord;
1363  packages: Word;
1364 begin
1365  if dir_dat2db then
1366  begin
1367    OniDataConnection.LoadDatFilePart(fileid, $1E, 2, @packages);
1368    if packages > 0 then
1369      for i := 0 to packages - 1 do
1370        InsertDatLinkToDB(fileid, $20 + i * 4);
1371  end
1372  else
1373  begin
1374  end;
1375 end;
1376
1377
1378
1379
1380 procedure TRGE(fileid: LongWord; dir_dat2db: Boolean);
1381 begin
1382  if dir_dat2db then
1383  begin
1384    InsertDatLinkToDB(fileid, $20);
1385  end
1386  else
1387  begin
1388  end;
1389 end;
1390
1391
1392
1393
1394 procedure TRIG(fileid: LongWord; dir_dat2db: Boolean);
1395 begin
1396  if dir_dat2db then
1397  begin
1398    InsertDatLinkToDB(fileid, $18);
1399    InsertDatLinkToDB(fileid, $24);
1400    InsertDatLinkToDB(fileid, $28);
1401  end
1402  else
1403  begin
1404  end;
1405 end;
1406
1407
1408
1409
1410 procedure TRMA(fileid: LongWord; dir_dat2db: Boolean);
1411 var
1412  i: LongWord;
1413  packages: Word;
1414 begin
1415  if dir_dat2db then
1416  begin
1417    OniDataConnection.LoadDatFilePart(fileid, $1E, 2, @packages);
1418    if packages > 0 then
1419      for i := 0 to packages - 1 do
1420        InsertDatLinkToDB(fileid, $20 + i * 4);
1421  end
1422  else
1423  begin
1424  end;
1425 end;
1426
1427
1428
1429
1430 procedure TRSC(fileid: LongWord; dir_dat2db: Boolean);
1431 var
1432  i: LongWord;
1433  packages: Word;
1434 begin
1435  if dir_dat2db then
1436  begin
1437    OniDataConnection.LoadDatFilePart(fileid, $1E, 2, @packages);
1438    if packages > 0 then
1439      for i := 0 to packages - 1 do
1440        InsertDatLinkToDB(fileid, $20 + i * 4);
1441  end
1442  else
1443  begin
1444  end;
1445 end;
1446
1447
1448
1449
1450 procedure TSFF(fileid: LongWord; dir_dat2db: Boolean);
1451 var
1452  i: LongWord;
1453  packages: LongWord;
1454 begin
1455  if dir_dat2db then
1456  begin
1457    OniDataConnection.LoadDatFilePart(fileid, $1C, 4, @packages);
1458    if packages > 0 then
1459      for i := 0 to packages - 1 do
1460        InsertDatLinkToDB(fileid, $20 + i * 4);
1461  end
1462  else
1463  begin
1464  end;
1465 end;
1466
1467
1468
1469
1470 procedure TSFT(fileid: LongWord; dir_dat2db: Boolean);
1471 begin
1472  if dir_dat2db then
1473  begin
1474    InsertDatLinkToDB(fileid, $1C);
1475  end
1476  else
1477  begin
1478  end;
1479 end;
1480
1481
1482
1483
1484 procedure TURR(fileid: LongWord; dir_dat2db: Boolean);
1485 begin
1486  if dir_dat2db then
1487  begin
1488    InsertDatLinkToDB(fileid, $60);
1489    InsertDatLinkToDB(fileid, $6C);
1490    InsertDatLinkToDB(fileid, $74);
1491  end
1492  else
1493  begin
1494  end;
1495 end;
1496
1497
1498
1499
1500 procedure TXAN(fileid: LongWord; dir_dat2db: Boolean);
1501 var
1502  i: LongWord;
1503  packages: LongWord;
1504 begin
1505  if dir_dat2db then
1506  begin
1507    OniDataConnection.LoadDatFilePart(fileid, $1C, 4, @packages);
1508    if packages > 0 then
1509      for i := 0 to packages - 1 do
1510        InsertDatLinkToDB(fileid, $20 + i * 4);
1511  end
1512  else
1513  begin
1514  end;
1515 end;
1516
1517
1518
1519
1520 procedure TXMA(fileid: LongWord; dir_dat2db: Boolean);
1521 var
1522  i: LongWord;
1523  packages: LongWord;
1524 begin
1525  if dir_dat2db then
1526  begin
1527    OniDataConnection.LoadDatFilePart(fileid, $1C, 4, @packages);
1528    if packages > 0 then
1529      for i := 0 to packages - 1 do
1530        InsertDatLinkToDB(fileid, $20 + i * 4);
1531  end
1532  else
1533  begin
1534  end;
1535 end;
1536
1537
1538
1539
1540 procedure TXMB(fileid: LongWord; dir_dat2db: Boolean);
1541 var
1542  i: LongWord;
1543  packages: LongWord;
1544 begin
1545  if dir_dat2db then
1546  begin
1547    OniDataConnection.LoadDatFilePart(fileid, $1C, 4, @packages);
1548    if packages > 0 then
1549      for i := 0 to packages - 1 do
1550        InsertDatLinkToDB(fileid, $20 + i * 4);
1551  end
1552  else
1553  begin
1554  end;
1555 end;
1556
1557
1558
1559
1560 procedure TXMP(fileid: LongWord; dir_dat2db: Boolean);
1561 begin
1562  if dir_dat2db then
1563  begin
1564    InsertDatLinkToDB(fileid, $94);
1565    InsertDatLinkToDB(fileid, $98);
1566  end
1567  else
1568  begin
1569  end;
1570 end;
1571
1572
1573
1574
1575 procedure TXTC(fileid: LongWord; dir_dat2db: Boolean);
1576 begin
1577  if dir_dat2db then
1578  begin
1579    InsertDatLinkToDB(fileid, $08);
1580  end
1581  else
1582  begin
1583  end;
1584 end;
1585
1586
1587
1588
1589 procedure WMCL(fileid: LongWord; dir_dat2db: Boolean);
1590 var
1591  i: LongWord;
1592  packages: LongWord;
1593 begin
1594  if dir_dat2db then
1595  begin
1596    OniDataConnection.LoadDatFilePart(fileid, $1C, 4, @packages);
1597    if packages > 0 then
1598      for i := 0 to packages - 1 do
1599        InsertDatLinkToDB(fileid, $20 + i * 8 + $4);
1600  end
1601  else
1602  begin
1603  end;
1604 end;
1605
1606
1607
1608
1609 procedure WMDD(fileid: LongWord; dir_dat2db: Boolean);
1610 var
1611  i: LongWord;
1612  packages: LongWord;
1613 begin
1614  if dir_dat2db then
1615  begin
1616    OniDataConnection.LoadDatFilePart(fileid, $11C, 4, @packages);
1617    if packages > 0 then
1618      for i := 0 to packages - 1 do
1619        InsertDatLinkToDB(fileid, $120 + i * $124 + $114);
1620  end
1621  else
1622  begin
1623  end;
1624 end;
1625
1626
1627
1628
1629 procedure WMMB(fileid: LongWord; dir_dat2db: Boolean);
1630 var
1631  i: LongWord;
1632  packages: LongWord;
1633 begin
1634  if dir_dat2db then
1635  begin
1636    OniDataConnection.LoadDatFilePart(fileid, $1C, 4, @packages);
1637    if packages > 0 then
1638      for i := 0 to packages - 1 do
1639        InsertDatLinkToDB(fileid, $20 + i * 4);
1640  end
1641  else
1642  begin
1643  end;
1644 end;
1645
1646
1647
1648
1649 procedure WPGE(fileid: LongWord; dir_dat2db: Boolean);
1650 begin
1651  if dir_dat2db then
1652  begin
1653    InsertDatLinkToDB(fileid, $08);
1654    InsertDatLinkToDB(fileid, $0C);
1655  end
1656  else
1657  begin
1658  end;
1659 end;
1660
1661
1662
1663
1664 procedure InsertHandler(ext: String; needed: Boolean; handler: THandler);
1665 begin
1666  SetLength(ConvertHandlers, Length(ConvertHandlers) + 1);
1667  ConvertHandlers[High(ConvertHandlers)].Ext     := ext;
1668  ConvertHandlers[High(ConvertHandlers)].needed  := needed;
1669  ConvertHandlers[High(ConvertHandlers)].handler := handler;
1670 end;
1671
1672 begin
1673  InsertHandler('ABNA', False, nil);
1674  //  InsertHandler('AGDB',True,AGDB);
1675  InsertHandler('AGDB', False, nil);
1676  InsertHandler('AGQC', False, nil);
1677  InsertHandler('AGQG', False, nil);
1678  InsertHandler('AGQR', False, nil);
1679  InsertHandler('AISA', True, AISA);
1680  InsertHandler('AITR', False, nil);
1681  InsertHandler('AKAA', False, nil);
1682  InsertHandler('AKBA', False, nil);
1683  InsertHandler('AKBP', False, nil);
1684  InsertHandler('AKDA', False, nil);
1685  InsertHandler('AKEV', True, AKEV);
1686  InsertHandler('AKOT', True, AKOT);
1687  InsertHandler('AKVA', False, nil);
1688  InsertHandler('BINA', False, nil);
1689  InsertHandler('CBPI', True, CBPI);
1690  InsertHandler('CBPM', True, CBPM);
1691  InsertHandler('CONS', True, CONS);
1692  InsertHandler('CRSA', True, CRSA);
1693  InsertHandler('DOOR', True, DOOR);
1694  InsertHandler('DPGE', True, DPGE);
1695  InsertHandler('ENVP', False, nil);
1696  InsertHandler('FILM', False, nil);
1697  InsertHandler('HPGE', True, HPGE);
1698  InsertHandler('IDXA', False, nil);
1699  InsertHandler('IGHH', True, IGHH);
1700  InsertHandler('IGPA', True, IGPA);
1701  InsertHandler('IGPG', True, IGPG);
1702  InsertHandler('IGSA', True, IGSA);
1703  InsertHandler('IMPT', True, IMPT);
1704  InsertHandler('IPGE', True, IPGE);
1705  InsertHandler('KEYI', True, KEYI);
1706  InsertHandler('M3GA', True, M3GA);
1707  InsertHandler('M3GM', True, M3GM);
1708  InsertHandler('MTRL', True, MTRL);
1709  InsertHandler('OBAN', False, nil);
1710  InsertHandler('OBDC', True, OBDC);
1711  InsertHandler('OBOA', True, OBOA);
1712  InsertHandler('OFGA', True, OFGA);
1713  InsertHandler('ONCC', True, ONCC);
1714  InsertHandler('ONCP', False, nil);
1715  InsertHandler('ONCV', True, ONCV);
1716  InsertHandler('ONFA', False, nil);
1717  InsertHandler('ONGS', False, nil);
1718  InsertHandler('ONIA', False, nil);
1719  InsertHandler('ONLD', False, nil);
1720  InsertHandler('ONLV', True, ONLV);
1721  InsertHandler('ONMA', False, nil);
1722  InsertHandler('ONOA', True, ONOA);
1723  InsertHandler('ONSA', False, nil);
1724  InsertHandler('ONSK', True, ONSK);
1725  InsertHandler('ONTA', False, nil);
1726  InsertHandler('ONVL', True, ONVL);
1727  InsertHandler('ONWC', True, ONWC);
1728  InsertHandler('OPGE', True, OPGE);
1729  InsertHandler('OSBD', False, nil);
1730  InsertHandler('OTIT', False, nil);
1731  InsertHandler('OTLF', False, nil);
1732  InsertHandler('PLEA', False, nil);
1733  InsertHandler('PNTA', False, nil);
1734  InsertHandler('PSPC', True, PSPC);
1735  InsertHandler('PSPL', True, PSPL);
1736  InsertHandler('PSUI', True, PSUI);
1737  InsertHandler('QTNA', False, nil);
1738  InsertHandler('SNDD', False, nil);
1739  InsertHandler('STNA', True, STNA);
1740  InsertHandler('SUBT', False, nil);
1741  InsertHandler('TRAC', True, TRAC);
1742  InsertHandler('TRAM', True, TRAM);
1743  InsertHandler('TRAS', True, TRAS);
1744  InsertHandler('TRBS', True, TRBS);
1745  InsertHandler('TRCM', True, TRCM);
1746  InsertHandler('TRGA', True, TRGA);
1747  InsertHandler('TRGE', True, TRGE);
1748  InsertHandler('TRIA', False, nil);
1749  InsertHandler('TRIG', True, TRIG);
1750  InsertHandler('TRMA', True, TRMA);
1751  InsertHandler('TRSC', True, TRSC);
1752  InsertHandler('TRTA', False, nil);
1753  InsertHandler('TSFF', True, TSFF);
1754  InsertHandler('TSFL', False, nil);
1755  InsertHandler('TSFT', True, TSFT);
1756  InsertHandler('TSGA', False, nil);
1757  InsertHandler('TSTR', False, nil);
1758  InsertHandler('TURR', True, TURR);
1759  InsertHandler('TXAN', True, TXAN);
1760  InsertHandler('TXCA', False, nil);
1761  InsertHandler('TXMA', True, TXMA);
1762  InsertHandler('TXMB', True, TXMB);
1763  InsertHandler('TXMP', True, TXMP);
1764  InsertHandler('TXTC', True, TXTC);
1765  InsertHandler('VCRA', False, nil);
1766  InsertHandler('WMCL', True, WMCL);
1767  InsertHandler('WMDD', True, WMDD);
1768  InsertHandler('WMM_', False, nil);
1769  InsertHandler('WMMB', True, WMMB);
1770  InsertHandler('WPGE', True, WPGE);
752   end.

Diff Legend

Removed lines
+ Added lines
< Changed lines (old)
> Changed lines (new)