1
0
mirror of https://github.com/cc65/cc65.git synced 2025-01-10 19:29:45 +00:00

Fixed a bug

git-svn-id: svn://svn.cc65.org/cc65/trunk@1023 b7a2c559-68d2-44c3-8de9-860c34a00d81
This commit is contained in:
cuz 2001-10-11 09:52:02 +00:00
parent 41d2cc8f91
commit e17ab75ab3

View File

@ -2838,16 +2838,17 @@ static void addsubeq (GenDesc* Gen, ExprDesc *lval, int k)
/* Process the += and -= operators */
{
ExprDesc lval2;
unsigned flags;
unsigned lflags;
unsigned rflags;
int MustScale;
/* We must have an lvalue */
if (k == 0) {
Error ("Invalid lvalue in assignment");
return;
}
/* We're currently only able to handle some adressing modes */
if ((lval->Flags & E_MGLOBAL) == 0 && /* Global address? */
(lval->Flags & E_MLOCAL) == 0 && /* Local address? */
@ -2863,58 +2864,64 @@ static void addsubeq (GenDesc* Gen, ExprDesc *lval, int k)
/* Check if we have a pointer expression and must scale rhs */
MustScale = (lval->Type [0] == T_PTR);
/* Determine the code generator flags */
flags = TypeOf (lval->Type) | CF_FORCECHAR;
/* Initialize the code generator flags */
lflags = 0;
rflags = 0;
/* Evaluate the rhs */
if (evalexpr (CF_NONE, hie1, &lval2) == 0) {
/* The resulting value is a constant. */
/* The resulting value is a constant. */
if (MustScale) {
/* lhs is a pointer, scale rhs */
lval2.ConstVal *= SizeOf (lval->Type+1);
}
flags |= CF_CONST;
/* lhs is a pointer, scale rhs */
lval2.ConstVal *= SizeOf (lval->Type+1);
}
rflags |= CF_CONST;
lflags |= CF_CONST;
} else {
/* rhs is not constant and already in the primary register */
/* rhs is not constant and already in the primary register */
if (MustScale) {
/* lhs is a pointer, scale rhs */
/* lhs is a pointer, scale rhs */
g_scale (TypeOf (lval2.Type), SizeOf (lval->Type+1));
}
}
}
/* Setup the code generator flags */
lflags |= TypeOf (lval->Type) | CF_FORCECHAR;
rflags |= TypeOf (lval2.Type);
/* Adjust the rhs to the lhs */
g_typeadjust (flags, TypeOf (lval2.Type));
g_typeadjust (lflags, rflags);
/* Output apropriate code */
if (lval->Flags & E_MGLOBAL) {
/* Static variable */
flags |= GlobalModeFlags (lval->Flags);
lflags |= GlobalModeFlags (lval->Flags);
if (Gen->Tok == TOK_PLUS_ASSIGN) {
g_addeqstatic (flags, lval->Name, lval->ConstVal, lval2.ConstVal);
g_addeqstatic (lflags, lval->Name, lval->ConstVal, lval2.ConstVal);
} else {
g_subeqstatic (flags, lval->Name, lval->ConstVal, lval2.ConstVal);
g_subeqstatic (lflags, lval->Name, lval->ConstVal, lval2.ConstVal);
}
} else if (lval->Flags & E_MLOCAL) {
/* ref to localvar */
if (Gen->Tok == TOK_PLUS_ASSIGN) {
g_addeqlocal (flags, lval->ConstVal, lval2.ConstVal);
g_addeqlocal (lflags, lval->ConstVal, lval2.ConstVal);
} else {
g_subeqlocal (flags, lval->ConstVal, lval2.ConstVal);
g_subeqlocal (lflags, lval->ConstVal, lval2.ConstVal);
}
} else if (lval->Flags & E_MCONST) {
/* ref to absolute address */
flags |= CF_ABSOLUTE;
lflags |= CF_ABSOLUTE;
if (Gen->Tok == TOK_PLUS_ASSIGN) {
g_addeqstatic (flags, lval->ConstVal, 0, lval2.ConstVal);
g_addeqstatic (lflags, lval->ConstVal, 0, lval2.ConstVal);
} else {
g_subeqstatic (flags, lval->ConstVal, 0, lval2.ConstVal);
g_subeqstatic (lflags, lval->ConstVal, 0, lval2.ConstVal);
}
} else if (lval->Flags & E_MEXPR) {
/* Address in a/x. */
if (Gen->Tok == TOK_PLUS_ASSIGN) {
g_addeqind (flags, lval->ConstVal, lval2.ConstVal);
g_addeqind (lflags, lval->ConstVal, lval2.ConstVal);
} else {
g_subeqind (flags, lval->ConstVal, lval2.ConstVal);
g_subeqind (lflags, lval->ConstVal, lval2.ConstVal);
}
} else {
Internal ("Invalid addressing mode");