2008-06-04 15:47:18 +01:00
|
|
|
#ifdef FROZEN_STACKS
|
2017-07-30 21:53:07 +01:00
|
|
|
{
|
2017-09-06 01:13:00 +01:00
|
|
|
tr_fr_ptr pt0, pt1, pbase, ptop;
|
|
|
|
pbase = B->cp_tr, ptop = TR;
|
2017-07-30 21:53:07 +01:00
|
|
|
pt0 = pt1 = TR - 1;
|
|
|
|
while (pt1 >= pbase) {
|
|
|
|
BEGD(d1);
|
|
|
|
d1 = TrailTerm(pt1);
|
|
|
|
if (IsVarTerm(d1)) {
|
|
|
|
if (d1 < (CELL)HBREG || d1 > Unsigned(B->cp_b)) {
|
|
|
|
TrailTerm(pt0) = d1;
|
|
|
|
TrailVal(pt0) = TrailVal(pt1);
|
|
|
|
pt0--;
|
|
|
|
}
|
|
|
|
pt1--;
|
|
|
|
} else if (IsPairTerm(d1)) {
|
|
|
|
CELL *pt = RepPair(d1);
|
2008-06-04 15:47:18 +01:00
|
|
|
#ifdef LIMIT_TABLING
|
2017-07-30 21:53:07 +01:00
|
|
|
if ((ADDR)pt == LOCAL_TrailBase) {
|
|
|
|
sg_fr_ptr sg_fr = (sg_fr_ptr)TrailVal(pt1);
|
|
|
|
SgFr_state(sg_fr)--; /* complete_in_use --> complete : compiled_in_use
|
|
|
|
--> compiled */
|
|
|
|
insert_into_global_sg_fr_list(sg_fr);
|
|
|
|
} else
|
2008-06-04 15:47:18 +01:00
|
|
|
#endif /* LIMIT_TABLING */
|
2017-07-30 21:53:07 +01:00
|
|
|
if (IN_BETWEEN(LOCAL_TrailBase, pt, LOCAL_TrailTop)) {
|
|
|
|
/* skip, this is a problem because we lose information,
|
|
|
|
namely active references */
|
|
|
|
pt1 = (tr_fr_ptr)pt;
|
|
|
|
} else if (IN_BETWEEN(H0, pt, HR) && IsApplTerm(HeadOfTerm(d1))) {
|
|
|
|
Term t = HeadOfTerm(d1);
|
|
|
|
Functor f = FunctorOfTerm(t);
|
|
|
|
if (f == FunctorBigInt) {
|
|
|
|
Int tag = Yap_blob_tag(t) - USER_BLOB_START;
|
|
|
|
GLOBAL_OpaqueHandlers[tag].cut_handler(d1);
|
|
|
|
} else {
|
|
|
|
pt0--;
|
|
|
|
}
|
|
|
|
pt1--;
|
|
|
|
continue;
|
|
|
|
} else if ((*pt & (LogUpdMask | IndexMask)) == (LogUpdMask | IndexMask)) {
|
|
|
|
LogUpdIndex *cl = ClauseFlagsToLogUpdIndex(pt);
|
|
|
|
int erase;
|
2008-06-04 15:47:18 +01:00
|
|
|
#if defined(THREADS) || defined(YAPOR)
|
2017-07-30 21:53:07 +01:00
|
|
|
PredEntry *ap = cl->ClPred;
|
2008-06-04 15:47:18 +01:00
|
|
|
#endif
|
2017-07-30 21:53:07 +01:00
|
|
|
|
|
|
|
LOCK(ap->PELock);
|
|
|
|
DEC_CLREF_COUNT(cl);
|
|
|
|
cl->ClFlags &= ~InUseMask;
|
|
|
|
erase = (cl->ClFlags & (ErasedMask | DirtyMask)) && !(cl->ClRefCount);
|
|
|
|
if (erase) {
|
|
|
|
/* at this point, we are the only ones accessing the clause,
|
|
|
|
hence we don't need to have a lock it */
|
|
|
|
if (cl->ClFlags & ErasedMask)
|
|
|
|
Yap_ErLogUpdIndex(cl);
|
|
|
|
else
|
|
|
|
Yap_CleanUpIndex(cl);
|
|
|
|
}
|
|
|
|
UNLOCK(ap->PELock);
|
2008-06-04 15:47:18 +01:00
|
|
|
} else {
|
2017-07-30 21:53:07 +01:00
|
|
|
TrailTerm(pt0) = d1;
|
|
|
|
TrailVal(pt0) = TrailVal(pt1);
|
|
|
|
pt0--;
|
2008-06-04 15:47:18 +01:00
|
|
|
}
|
2017-07-30 21:53:07 +01:00
|
|
|
pt1--;
|
|
|
|
} else if (IsApplTerm(d1)) {
|
|
|
|
if (IN_BETWEEN(HBREG, RepAppl(d1), B->cp_b)) {
|
|
|
|
/* deterministic binding to multi-assignment variable */
|
|
|
|
pt1 -= 2;
|
|
|
|
} else {
|
|
|
|
TrailVal(pt0) = TrailVal(pt1);
|
|
|
|
TrailTerm(pt0) = d1;
|
|
|
|
TrailVal(pt0 - 1) = TrailVal(pt1 - 1);
|
|
|
|
TrailTerm(pt0 - 1) = TrailTerm(pt1 - 1);
|
|
|
|
pt0 -= 2;
|
|
|
|
pt1 -= 2;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
TrailTerm(pt0) = d1;
|
|
|
|
TrailVal(pt0) = TrailVal(pt1);
|
|
|
|
pt0--;
|
|
|
|
pt1--;
|
2008-06-04 15:47:18 +01:00
|
|
|
}
|
2017-07-30 21:53:07 +01:00
|
|
|
ENDD(d1);
|
|
|
|
}
|
|
|
|
if (pt0 != pt1) {
|
|
|
|
int size;
|
|
|
|
pt0++;
|
2017-09-06 01:13:00 +01:00
|
|
|
size = ptop - pt0;
|
2017-07-30 21:53:07 +01:00
|
|
|
memmove(pbase, pt0, size * sizeof(struct trail_frame));
|
2017-09-06 01:13:00 +01:00
|
|
|
if (ptop != TR) {
|
|
|
|
memmove(pbase + size, ptop, (TR - ptop) * sizeof(struct trail_frame));
|
|
|
|
size += (TR - ptop);
|
|
|
|
}
|
2017-07-30 21:53:07 +01:00
|
|
|
TR = pbase + size;
|
2008-06-04 15:47:18 +01:00
|
|
|
}
|
2017-07-30 21:53:07 +01:00
|
|
|
}
|
2008-06-04 15:47:18 +01:00
|
|
|
#else
|
2017-07-30 21:53:07 +01:00
|
|
|
{
|
|
|
|
tr_fr_ptr pt1, pt0;
|
|
|
|
pt1 = pt0 = B->cp_tr;
|
|
|
|
while (pt1 != TR) {
|
|
|
|
BEGD(d1);
|
|
|
|
d1 = TrailTerm(pt1);
|
|
|
|
if (IsVarTerm(d1)) {
|
|
|
|
if (d1 < (CELL)HBREG || d1 > Unsigned(B->cp_b)) {
|
2008-06-04 15:47:18 +01:00
|
|
|
#ifdef FROZEN_STACKS
|
2017-07-30 21:53:07 +01:00
|
|
|
TrailVal(pt0) = TrailVal(pt1);
|
2008-06-04 15:47:18 +01:00
|
|
|
#endif /* FROZEN_STACKS */
|
2017-07-30 21:53:07 +01:00
|
|
|
TrailTerm(pt0) = d1;
|
|
|
|
pt0++;
|
|
|
|
}
|
|
|
|
pt1++;
|
|
|
|
} else if (IsApplTerm(d1)) {
|
|
|
|
if (IN_BETWEEN(HBREG, RepAppl(d1), B->cp_b)) {
|
2008-06-04 15:47:18 +01:00
|
|
|
#ifdef FROZEN_STACKS
|
2017-07-30 21:53:07 +01:00
|
|
|
pt1 += 2;
|
2008-06-04 15:47:18 +01:00
|
|
|
#else
|
2017-07-30 21:53:07 +01:00
|
|
|
pt1 += 3;
|
2008-06-04 15:47:18 +01:00
|
|
|
#endif
|
2017-07-30 21:53:07 +01:00
|
|
|
} else {
|
2008-06-04 15:47:18 +01:00
|
|
|
#ifdef FROZEN_STACKS
|
2017-07-30 21:53:07 +01:00
|
|
|
TrailVal(pt0) = TrailVal(pt1);
|
|
|
|
TrailTerm(pt0) = d1;
|
|
|
|
TrailVal(pt0 + 1) = TrailVal(pt1 + 1);
|
|
|
|
TrailTerm(pt0 + 1) = TrailTerm(pt1 + 1);
|
|
|
|
pt0 += 2;
|
|
|
|
pt1 += 2;
|
2008-06-04 15:47:18 +01:00
|
|
|
#else
|
2017-07-30 21:53:07 +01:00
|
|
|
TrailTerm(pt0 + 1) = TrailTerm(pt1 + 1);
|
|
|
|
TrailTerm(pt0) = TrailTerm(pt0 + 2) = d1;
|
|
|
|
pt0 += 3;
|
|
|
|
pt1 += 3;
|
2008-06-04 15:47:18 +01:00
|
|
|
#endif /* FROZEN_STACKS */
|
2017-07-30 21:53:07 +01:00
|
|
|
}
|
|
|
|
} else if (IsPairTerm(d1)) {
|
|
|
|
CELL *pt = RepPair(d1);
|
|
|
|
|
|
|
|
else if (IN_BETWEEN(H0, pt, HR) && IsApplTerm(HeadOfTerm(d1))) {
|
|
|
|
Term t = HeadOfTerm(d1);
|
|
|
|
Functor f = FunctorOfTerm(t);
|
|
|
|
if (f == FunctorBigInt) {
|
|
|
|
RESET_VARIABLE(&TrailTerm(pt1));
|
|
|
|
Int tag = Yap_blob_tag(t);
|
|
|
|
GLOBAL_OpaqueHandlers[tag].cut_handler(d1);
|
|
|
|
} else if ((*pt & (LogUpdMask | IndexMask)) ==
|
|
|
|
(LogUpdMask | IndexMask)) {
|
|
|
|
LogUpdIndex *cl = ClauseFlagsToLogUpdIndex(pt);
|
2008-06-04 15:47:18 +01:00
|
|
|
#if defined(YAPOR) || defined(THREADS)
|
2017-07-30 21:53:07 +01:00
|
|
|
PredEntry *ap = cl->ClPred;
|
2008-06-04 15:47:18 +01:00
|
|
|
#endif
|
2017-07-30 21:53:07 +01:00
|
|
|
int erase;
|
2008-06-04 15:47:18 +01:00
|
|
|
|
2017-07-30 21:53:07 +01:00
|
|
|
LOCK(ap->PELock);
|
|
|
|
DEC_CLREF_COUNT(cl);
|
|
|
|
cl->ClFlags &= ~InUseMask;
|
|
|
|
erase = (cl->ClFlags & (DirtyMask | ErasedMask)) && !(cl->ClRefCount);
|
|
|
|
if (erase) {
|
|
|
|
/* at this point, we are the only ones accessing the clause,
|
|
|
|
hence we don't need to have a lock it */
|
|
|
|
if (cl->ClFlags & ErasedMask)
|
|
|
|
Yap_ErLogUpdIndex(cl);
|
|
|
|
else
|
|
|
|
Yap_CleanUpIndex(cl);
|
|
|
|
}
|
|
|
|
UNLOCK(ap->PELock);
|
|
|
|
} else {
|
|
|
|
TrailTerm(pt0) = d1;
|
|
|
|
pt0++;
|
|
|
|
}
|
|
|
|
pt1++;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
TrailTerm(pt0) = d1;
|
|
|
|
pt0++;
|
|
|
|
pt1++;
|
2008-06-04 15:47:18 +01:00
|
|
|
}
|
2017-07-30 21:53:07 +01:00
|
|
|
ENDD(d1);
|
2008-06-04 15:47:18 +01:00
|
|
|
}
|
|
|
|
TR = pt0;
|
|
|
|
}
|
|
|
|
#endif /* FROZEN_STACKS */
|