mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-08-28 21:40:34 +02:00
+ add support for Delphi's dynamic array constant syntax ("[...]") in Delphi modes
git-svn-id: trunk@39042 -
This commit is contained in:
parent
08dd4e5445
commit
a29a6abc55
1
.gitattributes
vendored
1
.gitattributes
vendored
@ -12503,6 +12503,7 @@ tests/test/tarray12.pp svneol=native#text/pascal
|
|||||||
tests/test/tarray13.pp svneol=native#text/pascal
|
tests/test/tarray13.pp svneol=native#text/pascal
|
||||||
tests/test/tarray14.pp svneol=native#text/pascal
|
tests/test/tarray14.pp svneol=native#text/pascal
|
||||||
tests/test/tarray15.pp svneol=native#text/pascal
|
tests/test/tarray15.pp svneol=native#text/pascal
|
||||||
|
tests/test/tarray16.pp svneol=native#text/pascal
|
||||||
tests/test/tarray2.pp svneol=native#text/plain
|
tests/test/tarray2.pp svneol=native#text/plain
|
||||||
tests/test/tarray3.pp svneol=native#text/plain
|
tests/test/tarray3.pp svneol=native#text/plain
|
||||||
tests/test/tarray4.pp svneol=native#text/plain
|
tests/test/tarray4.pp svneol=native#text/plain
|
||||||
|
@ -1160,6 +1160,9 @@ function get_next_varsym(def: tabstractrecorddef; const SymList:TFPHashObjectLis
|
|||||||
|
|
||||||
|
|
||||||
procedure tasmlisttypedconstbuilder.parse_arraydef(def:tarraydef);
|
procedure tasmlisttypedconstbuilder.parse_arraydef(def:tarraydef);
|
||||||
|
const
|
||||||
|
LKlammerToken: array[Boolean] of TToken = (_LKLAMMER, _LECKKLAMMER);
|
||||||
|
RKlammerToken: array[Boolean] of TToken = (_RKLAMMER, _RECKKLAMMER);
|
||||||
var
|
var
|
||||||
n : tnode;
|
n : tnode;
|
||||||
i : longint;
|
i : longint;
|
||||||
@ -1186,9 +1189,9 @@ function get_next_varsym(def: tabstractrecorddef; const SymList:TFPHashObjectLis
|
|||||||
begin
|
begin
|
||||||
ftcb.emit_tai(Tai_const.Create_sym(nil),def);
|
ftcb.emit_tai(Tai_const.Create_sym(nil),def);
|
||||||
end
|
end
|
||||||
else if try_to_consume(_LKLAMMER) then
|
else if try_to_consume(LKlammerToken[m_delphi in current_settings.modeswitches]) then
|
||||||
begin
|
begin
|
||||||
if try_to_consume(_RKLAMMER) then
|
if try_to_consume(RKlammerToken[m_delphi in current_settings.modeswitches]) then
|
||||||
begin
|
begin
|
||||||
ftcb.emit_tai(tai_const.create_sym(nil),def);
|
ftcb.emit_tai(tai_const.create_sym(nil),def);
|
||||||
end
|
end
|
||||||
@ -1210,7 +1213,7 @@ function get_next_varsym(def: tabstractrecorddef; const SymList:TFPHashObjectLis
|
|||||||
begin
|
begin
|
||||||
read_typed_const_data(def.elementdef);
|
read_typed_const_data(def.elementdef);
|
||||||
inc(dyncount);
|
inc(dyncount);
|
||||||
if try_to_consume(_RKLAMMER) then
|
if try_to_consume(RKlammerToken[m_delphi in current_settings.modeswitches]) then
|
||||||
break
|
break
|
||||||
else
|
else
|
||||||
consume(_COMMA);
|
consume(_COMMA);
|
||||||
|
81
tests/test/tarray16.pp
Normal file
81
tests/test/tarray16.pp
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
program tarray16;
|
||||||
|
|
||||||
|
{$mode delphi}
|
||||||
|
|
||||||
|
{$ifdef InLazIDE}
|
||||||
|
function CheckArray(aArr, aExpected: array of LongInt): Boolean;
|
||||||
|
{$else}
|
||||||
|
function CheckArray<T>(aArr, aExpected: array of T): Boolean;
|
||||||
|
{$endif}
|
||||||
|
var
|
||||||
|
i: LongInt;
|
||||||
|
begin
|
||||||
|
if Length(aArr) <> Length(aExpected) then
|
||||||
|
Exit(False);
|
||||||
|
for i := Low(aArr) to High(aArr) do
|
||||||
|
if aArr[i] <> aExpected[i] then
|
||||||
|
Exit(False);
|
||||||
|
Result := True;
|
||||||
|
end;
|
||||||
|
|
||||||
|
var
|
||||||
|
v1: array of LongInt = Nil;
|
||||||
|
v2: array of LongInt = [];
|
||||||
|
v3: array of LongInt = [1, 2, 3];
|
||||||
|
v4: array of String = ['Alpha', 'Beta', 'Gamma', 'Delta'];
|
||||||
|
v5: array[0..2] of array of LongInt = (Nil, [], [1, 2, 3]);
|
||||||
|
// these do not work in Delphi
|
||||||
|
//v6: array of array[0..2] of LongInt = [(1, 2, 3), (4, 5, 6)];
|
||||||
|
//v7: array[0..2] of array of array[0..2] of LongInt = ([(1, 2, 3), (4, 5, 6)], [], [(7, 8, 9)]);
|
||||||
|
|
||||||
|
var
|
||||||
|
res: Boolean;
|
||||||
|
begin
|
||||||
|
if Length(v1) <> 0 then
|
||||||
|
Halt(1);
|
||||||
|
if Length(v2) <> 0 then
|
||||||
|
Halt(2);
|
||||||
|
{$ifndef InLazIDE}
|
||||||
|
res := CheckArray<LongInt>(v3, [1, 2, 3]);
|
||||||
|
if not res then
|
||||||
|
Halt(3);
|
||||||
|
res := CheckArray<String>(v4, ['Alpha', 'Beta', 'Gamma', 'Delta']);
|
||||||
|
if not res then
|
||||||
|
Halt(4);
|
||||||
|
if Length(v5[0]) <> 0 then
|
||||||
|
Halt(5);
|
||||||
|
if Length(v5[1]) <> 0 then
|
||||||
|
Halt(6);
|
||||||
|
res := CheckArray<LongInt>(v5[2], [1, 2, 3]);
|
||||||
|
if not res then
|
||||||
|
Halt(7);
|
||||||
|
{if Length(v6) <> 2 then
|
||||||
|
Halt(8);
|
||||||
|
res := CheckArray<LongInt>(v6[0], [1, 2, 3]);
|
||||||
|
if not res then
|
||||||
|
Halt(9);
|
||||||
|
res := CheckArray<LongInt>(v6[1], [4, 5, 6]);
|
||||||
|
if not res then
|
||||||
|
Halt(10);
|
||||||
|
if Length(v7[0]) <> 2 then
|
||||||
|
Halt(11);
|
||||||
|
if Length(v7[1]) <> 0 then
|
||||||
|
Halt(12);
|
||||||
|
if Length(v7[2]) <> 1 then
|
||||||
|
Halt(13);
|
||||||
|
res := CheckArray<LongInt>(v7[0, 0], [1, 2, 3]);
|
||||||
|
if not res then
|
||||||
|
Halt(14);
|
||||||
|
res := CheckArray<LongInt>(v7[0, 1], [4, 5, 6]);
|
||||||
|
if not res then
|
||||||
|
Halt(15);
|
||||||
|
res := CheckArray<LongInt>(v7[2, 0], [7, 8, 9]);
|
||||||
|
if not res then
|
||||||
|
Halt(16);}
|
||||||
|
v3[1] := 42;
|
||||||
|
res := CheckArray<LongInt>(v3, [1, 42, 3]);
|
||||||
|
if not res then
|
||||||
|
Halt(17);
|
||||||
|
{$endif}
|
||||||
|
Writeln('ok');
|
||||||
|
end.
|
Loading…
Reference in New Issue
Block a user