Test suite results for test file webtbs/tw3778.pp

Test run data :

Run ID:
Operating system: linux
Processor: i386
Version: 3.3.1
Fails/OK/Total: 240/9415/9655
Version: 3.3.1
Full version: 3.3.1-15584-g2f9ed0576e
Comment: -XR/home/muller/sys-root/i386-linux -Xd -Xr/home/muller/sys-root/i386-linux
Machine: cfarm421
Category: 1
SVN revisions: 2f9ed0576e:8b7dbb81b1:3f8bbd3b00:2f9ed0576e
Submitter: muller
Date: 2024/04/19 11:07:00 <> 2024/04/18
Previous run: 934323
Next run: 935660

Hide skipped tests

Hide successful tests

Test file "webtbs/tw3778.pp" information:

t_id 1550
t_adddate 2005/04/06
t_result 0
t_knownrunerror 0

Detailed test run results:

tr_idruntr_oktr_skiptr_result
443685027934969TrueFalseSuccessfully run

Record count: 1

No log of 934969.

Source:

{ Source provided for Free Pascal Bug Report 3778 }
{ Submitted by "David Fuchs" on  2005-03-13 }
{ e-mail: drfuchs@yahoo.com }

{$mode objfpc}

type
  a_class=class
    procedure a_method;
    function a_virtual_method:a_class; virtual;
    end;
  a_container=class
    a_field:a_class;
    end;

var
  already_called: boolean;
  glob: a_class;
  container_array: array[0..255] of a_container;
        error : boolean;

function a_function:byte;
begin
  if already_called then
    begin
      writeln('This can not possibly happen!');
      error:=true;
    end;
  a_function:=255;
  already_called:=true;
end;

function a_class.a_virtual_method:a_class;
begin
  a_virtual_method:=self;
end;

procedure a_class.a_method;
begin
  {this statement somehow compiles into TWO calls to a_function!}
  glob:=container_array[a_function].a_field.a_virtual_method;
end;

begin
        already_called:=false;
        glob:=a_class.create;
        container_array[255]:=a_container.create;
        container_array[255].a_field:=glob;
        glob.a_method;
        if error then
          halt(1);
end.

Link to SVN view of webtbs/tw3778.pp source.