Test suite results for test file tbs/tb0252.pp

Test run data :

Run ID:
Operating system: solaris
Processor: sparc
Version: 3.3.1
Fails/OK/Total: 57/9104/9161
Version: 3.3.1
Full version: 3.3.1-15627-g64f2e4b-unpushed
Comment: -Agas -Cg -Fd
Machine: unstable10s
Category: 1
SVN revisions: e601156:d3fd0b8:64f2e4b:6a10963
Submitter: pierre
Date: 2024/04/28 12:53:00
Previous run: 940458
Next run: 941965

Hide skipped tests

Hide successful tests

Test file "tbs/tb0252.pp" information:

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

Detailed test run results:

tr_idruntr_oktr_skiptr_result
482409206941218TrueFalseSuccessfully run

Record count: 1

No log of 941218.

Source:

{ Old file: tbs0292.pp }
{ objects not finalized when disposed                  OK 0.99.13 (FK) }

{$mode objfpc}

type
  pobj = ^tobj;
  tobj = object
    a: ansistring;
    constructor init(s: ansistring);
    destructor done;
  end;

  PAnsiRec = ^TAnsiRec;
  TAnsiRec = Packed Record
    Maxlen,
    len,
    ref   : Longint;
    First : Char;
  end;

const firstoff = sizeof(tansirec)-1;

var o: pobj;
    t: ansistring;

constructor tobj.init(s: ansistring);
begin
  a := s;
end;

destructor tobj.done;
begin
end;

const
  s : string = ' with suffix';
var
  refbefore : longint;
begin
  t:='test'+s;
  refbefore:=pansirec(pointer(t)-firstoff)^.ref;
  writeln('refcount before init: ',pansirec(pointer(t)-firstoff)^.ref);
  new(o,init(t));
  writeln('refcount after init: ',pansirec(pointer(t)-firstoff)^.ref);
  dispose(o,done);
  writeln('refcount after done: ',pansirec(pointer(t)-firstoff)^.ref);
  if refbefore<>pansirec(pointer(t)-firstoff)^.ref then
    Halt(1);
end.

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