mirror of
https://github.com/byteworksinc/ORCA-C.git
synced 2025-01-05 08:30:59 +00:00
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:
parent
8b4c83f527
commit
5618b2810e
34
Scanner.pas
34
Scanner.pas
@ -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}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user