Test suite results for test file tbs/tb0263.pp

Test run data :

Run ID:
Operating system: linux
Processor: i386
Version: 3.3.1
Fails/OK/Total: 24/9637/9661
Version: 3.3.1
Full version: 3.3.1-15677-g5e00358f13
Comment: -gl -Fl/lib32 -Fl/usr/lib32 -Fl/usr/lib/gcc/x86_64-linux-gnu/10/32 -Fl/home/muller/sys-root/i386-linux/lib -Fl/home/muller/sys-root/i386-linux/usr/lib -O2 -Fd
Machine: gcc186
Category: 1
SVN revisions: 5e00358f13:d6cf3c98d0:e657d6a07d:485b31de21
Submitter: pierre
Date: 2024/05/09 01:31:00 <> 2024/05/08
Previous run: 947713
Next run: 949015

Hide skipped tests

Hide successful tests

Test file "tbs/tb0263.pp" information:

t_id 491
t_adddate 2003/10/03
t_result 217
t_knownrunerror 0

Detailed test run results:

tr_idruntr_oktr_skiptr_result
526517856948361TrueFalseSuccessfully run

Record count: 1

No log of 948361.

Source:

{ %RESULT=217 }

{ Old file: tbs0306.pp }
{ Address is not popped with exit in try...except block OK 0.99.13 (PFV) }

{$MODE objfpc}
{$H+}

{
   Don't forget break,continue support
}

program stackcrash;
uses sysutils;
type
  TMyClass = class
  public
    procedure Proc1;
    procedure Proc2;
  end;

procedure TMyClass.Proc1;
var
  x, y: Integer;
begin
  try
    exit;
  except
    on e: Exception do begin e.Message := '[Proc1]' + e.Message; raise e end;
  end;
end;

procedure TMyClass.Proc2;
var
  x: array[0..7] of Byte;
  crash: Boolean;
begin
  crash := True;        // <--- ! This corrupts the stack?!?
  raise Exception.Create('I will crash now...');
end;

var
  obj: TMyClass;
begin
  obj := TMyClass.Create;
  obj.Proc1;
  WriteLn('Proc1 done, calling Proc2...');
  obj.Proc2;
  WriteLn('Proc2 done');
end.

Link to SVN view of tbs/tb0263.pp source.