* Test for default of property override: default of parent must be preserved

git-svn-id: trunk@12117 -
This commit is contained in:
michael 2008-11-15 22:35:36 +00:00
parent 11a41788fb
commit ea29eb439f
2 changed files with 49 additions and 0 deletions

1
.gitattributes vendored
View File

@ -7136,6 +7136,7 @@ tests/tbs/tb0553.pp svneol=native#text/plain
tests/tbs/tb0554.pp svneol=native#text/plain
tests/tbs/tb0555.pp svneol=native#text/plain
tests/tbs/tb0556.pp svneol=native#text/plain
tests/tbs/tb0557.pp svneol=native#text/plain
tests/tbs/tb205.pp svneol=native#text/plain
tests/tbs/ub0060.pp svneol=native#text/plain
tests/tbs/ub0069.pp svneol=native#text/plain

48
tests/tbs/tb0557.pp Normal file
View File

@ -0,0 +1,48 @@
program rtti;
{$ifdef fpc}
{$mode objfpc}{$H+}
{$apptype console}
{$endif}
uses
{$IFDEF UNIX}{$IFDEF UseCThreads}
cthreads,
{$ENDIF}{$ENDIF}
Classes, typinfo
{ you can add units after this };
type
{ TSomeBaseClass }
TSomeBaseClass = class(TPersistent)
private
FSomeProperty: Integer;
public
property SomeProperty: Integer read FSomeProperty write FSomeProperty default 10;
end;
{ TSomeDerivedClass }
TSomeDerivedClass = class(TSomeBaseClass)
private
FOwnProperty: Integer;
published
property SomeProperty;
property OwnProperty: Integer read FOwnProperty write FOwnProperty default 11;
end;
var
BC : TSomeBaseClass;
DC: TSomeDerivedClass;
Info: PPropInfo;
begin
DC := TSomeDerivedClass.Create;
Info := GetPropInfo(DC, 'SomeProperty');
if (Info^.Default<>10) then
Halt(1);
Info := GetPropInfo(DC, 'OwnProperty');
if Info^.Default<>11 then
Halt(2);
end.