|
@@ -1199,7 +1199,394 @@ end;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
+<<<<<<< HEAD
|
|
procedure TTestRTTI.TestInterface;
|
|
procedure TTestRTTI.TestInterface;
|
|
|
|
+=======
|
|
|
|
+ test.value1 := 42;
|
|
|
|
+ test.value2 := 'Hello World';
|
|
|
|
+ TValue.Make(@test, TypeInfo(TTestRecord), value);
|
|
|
|
+ Check(value.GetReferenceToRawData <> @test, 'Reference to record is equal');
|
|
|
|
+ Check(PTestRecord(value.GetReferenceToRawData)^.value1 = PTestRecord(@test)^.value1, 'Reference to record data value1 differs');
|
|
|
|
+ Check(PTestRecord(value.GetReferenceToRawData)^.value2 = PTestRecord(@test)^.value2, 'Reference to record data value2 differs');
|
|
|
|
+
|
|
|
|
+ SetLength(arrdyn, 3);
|
|
|
|
+ arrdyn[0] := 42;
|
|
|
|
+ arrdyn[1] := 23;
|
|
|
|
+ arrdyn[2] := 49;
|
|
|
|
+ TValue.Make(@arrdyn, TypeInfo(TArrayOfLongintDyn), value);
|
|
|
|
+ Check(PPointer(value.GetReferenceToRawData)^ = Pointer(arrdyn), 'Reference to dynamic array data differs');
|
|
|
|
+
|
|
|
|
+ arrstat[0] := 42;
|
|
|
|
+ arrstat[1] := 23;
|
|
|
|
+ arrstat[2] := 49;
|
|
|
|
+ arrstat[3] := 59;
|
|
|
|
+ TValue.Make(@arrstat, TypeInfo(TArrayOfLongintStatic), value);
|
|
|
|
+ Check(value.GetReferenceToRawData <> @arrstat, 'Reference to static array is equal');
|
|
|
|
+ Check(PLongInt(value.GetReferenceToRawData)^ = PLongInt(@arrstat)^, 'Reference to static array data differs');
|
|
|
|
+end;
|
|
|
|
+
|
|
|
|
+procedure TTestCase1.TestReferenceRawDataEmpty;
|
|
|
|
+var
|
|
|
|
+ value: TValue;
|
|
|
|
+begin
|
|
|
|
+ TValue.Make(Nil, TypeInfo(String), value);
|
|
|
|
+ Check(Assigned(value.GetReferenceToRawData()), 'Reference to empty String is not assigned');
|
|
|
|
+ Check(not Assigned(PPointer(value.GetReferenceToRawData)^), 'Empty String data is assigned');
|
|
|
|
+
|
|
|
|
+ TValue.Make(Nil, TypeInfo(IInterface), value);
|
|
|
|
+ Check(Assigned(value.GetReferenceToRawData()), 'Reference to empty interface is not assigned');
|
|
|
|
+ Check(not Assigned(PPointer(value.GetReferenceToRawData)^), 'Empty interface data is assigned');
|
|
|
|
+
|
|
|
|
+ TValue.Make(Nil, TypeInfo(LongInt), value);
|
|
|
|
+ Check(Assigned(value.GetReferenceToRawData()), 'Reference to empty LongInt is not assigned');
|
|
|
|
+ Check(PLongInt(value.GetReferenceToRawData)^ = 0, 'Empty longint data is not 0');
|
|
|
|
+
|
|
|
|
+ TValue.Make(Nil, TypeInfo(TTestRecord), value);
|
|
|
|
+ Check(Assigned(value.GetReferenceToRawData()), 'Reference to empty record is not assigned');
|
|
|
|
+ Check(PTestRecord(value.GetReferenceToRawData)^.value1 = 0, 'Empty record data value1 is not 0');
|
|
|
|
+ Check(PTestRecord(value.GetReferenceToRawData)^.value2 = '', 'Empty record data value2 is not empty');
|
|
|
|
+
|
|
|
|
+ TValue.Make(Nil, TypeInfo(TArrayOfLongintDyn), value);
|
|
|
|
+ Check(Assigned(value.GetReferenceToRawData()), 'Reference to empty dynamic array is not assigned');
|
|
|
|
+ Check(not Assigned(PPointer(value.GetReferenceToRawData)^), 'Empty dynamic array data is assigned');
|
|
|
|
+
|
|
|
|
+ TValue.Make(Nil, TypeInfo(TArrayOfLongintStatic), value);
|
|
|
|
+ Check(Assigned(value.GetReferenceToRawData()), 'Reference to empty static array is not assigned');
|
|
|
|
+ Check(PLongInt(value.GetReferenceToRawData)^ = 0, 'Empty static array data is not 0');
|
|
|
|
+end;
|
|
|
|
+
|
|
|
|
+procedure TTestCase1.TestDataSize;
|
|
|
|
+var
|
|
|
|
+ u8: UInt8;
|
|
|
|
+ u16: UInt16;
|
|
|
|
+ u32: UInt32;
|
|
|
|
+ u64: UInt64;
|
|
|
|
+ s8: Int8;
|
|
|
|
+ s16: Int16;
|
|
|
|
+ s32: Int32;
|
|
|
|
+ s64: Int64;
|
|
|
|
+ f32: Single;
|
|
|
|
+ f64: Double;
|
|
|
|
+{$ifdef FPC_HAS_TYPE_EXTENDED}
|
|
|
|
+ f80: Extended;
|
|
|
|
+{$endif}
|
|
|
|
+ fco: Comp;
|
|
|
|
+ fcu: Currency;
|
|
|
|
+ ss: ShortString;
|
|
|
|
+ sa: AnsiString;
|
|
|
|
+ su: UnicodeString;
|
|
|
|
+ sw: WideString;
|
|
|
|
+ o: TObject;
|
|
|
|
+ c: TClass;
|
|
|
|
+ i: IInterface;
|
|
|
|
+ ad: TArrayOfLongintDyn;
|
|
|
|
+ _as: TArrayOfLongintStatic;
|
|
|
|
+ b8: Boolean;
|
|
|
|
+{$ifdef fpc}
|
|
|
|
+ b16: Boolean16;
|
|
|
|
+ b32: Boolean32;
|
|
|
|
+ b64: Boolean64;
|
|
|
|
+{$endif}
|
|
|
|
+ bl8: ByteBool;
|
|
|
|
+ bl16: WordBool;
|
|
|
|
+ bl32: LongBool;
|
|
|
|
+{$ifdef fpc}
|
|
|
|
+ bl64: QWordBool;
|
|
|
|
+{$endif}
|
|
|
|
+ e: TTestEnum;
|
|
|
|
+ s: TTestSet;
|
|
|
|
+ t: TTestRecord;
|
|
|
|
+ p: Pointer;
|
|
|
|
+ proc: TTestProc;
|
|
|
|
+ method: TTestMethod;
|
|
|
|
+
|
|
|
|
+ value: TValue;
|
|
|
|
+begin
|
|
|
|
+ u8:=245;
|
|
|
|
+ TValue.Make(@u8, TypeInfo(UInt8), value);
|
|
|
|
+ CheckEquals(1, value.DataSize, 'Size of UInt8 differs');
|
|
|
|
+ u16:=789;
|
|
|
|
+ TValue.Make(@u16, TypeInfo(UInt16), value);
|
|
|
|
+ CheckEquals(2, value.DataSize, 'Size of UInt16 differs');
|
|
|
|
+ u32:=568789;
|
|
|
|
+ TValue.Make(@u32, TypeInfo(UInt32), value);
|
|
|
|
+ CheckEquals(4, value.DataSize, 'Size of UInt32 differs');
|
|
|
|
+ u64:=$abdcefadbcef;
|
|
|
|
+ TValue.Make(@u64, TypeInfo(UInt64), value);
|
|
|
|
+ CheckEquals(8, value.DataSize, 'Size of UInt64 differs');
|
|
|
|
+ s8:=-32;
|
|
|
|
+ TValue.Make(@s8, TypeInfo(Int8), value);
|
|
|
|
+ CheckEquals(1, value.DataSize, 'Size of Int8 differs');
|
|
|
|
+ s16:=-5345;
|
|
|
|
+ TValue.Make(@s16, TypeInfo(Int16), value);
|
|
|
|
+ CheckEquals(2, value.DataSize, 'Size of Int16 differs');
|
|
|
|
+ s32:=-234567;
|
|
|
|
+ TValue.Make(@s32, TypeInfo(Int32), value);
|
|
|
|
+ CheckEquals(4, value.DataSize, 'Size of Int32 differs');
|
|
|
|
+ s64:=23456789012;
|
|
|
|
+ TValue.Make(@s64, TypeInfo(Int64), value);
|
|
|
|
+ CheckEquals(8, value.DataSize, 'Size of Int64 differs');
|
|
|
|
+ b8:=false;
|
|
|
|
+ TValue.Make(@b8, TypeInfo(Boolean), value);
|
|
|
|
+ CheckEquals(1, value.DataSize, 'Size of Boolean differs');
|
|
|
|
+{$ifdef fpc}
|
|
|
|
+ b16:=true;
|
|
|
|
+ TValue.Make(@b16, TypeInfo(Boolean16), value);
|
|
|
|
+ CheckEquals(2, value.DataSize, 'Size of Boolean16 differs');
|
|
|
|
+ b32:=false;
|
|
|
|
+ TValue.Make(@b32, TypeInfo(Boolean32), value);
|
|
|
|
+ CheckEquals(4, value.DataSize, 'Size of Boolean32 differs');
|
|
|
|
+ b64:=true;
|
|
|
|
+ TValue.Make(@b64, TypeInfo(Boolean64), value);
|
|
|
|
+ CheckEquals(8, value.DataSize, 'Size of Boolean64 differs');
|
|
|
|
+{$endif}
|
|
|
|
+ bl8:=true;
|
|
|
|
+ TValue.Make(@bl8, TypeInfo(ByteBool), value);
|
|
|
|
+ CheckEquals(1, value.DataSize, 'Size of ByteBool differs');
|
|
|
|
+ bl16:=false;
|
|
|
|
+ TValue.Make(@bl16, TypeInfo(WordBool), value);
|
|
|
|
+ CheckEquals(2, value.DataSize, 'Size of WordBool differs');
|
|
|
|
+ bl32:=false;
|
|
|
|
+ TValue.Make(@bl32, TypeInfo(LongBool), value);
|
|
|
|
+ CheckEquals(4, value.DataSize, 'Size of LongBool differs');
|
|
|
|
+{$ifdef fpc}
|
|
|
|
+ bl64:=true;
|
|
|
|
+ TValue.Make(@bl64, TypeInfo(QWordBool), value);
|
|
|
|
+ CheckEquals(8, value.DataSize, 'Size of QWordBool differs');
|
|
|
|
+{$endif}
|
|
|
|
+ f32:=4.567;
|
|
|
|
+ TValue.Make(@f32, TypeInfo(Single), value);
|
|
|
|
+ CheckEquals(4, value.DataSize, 'Size of Single differs');
|
|
|
|
+ f64:=-3456.678;
|
|
|
|
+ TValue.Make(@f64, TypeInfo(Double), value);
|
|
|
|
+ CheckEquals(8, value.DataSize, 'Size of Double differs');
|
|
|
|
+{$ifdef FPC_HAS_TYPE_EXTENDED}
|
|
|
|
+ f80:=-2345.678;
|
|
|
|
+ TValue.Make(@f80, TypeInfo(Extended), value);
|
|
|
|
+ CheckEquals(10, value.DataSize, 'Size of Extended differs');
|
|
|
|
+{$endif}
|
|
|
|
+ fcu:=56.78;
|
|
|
|
+ TValue.Make(@fcu, TypeInfo(Currency), value);
|
|
|
|
+ CheckEquals(SizeOf(Currency), value.DataSize, 'Size of Currency differs');
|
|
|
|
+ fco:=456;
|
|
|
|
+ TValue.Make(@fco, TypeInfo(Comp), value);
|
|
|
|
+ CheckEquals(SizeOf(Comp), value.DataSize, 'Size of Comp differs');
|
|
|
|
+ ss := '';
|
|
|
|
+ TValue.Make(@ss, TypeInfo(ShortString), value);
|
|
|
|
+ CheckEquals(254, value.DataSize, 'Size ofShortString differs');
|
|
|
|
+ sa:= '';
|
|
|
|
+ TValue.Make(@sa, TypeInfo(AnsiString), value);
|
|
|
|
+ CheckEquals(SizeOf(Pointer), value.DataSize, 'Size of AnsiString differs');
|
|
|
|
+ sw := '';
|
|
|
|
+ TValue.Make(@sw, TypeInfo(WideString), value);
|
|
|
|
+ CheckEquals(SizeOf(Pointer), value.DataSize, 'Size of WideString differs');
|
|
|
|
+ su:='';
|
|
|
|
+ TValue.Make(@su, TypeInfo(UnicodeString), value);
|
|
|
|
+ CheckEquals(SizeOf(Pointer), value.DataSize, 'Size of UnicodeString differs');
|
|
|
|
+ o := TTestValueClass.Create;
|
|
|
|
+ TValue.Make(@o, TypeInfo(TObject), value);
|
|
|
|
+ CheckEquals(SizeOf(Pointer), value.DataSize, 'Size of TObject differs');
|
|
|
|
+ o.Free;
|
|
|
|
+ c := TObject;
|
|
|
|
+ TValue.Make(@c, TypeInfo(TClass), value);
|
|
|
|
+ CheckEquals(SizeOf(Pointer), value.DataSize, 'Size of TClass differs');
|
|
|
|
+ i := Nil;
|
|
|
|
+ TValue.Make(@i, TypeInfo(IInterface), value);
|
|
|
|
+ CheckEquals(SizeOf(Pointer), value.DataSize, 'Size of IInterface differs');
|
|
|
|
+ TValue.Make(@t, TypeInfo(TTestRecord), value);
|
|
|
|
+ CheckEquals(SizeOf(TTestRecord), value.DataSize, 'Size of TTestRecord differs');
|
|
|
|
+ proc := Nil;
|
|
|
|
+ TValue.Make(@proc, TypeInfo(TTestProc), value);
|
|
|
|
+ CheckEquals(SizeOf(TTestProc), value.DataSize, 'Size of TTestProc differs');
|
|
|
|
+ method := Nil;
|
|
|
|
+ TValue.Make(@method, TypeInfo(TTestMethod), value);
|
|
|
|
+ CheckEquals(SizeOf(TTestMethod), value.DataSize, 'Size of TTestMethod differs');
|
|
|
|
+ TValue.Make(@_as, TypeInfo(TArrayOfLongintStatic), value);
|
|
|
|
+ CheckEquals(SizeOf(TArrayOfLongintStatic), value.DataSize, 'Size of TArrayOfLongintStatic differs');
|
|
|
|
+ TValue.Make(@ad, TypeInfo(TArrayOfLongintDyn), value);
|
|
|
|
+ CheckEquals(SizeOf(TArrayOfLongintDyn), value.DataSize, 'Size of TArrayOfLongintDyn differs');
|
|
|
|
+ e:=low(TTestEnum);
|
|
|
|
+ TValue.Make(@e, TypeInfo(TTestEnum), value);
|
|
|
|
+ CheckEquals(SizeOf(TTestEnum), value.DataSize, 'Size of TTestEnum differs');
|
|
|
|
+ s:=[low(TTestEnum),high(TTestEnum)];
|
|
|
|
+ TValue.Make(@s, TypeInfo(TTestSet), value);
|
|
|
|
+ CheckEquals(SizeOf(TTestSet), value.DataSize, 'Size of TTestSet differs');
|
|
|
|
+ p := Nil;
|
|
|
|
+ TValue.Make(@p, TypeInfo(Pointer), value);
|
|
|
|
+ CheckEquals(SizeOf(Pointer), value.DataSize, 'Size of Pointer differs');
|
|
|
|
+end;
|
|
|
|
+
|
|
|
|
+procedure TTestCase1.TestDataSizeEmpty;
|
|
|
|
+var
|
|
|
|
+ value: TValue;
|
|
|
|
+begin
|
|
|
|
+ TValue.Make(Nil, TypeInfo(UInt8), value);
|
|
|
|
+ CheckEquals(1, value.DataSize, 'Size of UInt8 differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(UInt16), value);
|
|
|
|
+ CheckEquals(2, value.DataSize, 'Size of UInt16 differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(UInt32), value);
|
|
|
|
+ CheckEquals(4, value.DataSize, 'Size of UInt32 differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(UInt64), value);
|
|
|
|
+ CheckEquals(8, value.DataSize, 'Size of UInt64 differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(Int8), value);
|
|
|
|
+ CheckEquals(1, value.DataSize, 'Size of Int8 differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(Int16), value);
|
|
|
|
+ CheckEquals(2, value.DataSize, 'Size of Int16 differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(Int32), value);
|
|
|
|
+ CheckEquals(4, value.DataSize, 'Size of Int32 differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(Int64), value);
|
|
|
|
+ CheckEquals(8, value.DataSize, 'Size of Int64 differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(Boolean), value);
|
|
|
|
+ CheckEquals(1, value.DataSize, 'Size of Boolean differs');
|
|
|
|
+{$ifdef fpc}
|
|
|
|
+ TValue.Make(Nil, TypeInfo(Boolean16), value);
|
|
|
|
+ CheckEquals(2, value.DataSize, 'Size of Boolean16 differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(Boolean32), value);
|
|
|
|
+ CheckEquals(4, value.DataSize, 'Size of Boolean32 differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(Boolean64), value);
|
|
|
|
+ CheckEquals(8, value.DataSize, 'Size of Boolean64 differs');
|
|
|
|
+{$endif}
|
|
|
|
+ TValue.Make(Nil, TypeInfo(ByteBool), value);
|
|
|
|
+ CheckEquals(1, value.DataSize, 'Size of ByteBool differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(WordBool), value);
|
|
|
|
+ CheckEquals(2, value.DataSize, 'Size of WordBool differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(LongBool), value);
|
|
|
|
+ CheckEquals(4, value.DataSize, 'Size of LongBool differs');
|
|
|
|
+{$ifdef fpc}
|
|
|
|
+ TValue.Make(Nil, TypeInfo(QWordBool), value);
|
|
|
|
+ CheckEquals(8, value.DataSize, 'Size of QWordBool differs');
|
|
|
|
+{$endif}
|
|
|
|
+ TValue.Make(Nil, TypeInfo(Single), value);
|
|
|
|
+ CheckEquals(4, value.DataSize, 'Size of Single differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(Double), value);
|
|
|
|
+ CheckEquals(8, value.DataSize, 'Size of Double differs');
|
|
|
|
+{$ifdef FPC_HAS_TYPE_EXTENDED}
|
|
|
|
+ TValue.Make(Nil, TypeInfo(Extended), value);
|
|
|
|
+ CheckEquals(10, value.DataSize, 'Size of Extended differs');
|
|
|
|
+{$endif}
|
|
|
|
+ TValue.Make(Nil, TypeInfo(Currency), value);
|
|
|
|
+ CheckEquals(SizeOf(Currency), value.DataSize, 'Size of Currency differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(Comp), value);
|
|
|
|
+ CheckEquals(SizeOf(Comp), value.DataSize, 'Size of Comp differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(ShortString), value);
|
|
|
|
+ CheckEquals(254, value.DataSize, 'Size of ShortString differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(AnsiString), value);
|
|
|
|
+ CheckEquals(SizeOf(Pointer), value.DataSize, 'Size of Pointer differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(WideString), value);
|
|
|
|
+ CheckEquals(SizeOf(Pointer), value.DataSize, 'Size of WideString differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(UnicodeString), value);
|
|
|
|
+ CheckEquals(SizeOf(Pointer), value.DataSize, 'Size of UnicodeString differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(TObject), value);
|
|
|
|
+ CheckEquals(SizeOf(Pointer), value.DataSize, 'Size of TObject differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(TClass), value);
|
|
|
|
+ CheckEquals(SizeOf(Pointer), value.DataSize, 'Size of TClass differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(IInterface), value);
|
|
|
|
+ CheckEquals(SizeOf(Pointer), value.DataSize, 'Size of IInterface differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(TTestRecord), value);
|
|
|
|
+ CheckEquals(SizeOf(TTestRecord), value.DataSize, 'Size of TTestRecord differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(TTestProc), value);
|
|
|
|
+ CheckEquals(SizeOf(TTestProc), value.DataSize, 'Size of TTestProc differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(TTestMethod), value);
|
|
|
|
+ CheckEquals(SizeOf(TTestMethod), value.DataSize, 'Size of TTestMethod differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(TArrayOfLongintStatic), value);
|
|
|
|
+ CheckEquals(SizeOf(TArrayOfLongintStatic), value.DataSize, 'Size of TArrayOfLongintStatic differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(TArrayOfLongintDyn), value);
|
|
|
|
+ CheckEquals(SizeOf(TArrayOfLongintDyn), value.DataSize, 'Size of TArrayOfLongintDyn differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(TTestEnum), value);
|
|
|
|
+ CheckEquals(SizeOf(TTestEnum), value.DataSize, 'Size of TTestEnum differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(TTestSet), value);
|
|
|
|
+ CheckEquals(SizeOf(TTestSet), value.DataSize, 'Size of TTestSet differs');
|
|
|
|
+ TValue.Make(Nil, TypeInfo(Pointer), value);
|
|
|
|
+ CheckEquals(SizeOf(Pointer), value.DataSize, 'Size of Pointer differs');
|
|
|
|
+end;
|
|
|
|
+
|
|
|
|
+procedure TTestCase1.TestIsManaged;
|
|
|
|
+begin
|
|
|
|
+ CheckEquals(true, IsManaged(TypeInfo(ansistring)), 'IsManaged for tkAString');
|
|
|
|
+ CheckEquals(true, IsManaged(TypeInfo(widestring)), 'IsManaged for tkWString');
|
|
|
|
+ CheckEquals(true, IsManaged(TypeInfo(Variant)), 'IsManaged for tkVariant');
|
|
|
|
+ CheckEquals(true, IsManaged(TypeInfo(TArrayOfManagedRec)),
|
|
|
|
+ 'IsManaged for tkArray (with managed ElType)');
|
|
|
|
+ CheckEquals(true, IsManaged(TypeInfo(TArrayOfString)),
|
|
|
|
+ 'IsManaged for tkArray (with managed ElType)');
|
|
|
|
+ CheckEquals(true, IsManaged(TypeInfo(TManagedRec)), 'IsManaged for tkRecord');
|
|
|
|
+ {$ifdef fpc}
|
|
|
|
+ CheckEquals(true, IsManaged(TypeInfo(TManagedRecOp)), 'IsManaged for tkRecord');
|
|
|
|
+ {$endif}
|
|
|
|
+ CheckEquals(true, IsManaged(TypeInfo(IInterface)), 'IsManaged for tkInterface');
|
|
|
|
+ CheckEquals(true, IsManaged(TypeInfo(TManagedObj)), 'IsManaged for tkObject');
|
|
|
|
+ {$ifdef fpc}
|
|
|
|
+ CheckEquals(true, IsManaged(TypeInfo(specialize TArray<byte>)), 'IsManaged for tkDynArray');
|
|
|
|
+ {$else}
|
|
|
|
+ CheckEquals(true, IsManaged(TypeInfo(TArray<byte>)), 'IsManaged for tkDynArray');
|
|
|
|
+ {$endif}
|
|
|
|
+ CheckEquals(true, IsManaged(TypeInfo(unicodestring)), 'IsManaged for tkUString');
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(shortstring)), 'IsManaged for tkSString');
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(Byte)), 'IsManaged for tkInteger');
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(AnsiChar)), 'IsManaged for tkChar');
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(TTestEnum)), 'IsManaged for tkEnumeration');
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(Single)), 'IsManaged for tkFloat');
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(TTestSet)), 'IsManaged for tkSet');
|
|
|
|
+ {$ifdef fpc}
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(TTestMethod)), 'IsManaged for tkMethod');
|
|
|
|
+ {$else}
|
|
|
|
+ { Delphi bug (or sabotage). For some reason Delphi considers method pointers to be managed (only in newer versions, probably since XE7) :/ }
|
|
|
|
+ CheckEquals({$if RTLVersion>=28}true{$else}false{$endif}, IsManaged(TypeInfo(TTestMethod)), 'IsManaged for tkMethod');
|
|
|
|
+ {$endif}
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(TArrayOfByte)),
|
|
|
|
+ 'IsManaged for tkArray (with non managed ElType)');
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(TArrayOfNonManagedRec)),
|
|
|
|
+ 'IsManaged for tkArray (with non managed ElType)');
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(TNonManagedRec)), 'IsManaged for tkRecord');
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(TObject)), 'IsManaged for tkClass');
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(TNonManagedObj)), 'IsManaged for tkObject');
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(WideChar)), 'IsManaged for tkWChar');
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(Boolean)), 'IsManaged for tkBool');
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(Int64)), 'IsManaged for tkInt64');
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(UInt64)), 'IsManaged for tkQWord');
|
|
|
|
+ {$ifdef fpc}
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(ICORBATest)), 'IsManaged for tkInterfaceRaw');
|
|
|
|
+ {$endif}
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(TTestProc)), 'IsManaged for tkProcVar');
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(TTestHelper)), 'IsManaged for tkHelper');
|
|
|
|
+ {$ifdef fpc}
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(file)), 'IsManaged for tkFile');
|
|
|
|
+ {$endif}
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(TClass)), 'IsManaged for tkClassRef');
|
|
|
|
+ CheckEquals(false, IsManaged(TypeInfo(Pointer)), 'IsManaged for tkPointer');
|
|
|
|
+ CheckEquals(false, IsManaged(nil), 'IsManaged for nil');
|
|
|
|
+end;
|
|
|
|
+
|
|
|
|
+{$ifdef fpc}
|
|
|
|
+procedure TTestCase1.TestOpenArrayToDyn;
|
|
|
|
+
|
|
|
|
+ procedure OpenArrayProc(aArr: array of LongInt);
|
|
|
|
+ var
|
|
|
|
+ value: TValue;
|
|
|
|
+ begin
|
|
|
|
+{$ifndef InLazIDE}
|
|
|
|
+ value := specialize OpenArrayToDynArrayValue<LongInt>(aArr);
|
|
|
|
+{$endif}
|
|
|
|
+ CheckEquals(value.IsArray, True);
|
|
|
|
+ CheckEquals(value.IsOpenArray, False);
|
|
|
|
+ CheckEquals(value.IsObject, False);
|
|
|
|
+ CheckEquals(value.IsOrdinal, False);
|
|
|
|
+ CheckEquals(value.IsClass, False);
|
|
|
|
+ CheckEquals(value.GetArrayLength, 2);
|
|
|
|
+ CheckEquals(value.GetArrayElement(0).AsInteger, 42);
|
|
|
|
+ CheckEquals(value.GetArrayElement(1).AsInteger, 84);
|
|
|
|
+ value.SetArrayElement(0, 21);
|
|
|
|
+ { since this is a copy the original array is not modified! }
|
|
|
|
+ CheckEquals(aArr[0], 42);
|
|
|
|
+ end;
|
|
|
|
+
|
|
|
|
+begin
|
|
|
|
+ OpenArrayProc([42, 84]);
|
|
|
|
+end;
|
|
|
|
+{$endif}
|
|
|
|
+
|
|
|
|
+procedure TTestCase1.TestInterface;
|
|
|
|
+>>>>>>> a86fa16f98 (* PChar -> PAnsiChar)
|
|
var
|
|
var
|
|
context: TRttiContext;
|
|
context: TRttiContext;
|
|
t: TRttiType;
|
|
t: TRttiType;
|