mirror of
https://github.com/cc65/cc65.git
synced 2025-01-12 17:30:50 +00:00
Fixed a problem similar to the one in Assignment() some time ago: An
expression that yields a constant value may have side effects, and the expression code must not be removed in this case. git-svn-id: svn://svn.cc65.org/cc65/trunk@4137 b7a2c559-68d2-44c3-8de9-860c34a00d81
This commit is contained in:
parent
84e288f21c
commit
2d3b0f1146
@ -1721,7 +1721,14 @@ static void hie_internal (const GenDesc* Ops, /* List of generators */
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Get the right hand side */
|
/* Get the right hand side */
|
||||||
rconst = (evalexpr (CF_NONE, hienext, &Expr2) == 0);
|
MarkedExprWithCheck (hienext, &Expr2);
|
||||||
|
|
||||||
|
/* Check for a constant expression */
|
||||||
|
rconst = (ED_IsConstAbs (&Expr2) && ED_CodeRangeIsEmpty (&Expr2));
|
||||||
|
if (!rconst) {
|
||||||
|
/* Not constant, load into the primary */
|
||||||
|
LoadExpr (CF_NONE, &Expr2);
|
||||||
|
}
|
||||||
|
|
||||||
/* Check the type of the rhs */
|
/* Check the type of the rhs */
|
||||||
if (!IsClassInt (Expr2.Type)) {
|
if (!IsClassInt (Expr2.Type)) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user