mirror of
https://github.com/cc65/cc65.git
synced 2025-01-13 09:31:53 +00:00
Added code that avoids infinite loops that were caused by circular references
(a symbol that was defined by referring to itself directly or indirectly). Patch by kugelfuhr.
This commit is contained in:
parent
2628a176f9
commit
800568dd58
@ -171,6 +171,25 @@ int IsFarRange (long Val)
|
||||
|
||||
|
||||
|
||||
static const ExprNode* ResolveSymbolChain(const ExprNode* E)
|
||||
/* Recursive helper function for IsEasyConst */
|
||||
{
|
||||
if (E->Op == EXPR_SYMBOL) {
|
||||
SymEntry* Sym = E->V.Sym;
|
||||
|
||||
if (Sym == 0 || Sym->Expr == 0 || SymHasUserMark (Sym)) {
|
||||
return 0;
|
||||
} else {
|
||||
SymMarkUser (Sym);
|
||||
E = ResolveSymbolChain (Sym->Expr);
|
||||
SymUnmarkUser (Sym);
|
||||
}
|
||||
}
|
||||
return E;
|
||||
}
|
||||
|
||||
|
||||
|
||||
int IsEasyConst (const ExprNode* E, long* Val)
|
||||
/* Do some light checking if the given node is a constant. Don't care if E is
|
||||
** a complex expression. If E is a constant, return true and place its value
|
||||
@ -178,13 +197,11 @@ int IsEasyConst (const ExprNode* E, long* Val)
|
||||
*/
|
||||
{
|
||||
/* Resolve symbols, follow symbol chains */
|
||||
while (E->Op == EXPR_SYMBOL) {
|
||||
E = SymResolve (E->V.Sym);
|
||||
E = ResolveSymbolChain (E);
|
||||
if (E == 0) {
|
||||
/* Could not resolve */
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
/* Symbols resolved, check for a literal */
|
||||
if (E->Op == EXPR_LITERAL) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user