* empty class and object instance seems to be handled a bit different

git-svn-id: trunk@36985 -
This commit is contained in:
svenbarth 2017-08-20 19:20:42 +00:00
parent ae6352611f
commit 5f116c4cec

View File

@ -746,7 +746,7 @@ end;
function TValue.AsObject: TObject;
begin
if IsObject then
if IsObject or (IsClass and not Assigned(FData.FAsObject)) then
result := TObject(FData.FAsObject)
else
raise EInvalidCast.Create(SErrInvalidTypecast);
@ -759,7 +759,7 @@ end;
function TValue.IsClass: boolean;
begin
result := Kind = tkClassRef;
result := (Kind = tkClassRef) or ((Kind = tkClass) and not Assigned(FData.FAsObject));
end;
function TValue.AsClass: TClass;
@ -772,7 +772,8 @@ end;
function TValue.IsOrdinal: boolean;
begin
result := Kind in [tkInteger, tkInt64, tkQWord, tkBool];
result := (Kind in [tkInteger, tkInt64, tkQWord, tkBool]) or
((Kind in [tkClass, tkClassRef, tkInterfaceRaw]) and not Assigned(FData.FAsPointer));
end;
function TValue.AsBoolean: boolean;
@ -795,16 +796,19 @@ end;
function TValue.AsOrdinal: Int64;
begin
if IsOrdinal then
case TypeData^.OrdType of
otSByte: Result := FData.FAsSByte;
otUByte: Result := FData.FAsUByte;
otSWord: Result := FData.FAsSWord;
otUWord: Result := FData.FAsUWord;
otSLong: Result := FData.FAsSLong;
otULong: Result := FData.FAsULong;
otSQWord: Result := FData.FAsSInt64;
otUQWord: Result := FData.FAsUInt64;
end
if Kind in [tkClass, tkClassRef, tkInterfaceRaw] then
Result := 0
else
case TypeData^.OrdType of
otSByte: Result := FData.FAsSByte;
otUByte: Result := FData.FAsUByte;
otSWord: Result := FData.FAsSWord;
otUWord: Result := FData.FAsUWord;
otSLong: Result := FData.FAsSLong;
otULong: Result := FData.FAsULong;
otSQWord: Result := FData.FAsSInt64;
otUQWord: Result := FData.FAsUInt64;
end
else
raise EInvalidCast.Create(SErrInvalidTypecast);
end;
@ -836,9 +840,12 @@ end;
function TValue.AsInterface: IInterface;
begin
if Kind <> tkInterface then
if Kind = tkInterface then
Result := PInterface(FData.FValueData.GetReferenceToRawData)^
else if (Kind in [tkClass, tkClassRef]) and not Assigned(FData.FAsPointer) then
Result := Nil
else
raise EInvalidCast.Create(SErrInvalidTypecast);
Result := PInterface(FData.FValueData.GetReferenceToRawData)^;
end;
function TValue.ToString: String;