diff --git a/Expression.pas b/Expression.pas index a042d89..984478f 100644 --- a/Expression.pas +++ b/Expression.pas @@ -1199,9 +1199,8 @@ var codeGeneration := lCodeGeneration and (numErrors = 0); op^.token.lval := expressionType^.size; with expressionType^ do - if kind = arrayType then - if (elements = 0) or (size = 0) then - Error(49); + if (size = 0) or ((kind = arrayType) and (elements = 0)) then + Error(49); end; {else} op^.left := nil; end {if sizeofsy} @@ -1607,8 +1606,8 @@ if token.kind in startExpression then begin sp^.token.kind := ulongconst; sp^.token.class := longConstant; sp^.token.lval := typeSpec^.size; - if typeSpec^.kind = arrayType then - if (typeSpec^.elements = 0) or (typeSpec^.size = 0) then + with typeSpec^ do + if (size = 0) or ((kind = arrayType) and (elements = 0)) then Error(49); sp^.next := stack; stack := sp; diff --git a/Scanner.pas b/Scanner.pas index 40e6186..59cceab 100644 --- a/Scanner.pas +++ b/Scanner.pas @@ -529,7 +529,7 @@ if list or (numErr <> 0) then begin 46: msg := @'you must initialize the individual elements of a struct, union, or non-char array'; 47: msg := @'type conflict'; 48: msg := @'pointer initializers must resolve to an integer, address or string'; - 49: msg := @'the array size could not be determined'; + 49: msg := @'the size could not be determined'; 50: msg := @'only parameters or types may be declared here'; 51: msg := @'lint: undefined function'; 52: msg := @'you cannot initialize a type';