mirror of
https://github.com/byteworksinc/ORCA-C.git
synced 2025-01-18 03:29:49 +00:00
Address some issues with stringization of macro arguments.
We now insert spaces corresponding to whitespace between tokens, and string tokens are enclosed in quotes. There are still issues with (at least) escape sequences in strings and comments between tokens.
This commit is contained in:
parent
ea72e60b4a
commit
76eb476809
24
Scanner.pas
24
Scanner.pas
@ -267,6 +267,8 @@ var
|
|||||||
workString: pstring; {for building strings and identifiers}
|
workString: pstring; {for building strings and identifiers}
|
||||||
ucnString: string[10]; {string of a UCN}
|
ucnString: string[10]; {string of a UCN}
|
||||||
lintErrors: set of 1..maxLint; {lint error codes}
|
lintErrors: set of 1..maxLint; {lint error codes}
|
||||||
|
spaceStr: string[2]; {string ' ' (used in stringization)}
|
||||||
|
quoteStr: string[2]; {string '"' (used in stringization)}
|
||||||
|
|
||||||
{-- External procedures; see expression evaluator for notes ----}
|
{-- External procedures; see expression evaluator for notes ----}
|
||||||
|
|
||||||
@ -1513,12 +1515,25 @@ else begin
|
|||||||
if tcPtr = nil then
|
if tcPtr = nil then
|
||||||
BuildStringToken(nil, 0);
|
BuildStringToken(nil, 0);
|
||||||
while tcPtr <> nil do begin
|
while tcPtr <> nil do begin
|
||||||
if tcPtr^.token.kind = stringconst then
|
if tcPtr^.token.kind = stringconst then begin
|
||||||
|
BuildStringToken(@quoteStr[1], 1);
|
||||||
BuildStringToken(@tcPtr^.token.sval^.str,
|
BuildStringToken(@tcPtr^.token.sval^.str,
|
||||||
tcPtr^.token.sval^.length)
|
tcPtr^.token.sval^.length);
|
||||||
else
|
BuildStringToken(@quoteStr[1], 1);
|
||||||
|
end {if}
|
||||||
|
else begin
|
||||||
|
if tcPtr <> pptr^.tokens then
|
||||||
|
if charKinds[tcPtr^.tokenEnd^] = ch_white then
|
||||||
|
BuildStringToken(@spaceStr[1], 1);
|
||||||
BuildStringToken(tcPtr^.tokenStart,
|
BuildStringToken(tcPtr^.tokenStart,
|
||||||
ord(ord4(tcPtr^.tokenEnd)-ord4(tcPtr^.tokenStart)));
|
ord(ord4(tcPtr^.tokenEnd)-ord4(tcPtr^.tokenStart)));
|
||||||
|
|
||||||
|
{hack because stringconst may not have proper tokenEnd}
|
||||||
|
if tcPtr^.next <> nil then
|
||||||
|
if tcPtr^.next^.token.kind = stringconst then
|
||||||
|
if charKinds[ptr(ord4(tcPtr^.tokenStart)-1)^] = ch_white then
|
||||||
|
BuildStringToken(@spaceStr[1], 1);
|
||||||
|
end;
|
||||||
tcPtr := tcPtr^.next;
|
tcPtr := tcPtr^.next;
|
||||||
end; {while}
|
end; {while}
|
||||||
tlPtr := tlPtr^.next;
|
tlPtr := tlPtr^.next;
|
||||||
@ -3640,6 +3655,9 @@ lintIsError := true; {lint messages are considered errors}
|
|||||||
{if changed, also change maxLint}
|
{if changed, also change maxLint}
|
||||||
lintErrors := [51,104,105,110,124,125,128,129,130,147,151,152,153];
|
lintErrors := [51,104,105,110,124,125,128,129,130,147,151,152,153];
|
||||||
|
|
||||||
|
spaceStr := ' '; {strings used in stringization}
|
||||||
|
quoteStr := '"';
|
||||||
|
|
||||||
new(mp); {__LINE__}
|
new(mp); {__LINE__}
|
||||||
mp^.name := @'__LINE__';
|
mp^.name := @'__LINE__';
|
||||||
mp^.parameters := -1;
|
mp^.parameters := -1;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user