Test suite results for test file tbs/tb0157.pp

Test run data :

Run ID:
Operating system: linux
Processor: powerpc64
Version: 3.2.3
Fails/OK/Total: 96/7878/7974
Version: 3.2.3
Full version: 3.2.3-1374-g849fbd722c-unpushed
Comment: -gwlttt -CriotR -O- -Fl/usr/lib/gcc/powerpc64-linux-gnu/13 -Fd
Machine: gcc203
Category: 1
SVN revisions: fdf93c5b29:849fbd722c:ae0fe8a6a0:d1c29e6cb9
Submitter: pierre
Date: 2024/04/19 10:26:00 <> 2024/04/10
Previous run: 933748
Next run: 936279

Hide skipped tests

Hide successful tests

Test file "tbs/tb0157.pp" information:

t_id 396
t_adddate 2003/10/03
t_result 0
t_knownrunerror 0

Detailed test run results:

tr_idruntr_oktr_skiptr_result
443548075934947TrueFalseSuccessfully run

Record count: 1

No log of 934947.

Source:

{ Old file: tbs0188.pp }
{ can't print function result of procedural var that returns a function. Not a bugs : wrong syntax !! See source (PM) }

{ this are no bugs, just wrong
  understanding of FPC syntax }

type testfunc = function:longint;

var f : testfunc;

var test: testfunc;

function test_temp: longint;
begin
  test_temp:=12;
end;

procedure sound(test: testfunc);
begin
  {writeln(test); this is wrong because
   test is the function itself and write does not know how to
   output a function !
   to call test you must use test() !! }
  writeln(test());
end; { proc. sound }

var i : longint;
begin
  i:=test_temp;
  f:=@test_temp;
  if f()<>i then
    begin
       Writeln('error calling f');
       Halt(1);
    end;

  { this works for FPC
   sound(test_temp);
  but the correct syntax would be }
  sound(@test_temp);
  { imagine if a function would return its own type !! }

  { for f var this is correct also ! }
  sound(f);
end.

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