Test suite results for test file webtbs/tw3778.pp

Test run data :

Run ID:
Operating system: linux
Processor: mips
Version: 3.2.3
Fails/OK/Total: 48/7923/7971
Version: 3.2.3
Full version: 3.2.3-1373-gae0fe8a6a0
Comment: -ao-xgot -fPIC -XR/home/pierre/sys-root/mips-linux -Xd -Xr/home/pierre/sys-root/mips-linux
Machine: gcclocal
Category: 1
SVN revisions: fdf93c5b29:c17a0e20f5:ae0fe8a6a0:d1c29e6cb9
Submitter: pierre
Date: 2024/04/19 10:56:00 <> 2024/04/09
Previous run: 934299
Next run: 935637

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
443630514934958TrueFalseSuccessfully run

Record count: 1

No log of 934958.

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.