#define should always use the global pool....

if a #define is within a function, it could use the local memory pool for string allocation (via Malloc in NextToken, line 5785) which can lead to a dangling memory reference when the macro is expanded.

void function(void) {

#define TEXT "abc"

static struct {
	char text[sizeof(TEXT)];
} template = { TEXT };

}
This commit is contained in:
Kelvin Sherlock 2023-12-31 11:34:25 -05:00 committed by Stephen Heumann
parent 0aee669746
commit 586229e6eb

View File

@ -2786,8 +2786,12 @@ var
ple: stringListPtr; {pointer to the last element in parameterList} ple: stringListPtr; {pointer to the last element in parameterList}
pnum: integer; {for counting parameters} pnum: integer; {for counting parameters}
tPtr,tk1,tk2: tokenListRecordPtr; {pointer to a token} tPtr,tk1,tk2: tokenListRecordPtr; {pointer to a token}
luseGlobalPool: boolean; {local copy of useGlobalPool}
begin {DoDefine} begin {DoDefine}
lUseGlobalPool := useGlobalPool;
useGlobalPool := true; {use global memory for defines}
expandMacros := false; {block expansions} expandMacros := false; {block expansions}
saveNumber := true; {save characters in numeric tokens} saveNumber := true; {save characters in numeric tokens}
parameterList := nil; {no parameters yet} parameterList := nil; {no parameters yet}
@ -2999,6 +3003,7 @@ var
dispose(np); dispose(np);
end; {while} end; {while}
saveNumber := false; {stop saving numeric strings} saveNumber := false; {stop saving numeric strings}
useGlobalPool := lUseGlobalPool;
end; {DoDefine} end; {DoDefine}