* prevent crash of h2pas if an unknown specifier is encountered, resolves #18664

git-svn-id: trunk@20136 -
This commit is contained in:
florian 2012-01-21 15:17:11 +00:00
parent a0b200db76
commit d01824ab22
2 changed files with 10 additions and 6 deletions

View File

@ -1076,8 +1076,9 @@ program h2pas;
hp3:=hp2^.p2;
while assigned(hp3) do
begin
if not assigned(hp3^.p1^.p3) or
(hp3^.p1^.p3^.typ <> t_size_specifier) then
if assigned(hp3^.p1) and
(not assigned(hp3^.p1^.p3) or
(hp3^.p1^.p3^.typ <> t_size_specifier)) then
begin
if is_sized then
begin
@ -1097,7 +1098,8 @@ program h2pas;
popshift;
end;
{ size specifier or default value ? }
if assigned(hp3^.p1^.p3) then
if assigned(hp3^.p1) and
assigned(hp3^.p1^.p3) then
begin
{ we could use mask to implement this }
{ because we need to respect the positions }

View File

@ -1072,8 +1072,9 @@ program h2pas;
hp3:=hp2^.p2;
while assigned(hp3) do
begin
if not assigned(hp3^.p1^.p3) or
(hp3^.p1^.p3^.typ <> t_size_specifier) then
if assigned(hp3^.p1) and
(not assigned(hp3^.p1^.p3) or
(hp3^.p1^.p3^.typ <> t_size_specifier)) then
begin
if is_sized then
begin
@ -1093,7 +1094,8 @@ program h2pas;
popshift;
end;
{ size specifier or default value ? }
if assigned(hp3^.p1^.p3) then
if assigned(hp3^.p1) and
assigned(hp3^.p1^.p3) then
begin
{ we could use mask to implement this }
{ because we need to respect the positions }