52 lines
1.5 KiB
C
52 lines
1.5 KiB
C
/****************************************************************
|
|
* *
|
|
* Copyright 2001 Sanchez Computer Associates, Inc. *
|
|
* *
|
|
* This source code contains the intellectual property *
|
|
* of its copyright holder(s), and is made available *
|
|
* under a license. If you do not know the terms of *
|
|
* the license, please stop and do not read further. *
|
|
* *
|
|
****************************************************************/
|
|
|
|
#include "mdef.h"
|
|
#include "compiler.h"
|
|
#include "opcode.h"
|
|
#include "mdq.h"
|
|
|
|
#define STO_LPX(X) (*lpx && (*lpx < lptop) ? (*++(*lpx) = ((X)->operand[0].oprval.tref->opcode == OC_LIT) ? (X): 0) : 0)
|
|
#define NOT_CAT(X,Y) ((X)->operand[(Y)].oprval.tref->opcode != OC_CAT)
|
|
|
|
void wrtcatopt(triple *r, triple ***lpx, triple **lptop)
|
|
{
|
|
triple *ref, *w;
|
|
|
|
assert(r->opcode == OC_CAT);
|
|
assert(r->operand[0].oprclass == TRIP_REF);
|
|
assert(r->operand[1].oprclass == TRIP_REF);
|
|
assert(r->operand[0].oprval.tref->opcode == OC_ILIT);
|
|
ref = r->operand[1].oprval.tref;
|
|
r->operand[0].oprclass = r->operand[1].oprclass = 0;
|
|
r->opcode = OC_NOOP;
|
|
for (;;)
|
|
{
|
|
assert(ref->opcode == OC_PARAMETER);
|
|
if (NOT_CAT(ref,0))
|
|
{
|
|
ref->opcode = OC_WRITE;
|
|
STO_LPX(ref);
|
|
}
|
|
else
|
|
{
|
|
wrtcatopt(ref->operand[0].oprval.tref, lpx, lptop);
|
|
ref->operand[0].oprclass = 0;
|
|
ref->opcode = OC_NOOP;
|
|
}
|
|
if (ref->operand[1].oprclass == 0)
|
|
break;
|
|
assert(ref->operand[1].oprclass == TRIP_REF);
|
|
ref->operand[1].oprclass = 0;
|
|
ref = ref->operand[1].oprval.tref;
|
|
}
|
|
}
|