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:
Stephen Heumann 2020-01-30 12:48:16 -06:00
parent ea72e60b4a
commit 76eb476809

View File

@ -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;