|
|
|
@@ -184,13 +184,13 @@ clean_dirty_tr(tr_fr_ptr TR0 USES_REGS) {
|
|
|
|
|
#define MIN_ARENA_SIZE (1048L)
|
|
|
|
|
|
|
|
|
|
int Yap_copy_complex_term(register CELL *pt0, register CELL *pt0_end,
|
|
|
|
|
bool share, bool copy_att_vars, CELL *ptf,
|
|
|
|
|
bool share, Term *split, bool copy_att_vars, CELL *ptf,
|
|
|
|
|
CELL *HLow USES_REGS) {
|
|
|
|
|
// fprintf(stderr,"+++++++++\n");
|
|
|
|
|
//CELL *x = pt0; while(x != pt0_end) Yap_DebugPlWriteln(*++ x);
|
|
|
|
|
|
|
|
|
|
int lvl = push_text_stack();
|
|
|
|
|
|
|
|
|
|
Term o = TermNil;
|
|
|
|
|
struct cp_frame *to_visit0,
|
|
|
|
|
*to_visit = Malloc(1024*sizeof(struct cp_frame));
|
|
|
|
|
struct cp_frame *to_visit_max;
|
|
|
|
@@ -214,229 +214,264 @@ int Yap_copy_complex_term(register CELL *pt0, register CELL *pt0_end,
|
|
|
|
|
copy_term_nvar : {
|
|
|
|
|
if (IsPairTerm(d0)) {
|
|
|
|
|
CELL *headp = RepPair(d0);
|
|
|
|
|
if (//(share && headp < HB) ||
|
|
|
|
|
(IsPairTerm(*headp) && RepPair(*headp) >= HB && RepPair(*headp) < HR)) {
|
|
|
|
|
if (IsPairTerm(*headp) && RepPair(*headp) >= HB && RepPair(*headp) < HR) {
|
|
|
|
|
if (split) {
|
|
|
|
|
Term v = Yap_MkNewApplTerm(FunctorEq, 2);
|
|
|
|
|
RepAppl(v)[1] = *headp;
|
|
|
|
|
*headp = *ptf++ = RepAppl(v)[0];
|
|
|
|
|
o = MkPairTerm( v, o );
|
|
|
|
|
} else {
|
|
|
|
|
/* If this is newer than the current term, just reuse */
|
|
|
|
|
*ptf++ = (CELL)RepAppl(*headp);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else if (IsApplTerm(*headp) && RepAppl(*headp) >= HB && RepAppl(*headp) < HR) {
|
|
|
|
|
*ptf++ = AbsPair(RepAppl(*headp));
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
if (to_visit >= to_visit_max-32) {
|
|
|
|
|
expand_stack(to_visit0, to_visit, to_visit_max, struct cp_frame);
|
|
|
|
|
}
|
|
|
|
|
*ptf = AbsPair(HR);
|
|
|
|
|
ptf++;
|
|
|
|
|
to_visit->start_cp = pt0;
|
|
|
|
|
to_visit->end_cp = pt0_end;
|
|
|
|
|
to_visit->to = ptf;
|
|
|
|
|
to_visit->curp = headp;
|
|
|
|
|
d0 = *headp;
|
|
|
|
|
to_visit->oldv = d0;
|
|
|
|
|
to_visit->ground = ground;
|
|
|
|
|
to_visit++;
|
|
|
|
|
// move to new list
|
|
|
|
|
if (share) {
|
|
|
|
|
TrailedMaBind(headp,AbsPair(HR));
|
|
|
|
|
} else {
|
|
|
|
|
*headp = AbsPair(HR);
|
|
|
|
|
}
|
|
|
|
|
pt0 = headp;
|
|
|
|
|
pt0_end = headp + 1;
|
|
|
|
|
ptf = HR;
|
|
|
|
|
ground = true;
|
|
|
|
|
HR += 2;
|
|
|
|
|
if (HR > ASP - MIN_ARENA_SIZE) {
|
|
|
|
|
goto overflow;
|
|
|
|
|
}
|
|
|
|
|
ptd0 = pt0;
|
|
|
|
|
goto deref;
|
|
|
|
|
} else if (IsApplTerm(d0)) {
|
|
|
|
|
register Functor f;
|
|
|
|
|
register CELL *headp;
|
|
|
|
|
/* store the terms to visit */
|
|
|
|
|
headp = RepAppl(d0);
|
|
|
|
|
if (IsPairTerm(*headp)//(share && headp < HB) ||
|
|
|
|
|
) {
|
|
|
|
|
if (split) {
|
|
|
|
|
Term v = Yap_MkNewApplTerm(FunctorEq, 2);
|
|
|
|
|
RepAppl(v)[1] = *headp;
|
|
|
|
|
*headp = *ptf++ = RepAppl(v)[0];
|
|
|
|
|
o = MkPairTerm( v, o );
|
|
|
|
|
} else {
|
|
|
|
|
/* If this is newer than the current term, just reuse */
|
|
|
|
|
*ptf++ = *headp;
|
|
|
|
|
continue;
|
|
|
|
|
*ptf++ = AbsPair(RepAppl(*headp));
|
|
|
|
|
}
|
|
|
|
|
if (to_visit >= to_visit_max-32) {
|
|
|
|
|
expand_stack(to_visit0, to_visit, to_visit_max, struct cp_frame);
|
|
|
|
|
}
|
|
|
|
|
*ptf = AbsPair(HR);
|
|
|
|
|
ptf++;
|
|
|
|
|
to_visit->start_cp = pt0;
|
|
|
|
|
to_visit->end_cp = pt0_end;
|
|
|
|
|
to_visit->to = ptf;
|
|
|
|
|
to_visit->ground = ground;
|
|
|
|
|
to_visit++;
|
|
|
|
|
// move to new list
|
|
|
|
|
d0 = *headp;
|
|
|
|
|
TrailedMaBind(headp, AbsPair(HR));
|
|
|
|
|
pt0 = headp;
|
|
|
|
|
pt0_end = headp + 1;
|
|
|
|
|
ptf = HR;
|
|
|
|
|
ground = true;
|
|
|
|
|
HR += 2;
|
|
|
|
|
if (HR > ASP - MIN_ARENA_SIZE) {
|
|
|
|
|
goto overflow;
|
|
|
|
|
}
|
|
|
|
|
ptd0 = pt0;
|
|
|
|
|
goto deref;
|
|
|
|
|
} else if (IsApplTerm(d0)) {
|
|
|
|
|
register Functor f;
|
|
|
|
|
register CELL *headp;
|
|
|
|
|
/* store the terms to visit */
|
|
|
|
|
headp = RepAppl(d0);
|
|
|
|
|
if (IsApplTerm(*headp)//(share && headp < HB) ||
|
|
|
|
|
) {
|
|
|
|
|
/* If this is newer than the current term, just reuse */
|
|
|
|
|
*ptf++ = *headp;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
f = (Functor)(*headp);
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
f = (Functor)(*headp);
|
|
|
|
|
|
|
|
|
|
if (IsExtensionFunctor(f)) {
|
|
|
|
|
switch ((CELL)f) {
|
|
|
|
|
case (CELL) FunctorDBRef:
|
|
|
|
|
case (CELL) FunctorAttVar:
|
|
|
|
|
*ptf++ = d0;
|
|
|
|
|
break;
|
|
|
|
|
case (CELL) FunctorLongInt:
|
|
|
|
|
if (HR > ASP - (MIN_ARENA_SIZE + 3)) {
|
|
|
|
|
goto overflow;
|
|
|
|
|
}
|
|
|
|
|
*ptf++ = AbsAppl(HR);
|
|
|
|
|
HR[0] = (CELL)f;
|
|
|
|
|
HR[1] = headp[1];
|
|
|
|
|
HR[2] = EndSpecials;
|
|
|
|
|
HR += 3;
|
|
|
|
|
if (HR > ASP - MIN_ARENA_SIZE) {
|
|
|
|
|
goto overflow;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case (CELL) FunctorDouble:
|
|
|
|
|
if (HR >
|
|
|
|
|
ASP - (MIN_ARENA_SIZE + (2 + SIZEOF_DOUBLE / sizeof(CELL)))) {
|
|
|
|
|
goto overflow;
|
|
|
|
|
}
|
|
|
|
|
*ptf++ = AbsAppl(HR);
|
|
|
|
|
HR[0] = (CELL)f;
|
|
|
|
|
HR[1] = headp[1];
|
|
|
|
|
if (IsExtensionFunctor(f)) {
|
|
|
|
|
if (share) {
|
|
|
|
|
*ptf++ = d0;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
switch ((CELL)f) {
|
|
|
|
|
case (CELL) FunctorDBRef:
|
|
|
|
|
case (CELL) FunctorAttVar:
|
|
|
|
|
*ptf++ = d0;
|
|
|
|
|
break;
|
|
|
|
|
case (CELL) FunctorLongInt:
|
|
|
|
|
if (HR > ASP - (MIN_ARENA_SIZE + 3)) {
|
|
|
|
|
goto overflow;
|
|
|
|
|
}
|
|
|
|
|
*ptf++ = AbsAppl(HR);
|
|
|
|
|
HR[0] = (CELL)f;
|
|
|
|
|
HR[1] = headp[1];
|
|
|
|
|
HR[2] = EndSpecials;
|
|
|
|
|
HR += 3;
|
|
|
|
|
if (HR > ASP - MIN_ARENA_SIZE) {
|
|
|
|
|
goto overflow;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case (CELL) FunctorDouble:
|
|
|
|
|
if (HR >
|
|
|
|
|
ASP - (MIN_ARENA_SIZE + (2 + SIZEOF_DOUBLE / sizeof(CELL)))) {
|
|
|
|
|
goto overflow;
|
|
|
|
|
}
|
|
|
|
|
*ptf++ = AbsAppl(HR);
|
|
|
|
|
HR[0] = (CELL)f;
|
|
|
|
|
HR[1] = headp[1];
|
|
|
|
|
#if SIZEOF_DOUBLE == 2 * SIZEOF_INT_P
|
|
|
|
|
HR[2] = headp[2];
|
|
|
|
|
HR[3] = EndSpecials;
|
|
|
|
|
HR += 4;
|
|
|
|
|
HR[2] = headp[2];
|
|
|
|
|
HR[3] = EndSpecials;
|
|
|
|
|
HR += 4;
|
|
|
|
|
#else
|
|
|
|
|
HR[2] = EndSpecials;
|
|
|
|
|
HR += 3;
|
|
|
|
|
HR[2] = EndSpecials;
|
|
|
|
|
HR += 3;
|
|
|
|
|
#endif
|
|
|
|
|
break;
|
|
|
|
|
case (CELL) FunctorString:
|
|
|
|
|
if (ASP - HR < MIN_ARENA_SIZE + 3 + headp[1]) {
|
|
|
|
|
goto overflow;
|
|
|
|
|
}
|
|
|
|
|
*ptf++ = AbsAppl(HR);
|
|
|
|
|
memmove(HR, headp, sizeof(CELL) * (3 + headp[1]));
|
|
|
|
|
HR += headp[1] + 3;
|
|
|
|
|
break;
|
|
|
|
|
default: {
|
|
|
|
|
/* big int */
|
|
|
|
|
size_t sz = (sizeof(MP_INT) + 3 * CellSize +
|
|
|
|
|
((MP_INT *)(headp + 2))->_mp_alloc * sizeof(mp_limb_t)) /
|
|
|
|
|
CellSize,
|
|
|
|
|
i;
|
|
|
|
|
|
|
|
|
|
if (HR > ASP - (MIN_ARENA_SIZE + sz)) {
|
|
|
|
|
goto overflow;
|
|
|
|
|
}
|
|
|
|
|
*ptf++ = AbsAppl(HR);
|
|
|
|
|
HR[0] = (CELL)f;
|
|
|
|
|
for (i = 1; i < sz; i++) {
|
|
|
|
|
HR[i] = headp[i];
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
HR += sz;
|
|
|
|
|
break;
|
|
|
|
|
case (CELL) FunctorString:
|
|
|
|
|
if (ASP - HR < MIN_ARENA_SIZE + 3 + headp[1]) {
|
|
|
|
|
goto overflow;
|
|
|
|
|
}
|
|
|
|
|
*ptf++ = AbsAppl(HR);
|
|
|
|
|
memmove(HR, headp, sizeof(CELL) * (3 + headp[1]));
|
|
|
|
|
HR += headp[1] + 3;
|
|
|
|
|
break;
|
|
|
|
|
default: {
|
|
|
|
|
/* big int */
|
|
|
|
|
size_t sz = (sizeof(MP_INT) + 3 * CellSize +
|
|
|
|
|
((MP_INT *)(headp + 2))->_mp_alloc * sizeof(mp_limb_t)) /
|
|
|
|
|
CellSize,
|
|
|
|
|
i;
|
|
|
|
|
|
|
|
|
|
if (HR > ASP - (MIN_ARENA_SIZE + sz)) {
|
|
|
|
|
goto overflow;
|
|
|
|
|
}
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
*ptf = AbsAppl(HR);
|
|
|
|
|
ptf++;
|
|
|
|
|
/* store the terms to visit */
|
|
|
|
|
to_visit->start_cp = pt0;
|
|
|
|
|
to_visit->end_cp = pt0_end;
|
|
|
|
|
to_visit->to = ptf;
|
|
|
|
|
to_visit->ground = ground;
|
|
|
|
|
if (++to_visit >= to_visit_max-32) {
|
|
|
|
|
expand_stack(to_visit0, to_visit, to_visit_max, struct cp_frame);
|
|
|
|
|
*ptf++ = AbsAppl(HR);
|
|
|
|
|
HR[0] = (CELL)f;
|
|
|
|
|
for (i = 1; i < sz; i++) {
|
|
|
|
|
HR[i] = headp[i];
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
HR += sz;
|
|
|
|
|
}
|
|
|
|
|
TrailedMaBind(headp,AbsAppl(HR));
|
|
|
|
|
ptf = HR;
|
|
|
|
|
*ptf++ = (CELL)f;
|
|
|
|
|
ground = true;
|
|
|
|
|
arity_t a = ArityOfFunctor(f);
|
|
|
|
|
HR = ptf+a;
|
|
|
|
|
if (HR > ASP - MIN_ARENA_SIZE) {
|
|
|
|
|
goto overflow;
|
|
|
|
|
}
|
|
|
|
|
pt0 = headp;
|
|
|
|
|
pt0_end = headp+a;
|
|
|
|
|
ground = (f != FunctorMutable);
|
|
|
|
|
} else {
|
|
|
|
|
/* just copy atoms or integers */
|
|
|
|
|
*ptf++ = d0;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
derefa_body(d0, ptd0, copy_term_unk, copy_term_nvar);
|
|
|
|
|
ground = false;
|
|
|
|
|
/* don't need to copy variables if we want to share the global term */
|
|
|
|
|
if (//(share && ptd0 < HB && ptd0 > H0) ||
|
|
|
|
|
(ptd0 >= HLow && ptd0 < HR)) {
|
|
|
|
|
/* we have already found this cell */
|
|
|
|
|
*ptf++ = (CELL)ptd0;
|
|
|
|
|
*ptf = AbsAppl(HR);
|
|
|
|
|
ptf++;
|
|
|
|
|
/* store the terms to visit */
|
|
|
|
|
to_visit->start_cp = pt0;
|
|
|
|
|
to_visit->end_cp = pt0_end;
|
|
|
|
|
to_visit->to = ptf;
|
|
|
|
|
to_visit->curp = headp;
|
|
|
|
|
d0 = *headp;
|
|
|
|
|
to_visit->oldv = d0;
|
|
|
|
|
to_visit->ground = ground;
|
|
|
|
|
if (++to_visit >= to_visit_max-32) {
|
|
|
|
|
expand_stack(to_visit0, to_visit, to_visit_max, struct cp_frame);
|
|
|
|
|
}
|
|
|
|
|
if (share) {
|
|
|
|
|
TrailedMaBind(headp,AbsPair(HR));
|
|
|
|
|
} else {
|
|
|
|
|
*headp = AbsPair(HR);
|
|
|
|
|
}
|
|
|
|
|
ptf = HR;
|
|
|
|
|
ptf[-1] = (CELL)f;
|
|
|
|
|
ground = true;
|
|
|
|
|
arity_t a = ArityOfFunctor(f);
|
|
|
|
|
HR = ptf+a;
|
|
|
|
|
if (HR > ASP - MIN_ARENA_SIZE) {
|
|
|
|
|
goto overflow;
|
|
|
|
|
}
|
|
|
|
|
pt0 = headp;
|
|
|
|
|
pt0_end = headp+a;
|
|
|
|
|
ground = (f != FunctorMutable);
|
|
|
|
|
} else {
|
|
|
|
|
if (copy_att_vars && GlobalIsAttachedTerm((CELL)ptd0)) {
|
|
|
|
|
/* if unbound, call the standard copy term routine */
|
|
|
|
|
struct cp_frame *bp;
|
|
|
|
|
CELL new;
|
|
|
|
|
/* just copy atoms or integers */
|
|
|
|
|
*ptf++ = d0;
|
|
|
|
|
}
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bp = to_visit;
|
|
|
|
|
if (!GLOBAL_attas[ExtFromCell(ptd0)].copy_term_op(ptd0, &bp,
|
|
|
|
|
ptf PASS_REGS)) {
|
|
|
|
|
goto overflow;
|
|
|
|
|
}
|
|
|
|
|
to_visit = bp;
|
|
|
|
|
new = *ptf;
|
|
|
|
|
if (TR > (tr_fr_ptr)LOCAL_TrailTop - 256) {
|
|
|
|
|
/* Trail overflow */
|
|
|
|
|
if (!Yap_growtrail((TR - TR0) * sizeof(tr_fr_ptr *), TRUE)) {
|
|
|
|
|
goto trail_overflow;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
TrailedMaBind(ptd0, new);
|
|
|
|
|
ptf++;
|
|
|
|
|
} else {
|
|
|
|
|
/* first time we met this term */
|
|
|
|
|
RESET_VARIABLE(ptf);
|
|
|
|
|
if ((ADDR)TR > LOCAL_TrailTop - MIN_ARENA_SIZE)
|
|
|
|
|
goto trail_overflow;
|
|
|
|
|
TrailedMaBind(ptd0, (CELL)ptf);
|
|
|
|
|
ptf++;
|
|
|
|
|
derefa_body(d0, ptd0, copy_term_unk, copy_term_nvar);
|
|
|
|
|
ground = false;
|
|
|
|
|
/* don't need to copy variables if we want to share the global term */
|
|
|
|
|
if (//(share && ptd0 < HB && ptd0 > H0) ||
|
|
|
|
|
(ptd0 >= HLow && ptd0 < HR)) {
|
|
|
|
|
/* we have already found this cell */
|
|
|
|
|
*ptf++ = (CELL)ptd0;
|
|
|
|
|
} else {
|
|
|
|
|
if (copy_att_vars && GlobalIsAttachedTerm((CELL)ptd0)) {
|
|
|
|
|
/* if unbound, call the standard copy term routine */
|
|
|
|
|
struct cp_frame *bp;
|
|
|
|
|
CELL new;
|
|
|
|
|
|
|
|
|
|
bp = to_visit;
|
|
|
|
|
if (!GLOBAL_attas[ExtFromCell(ptd0)].copy_term_op(ptd0, &bp,
|
|
|
|
|
ptf PASS_REGS)) {
|
|
|
|
|
goto overflow;
|
|
|
|
|
}
|
|
|
|
|
to_visit = bp;
|
|
|
|
|
new = *ptf;
|
|
|
|
|
if (TR > (tr_fr_ptr)LOCAL_TrailTop - 256) {
|
|
|
|
|
/* Trail overflow */
|
|
|
|
|
if (!Yap_growtrail((TR - TR0) * sizeof(tr_fr_ptr *), TRUE)) {
|
|
|
|
|
goto trail_overflow;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
TrailedMaBind(ptd0, new);
|
|
|
|
|
ptf++;
|
|
|
|
|
} else {
|
|
|
|
|
/* first time we met this term */
|
|
|
|
|
RESET_VARIABLE(ptf);
|
|
|
|
|
if ((ADDR)TR > LOCAL_TrailTop - MIN_ARENA_SIZE)
|
|
|
|
|
goto trail_overflow;
|
|
|
|
|
TrailedMaBind(ptd0, (CELL)ptf);
|
|
|
|
|
ptf++;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Do we still have compound terms to visit */
|
|
|
|
|
if (to_visit > to_visit0) {
|
|
|
|
|
to_visit--;
|
|
|
|
|
pt0 = to_visit->start_cp;
|
|
|
|
|
pt0_end = to_visit->end_cp;
|
|
|
|
|
ptf = to_visit->to;
|
|
|
|
|
ground = (ground && to_visit->ground);
|
|
|
|
|
goto loop;
|
|
|
|
|
}
|
|
|
|
|
/* Do we still have compound terms to visit */
|
|
|
|
|
if (to_visit > to_visit0) {
|
|
|
|
|
to_visit--;
|
|
|
|
|
if (!share)
|
|
|
|
|
*to_visit->curp = to_visit->oldv;
|
|
|
|
|
pt0 = to_visit->start_cp;
|
|
|
|
|
pt0_end = to_visit->end_cp;
|
|
|
|
|
ptf = to_visit->to;
|
|
|
|
|
ground = (ground && to_visit->ground);
|
|
|
|
|
goto loop;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* restore our nice, friendly, term to its original state */
|
|
|
|
|
clean_dirty_tr(TR0 PASS_REGS);
|
|
|
|
|
/* follow chain of multi-assigned variables */
|
|
|
|
|
pop_text_stack(lvl);
|
|
|
|
|
return 0;
|
|
|
|
|
/* restore our nice, friendly, term to its original state */
|
|
|
|
|
clean_dirty_tr(TR0 PASS_REGS);
|
|
|
|
|
/* follow chain of multi-assigned variables */
|
|
|
|
|
pop_text_stack(lvl);
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
overflow:
|
|
|
|
|
/* oops, we're in trouble */
|
|
|
|
|
HR = HLow;
|
|
|
|
|
/* we've done it */
|
|
|
|
|
/* restore our nice, friendly, term to its original state */
|
|
|
|
|
HB = HB0;
|
|
|
|
|
while (to_visit > to_visit0) {
|
|
|
|
|
to_visit--;
|
|
|
|
|
pt0 = to_visit->start_cp;
|
|
|
|
|
pt0_end = to_visit->end_cp;
|
|
|
|
|
ptf = to_visit->to;
|
|
|
|
|
}
|
|
|
|
|
reset_trail(TR0);
|
|
|
|
|
pop_text_stack(lvl);
|
|
|
|
|
return -1;
|
|
|
|
|
overflow:
|
|
|
|
|
/* oops, we're in trouble */
|
|
|
|
|
HR = HLow;
|
|
|
|
|
/* we've done it */
|
|
|
|
|
/* restore our nice, friendly, term to its original state */
|
|
|
|
|
HB = HB0;
|
|
|
|
|
while (to_visit > to_visit0) {
|
|
|
|
|
to_visit--;
|
|
|
|
|
pt0 = to_visit->start_cp;
|
|
|
|
|
pt0_end = to_visit->end_cp;
|
|
|
|
|
ptf = to_visit->to;
|
|
|
|
|
}
|
|
|
|
|
reset_trail(TR0);
|
|
|
|
|
pop_text_stack(lvl);
|
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
|
|
trail_overflow:
|
|
|
|
|
/* oops, we're in trouble */
|
|
|
|
|
HR = HLow;
|
|
|
|
|
/* we've done it */
|
|
|
|
|
/* restore our nice, friendly, term to its original state */
|
|
|
|
|
HB = HB0;
|
|
|
|
|
while (to_visit > to_visit0) {
|
|
|
|
|
to_visit--;
|
|
|
|
|
pt0 = to_visit->start_cp;
|
|
|
|
|
pt0_end = to_visit->end_cp;
|
|
|
|
|
ptf = to_visit->to;
|
|
|
|
|
}
|
|
|
|
|
reset_trail(TR0);
|
|
|
|
|
pop_text_stack(lvl);
|
|
|
|
|
return -4;
|
|
|
|
|
trail_overflow:
|
|
|
|
|
/* oops, we're in trouble */
|
|
|
|
|
HR = HLow;
|
|
|
|
|
/* we've done it */
|
|
|
|
|
/* restore our nice, friendly, term to its original state */
|
|
|
|
|
HB = HB0;
|
|
|
|
|
while (to_visit > to_visit0) {
|
|
|
|
|
to_visit--;
|
|
|
|
|
pt0 = to_visit->start_cp;
|
|
|
|
|
pt0_end = to_visit->end_cp;
|
|
|
|
|
ptf = to_visit->to;
|
|
|
|
|
}
|
|
|
|
|
reset_trail(TR0);
|
|
|
|
|
pop_text_stack(lvl);
|
|
|
|
|
return -4;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@@ -492,7 +527,7 @@ CopyTerm(Term inp, UInt arity, int share, int newattvs USES_REGS) {
|
|
|
|
|
*HR = t;
|
|
|
|
|
Hi = HR+1;
|
|
|
|
|
HR += 2;
|
|
|
|
|
if ((res = Yap_copy_complex_term(Hi-2, Hi-1, share, newattvs, Hi, Hi PASS_REGS)) < 0) {
|
|
|
|
|
if ((res = Yap_copy_complex_term(Hi-2, Hi-1, share, NULL, newattvs, Hi, Hi PASS_REGS)) < 0) {
|
|
|
|
|
HR = Hi-1;
|
|
|
|
|
if ((t = handle_cp_overflow(res, TR0, arity, t))== 0L)
|
|
|
|
|
return FALSE;
|
|
|
|
@@ -516,7 +551,7 @@ CopyTerm(Term inp, UInt arity, int share, int newattvs USES_REGS) {
|
|
|
|
|
HR += 2;
|
|
|
|
|
{
|
|
|
|
|
int res;
|
|
|
|
|
if ((res = Yap_copy_complex_term(ap-1, ap+1, share, newattvs, Hi, Hi PASS_REGS)) < 0) {
|
|
|
|
|
if ((res = Yap_copy_complex_term(ap-1, ap+1, share, NULL, newattvs, Hi, Hi PASS_REGS)) < 0) {
|
|
|
|
|
HR = Hi;
|
|
|
|
|
if ((t = handle_cp_overflow(res, TR0, arity, t))== 0L)
|
|
|
|
|
return FALSE;
|
|
|
|
@@ -548,7 +583,7 @@ CopyTerm(Term inp, UInt arity, int share, int newattvs USES_REGS) {
|
|
|
|
|
} else {
|
|
|
|
|
int res;
|
|
|
|
|
|
|
|
|
|
if ((res = Yap_copy_complex_term(ap, ap+ArityOfFunctor(f), share, newattvs, HB0+1, HB0 PASS_REGS)) < 0) {
|
|
|
|
|
if ((res = Yap_copy_complex_term(ap, ap+ArityOfFunctor(f), share, NULL, newattvs, HB0+1, HB0 PASS_REGS)) < 0) {
|
|
|
|
|
HR = HB0;
|
|
|
|
|
if ((t = handle_cp_overflow(res, TR0, arity, t))== 0L)
|
|
|
|
|
return FALSE;
|
|
|
|
|