{$INCLUDE ../shared/a_modes.inc}
uses
- Forms, Interfaces,
- GL, GLExt,
+ Forms, Interfaces, Dialogs,
+ GL, GLExt, SysUtils,
e_graphics in '../engine/e_graphics.pas',
e_log in '../engine/e_log.pas',
e_textures in '../engine/e_textures.pas',
{$R *.res}
{$ENDIF}
+ type
+ THandlerObject = class (TObject)
+ procedure ExceptionHandler (Sender: TObject; e: Exception);
+ end;
+
+ var
+ H: THandlerObject;
+
+ procedure THandlerObject.ExceptionHandler (Sender: TObject; e: Exception);
+ begin
+ e_WriteStackTrace(e.message);
+ MessageDlg('Unhandled exception: ' + e.message + ' (see Editor.log for more information)', mtError, [mbOK], 0);
+ end;
+
begin
Application.ExceptionDialog := aedOkMessageBox;
+ Application.AddOnExceptionHandler(H.ExceptionHandler, True);
Application.Initialize();
Application.CreateForm(TMainForm, MainForm);
for i := 0 to list.Count - 1 do
begin
- writeln('GetMap "' + list.Files[i].path + '" "' + list.Files[i].name + '"');
g_ReadResource(FileName, list.Files[i].path, list.Files[i].name, data, len);
if len >= 3 then
begin
len := stream.Size;
GetMem(data, len);
+ ASSERT(data <> nil);
//stream.ReadBuffer(data, len); (* leads to segfault *)
for i := 0 to len - 1 do
data[i] := stream.ReadByte();
begin
len := stream1.Size;
GetMem(data, len);
+ ASSERT(data <> nil);
//stream1.ReadBuffer(data, len); (* leads to segfault *)
for i := 0 to len - 1 do
data[i] := stream1.ReadByte();
procedure e_InitLog(fFileName: String; fWriteMode: TWriteMode);
procedure e_WriteLog(TextLine: String; RecordCategory: TRecordCategory;
WriteTime: Boolean = True);
+procedure e_WriteStackTrace (const msg: AnsiString);
function DecodeIPV4(ip: LongWord): string;
implementation
Close(LogFile);
end;
+{$I-}
+procedure e_WriteStackTrace (const msg: AnsiString);
+ var LogFile: TextFile;
+begin
+ e_WriteLog(msg, TRecordCategory.MSG_FATALERROR);
+
+ Assign(LogFile, FileName);
+ if FileExists(FileName) then
+ Append(LogFile)
+ else
+ Rewrite(LogFile);
+
+ writeln(LogFile, '=====================');
+ DumpExceptionBackTrace(LogFile);
+
+ Close(LogFile);
+end;
+
procedure e_InitLog(fFileName: String; fWriteMode: TWriteMode);
begin
FileName := fFileName;