Don’t produce spurious error messages when #error is used with tokens other than a string constant.

According to the C standards, #error is supposed to take an arbitrary sequence of pp-tokens, not just a string constant.
This commit is contained in:
Stephen Heumann 2016-11-05 18:57:26 -05:00
parent 8b4c83f527
commit 5618b2810e

View File

@ -2237,37 +2237,45 @@ var
procedure DoError; procedure DoError;
{ #error STRING } { #error pp-tokens(opt) }
var var
i: integer; {loop variable} i: integer; {loop variable}
len: integer; {string length} len: integer; {string length}
msg: stringPtr; {error message ptr} msg: stringPtr; {error message ptr}
cp: ptr; {character pointer}
lFirstPtr: ptr; {local copy of firstPtr}
begin {DoError} begin {DoError}
NextToken; {skip the command name} lFirstPtr := firstPtr;
if token.kind = stringConst then begin
numErrors := numErrors+1; numErrors := numErrors+1;
new(msg); new(msg);
len := token.sval^.length;
if len > 246 then
len := 246;
msg^ := '#error:'; msg^ := '#error:';
NextToken; {skip the command name}
while not (token.kind in [eolsy, eofsy]) do begin
msg^ := concat(msg^, ' ');
if token.kind = stringConst then begin
len := token.sval^.length;
for i := 1 to len do for i := 1 to len do
msg^ := concat(msg^, token.sval^.str[i]); msg^ := concat(msg^, token.sval^.str[i]);
end {if}
else begin
len := ord(ord4(tokenEnd) - ord4(tokenStart));
cp := tokenStart;
for i := 1 to len do begin
msg^ := concat(msg^, chr(cp^));
cp := pointer(ord4(cp)+1);
end; {for}
end; {else}
NextToken;
end; {while}
writeln(msg^); writeln(msg^);
if terminalErrors then begin if terminalErrors then begin
if enterEditor then if enterEditor then
ExitToEditor(msg, ord4(firstPtr)-ord4(bofPtr)) ExitToEditor(msg, ord4(lFirstPtr)-ord4(bofPtr))
else else
TermError(0); TermError(0);
end; {if} end; {if}
end {if}
else
Error(83);
NextToken; {skip the command name}
if token.kind <> eolsy then {check for extra stuff on the line}
Error(11);
end; {DoError} end; {DoError}