new version of attributed variable code, using arena to store variables and
removing variable chain.
This commit is contained in:
parent
76c6e06b45
commit
e992b0dcf0
177
C/attvar.c
177
C/attvar.c
@ -67,21 +67,32 @@ AddFailToQueue(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static attvar_record *
|
||||||
|
BuildNewAttVar(void)
|
||||||
|
{
|
||||||
|
attvar_record *newv;
|
||||||
|
|
||||||
|
/* add a new attributed variable */
|
||||||
|
if (!(newv = (attvar_record *)Yap_GetFromArena(&GlobalArena, sizeof(attvar_record)/sizeof(CELL),2)))
|
||||||
|
return NULL;
|
||||||
|
newv->AttFunc = FunctorAttVar;
|
||||||
|
RESET_VARIABLE(&(newv->Value));
|
||||||
|
RESET_VARIABLE(&(newv->Done));
|
||||||
|
RESET_VARIABLE(&(newv->Atts));
|
||||||
|
HB = PROTECT_FROZEN_H(B);
|
||||||
|
return newv;
|
||||||
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
CopyAttVar(CELL *orig, struct cp_frame **to_visit_ptr, CELL *res)
|
CopyAttVar(CELL *orig, struct cp_frame **to_visit_ptr, CELL *res)
|
||||||
{
|
{
|
||||||
register attvar_record *attv = (attvar_record *)orig;
|
register attvar_record *attv = RepAttVar(orig);
|
||||||
register attvar_record *newv;
|
register attvar_record *newv;
|
||||||
struct cp_frame *to_visit = *to_visit_ptr;
|
struct cp_frame *to_visit = *to_visit_ptr;
|
||||||
CELL *vt;
|
CELL *vt;
|
||||||
|
|
||||||
/* add a new attributed variable */
|
if (!(newv = BuildNewAttVar()))
|
||||||
newv = DelayTop();
|
|
||||||
if ((ADDR)newv - Yap_GlobalBase < 1024*sizeof(CELL))
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
newv--;
|
|
||||||
RESET_VARIABLE(&(newv->Value));
|
|
||||||
RESET_VARIABLE(&(newv->Done));
|
|
||||||
vt = &(attv->Atts);
|
vt = &(attv->Atts);
|
||||||
to_visit->start_cp = vt-1;
|
to_visit->start_cp = vt-1;
|
||||||
to_visit->end_cp = vt;
|
to_visit->end_cp = vt;
|
||||||
@ -97,32 +108,17 @@ CopyAttVar(CELL *orig, struct cp_frame **to_visit_ptr, CELL *res)
|
|||||||
to_visit->ground = FALSE;
|
to_visit->ground = FALSE;
|
||||||
*to_visit_ptr = to_visit+1;
|
*to_visit_ptr = to_visit+1;
|
||||||
*res = (CELL)&(newv->Done);
|
*res = (CELL)&(newv->Done);
|
||||||
SetDelayTop(newv);
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static Term
|
static Term
|
||||||
AttVarToTerm(CELL *orig)
|
AttVarToTerm(CELL *orig)
|
||||||
{
|
{
|
||||||
attvar_record *attv = (attvar_record *)orig;
|
attvar_record *attv = RepAttVar(orig);
|
||||||
|
|
||||||
return attv->Atts;
|
return attv->Atts;
|
||||||
}
|
}
|
||||||
|
|
||||||
static attvar_record *
|
|
||||||
BuildNewAttVar(void)
|
|
||||||
{
|
|
||||||
attvar_record *attv = DelayTop();
|
|
||||||
if ((ADDR)attv - Yap_GlobalBase < 1024*sizeof(CELL))
|
|
||||||
return FALSE;
|
|
||||||
attv--;
|
|
||||||
RESET_VARIABLE(&(attv->Done));
|
|
||||||
RESET_VARIABLE(&(attv->Value));
|
|
||||||
RESET_VARIABLE(&(attv->Atts));
|
|
||||||
SetDelayTop(attv);
|
|
||||||
return attv;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
TermToAttVar(Term attvar, Term to)
|
TermToAttVar(Term attvar, Term to)
|
||||||
{
|
{
|
||||||
@ -130,7 +126,7 @@ TermToAttVar(Term attvar, Term to)
|
|||||||
if (!attv)
|
if (!attv)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
attv->Atts = attvar;
|
attv->Atts = attvar;
|
||||||
*VarOfTerm(to) = (CELL)attv;
|
*VarOfTerm(to) = AbsAttVar(attv);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -139,7 +135,7 @@ WakeAttVar(CELL* pt1, CELL reg2)
|
|||||||
{
|
{
|
||||||
|
|
||||||
/* if bound to someone else, follow until we find the last one */
|
/* if bound to someone else, follow until we find the last one */
|
||||||
attvar_record *attv = (attvar_record *)pt1;
|
attvar_record *attv = RepAttVar(pt1);
|
||||||
CELL *myH = H;
|
CELL *myH = H;
|
||||||
CELL *bind_ptr;
|
CELL *bind_ptr;
|
||||||
|
|
||||||
@ -147,7 +143,7 @@ WakeAttVar(CELL* pt1, CELL reg2)
|
|||||||
if (pt1 == VarOfTerm(reg2))
|
if (pt1 == VarOfTerm(reg2))
|
||||||
return;
|
return;
|
||||||
if (IsAttachedTerm(reg2)) {
|
if (IsAttachedTerm(reg2)) {
|
||||||
attvar_record *susp2 = (attvar_record *)VarOfTerm(reg2);
|
attvar_record *susp2 = RepAttVar(VarOfTerm(reg2));
|
||||||
|
|
||||||
/* binding two suspended variables, be careful */
|
/* binding two suspended variables, be careful */
|
||||||
if (susp2 >= attv) {
|
if (susp2 >= attv) {
|
||||||
@ -196,11 +192,7 @@ Yap_WakeUp(CELL *pt0) {
|
|||||||
static void
|
static void
|
||||||
mark_attvar(CELL *orig)
|
mark_attvar(CELL *orig)
|
||||||
{
|
{
|
||||||
register attvar_record *attv = (attvar_record *)orig;
|
return;
|
||||||
|
|
||||||
Yap_mark_external_reference(&(attv->Value));
|
|
||||||
Yap_mark_external_reference(&(attv->Done));
|
|
||||||
Yap_mark_external_reference(&(attv->Atts));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static Term
|
static Term
|
||||||
@ -388,11 +380,11 @@ BindAttVar(attvar_record *attv) {
|
|||||||
Term t = Deref(attv->Value);
|
Term t = Deref(attv->Value);
|
||||||
if (IsVarTerm(t)) {
|
if (IsVarTerm(t)) {
|
||||||
if (IsAttachedTerm(t)) {
|
if (IsAttachedTerm(t)) {
|
||||||
attvar_record *attv2 = (attvar_record *)VarOfTerm(t);
|
attvar_record *attv2 = RepAttVar(VarOfTerm(t));
|
||||||
if (attv2 < attv) {
|
if (attv2 < attv) {
|
||||||
Bind_Global(&(attv->Done), t);
|
Bind_Global(&(attv->Done), t);
|
||||||
} else {
|
} else {
|
||||||
Bind_Global(&(attv2->Done), (CELL)attv);
|
Bind_Global(&(attv2->Done), AbsAttVar(attv));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Yap_Error(SYSTEM_ERROR,(CELL)&(attv->Done),"attvar was bound when unset");
|
Yap_Error(SYSTEM_ERROR,(CELL)&(attv->Done),"attvar was bound when unset");
|
||||||
@ -421,43 +413,6 @@ GetAllAtts(attvar_record *attv) {
|
|||||||
return attv->Atts;
|
return attv->Atts;
|
||||||
}
|
}
|
||||||
|
|
||||||
static Term
|
|
||||||
AllAttVars(attvar_record *attv) {
|
|
||||||
CELL *h0 = H;
|
|
||||||
attvar_record *max = DelayTop();
|
|
||||||
|
|
||||||
while (--attv >= max) {
|
|
||||||
if (ASP - H < 1024) {
|
|
||||||
H = h0;
|
|
||||||
Yap_Error_Size = (ASP-H)*sizeof(CELL);
|
|
||||||
return 0L;
|
|
||||||
}
|
|
||||||
if (IsVarTerm(attv->Done) && IsUnboundVar(&attv->Done)) {
|
|
||||||
if (IsVarTerm(attv->Atts)) {
|
|
||||||
if (VarOfTerm(attv->Atts) < (CELL *)attv) {
|
|
||||||
/* skip call residue(s) */
|
|
||||||
attv = (attvar_record *)(attv->Atts);
|
|
||||||
continue;
|
|
||||||
} else if (IsUnboundVar(&attv->Atts)) {
|
|
||||||
/* ignore arena */
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (H != h0) {
|
|
||||||
H[-1] = AbsPair(H);
|
|
||||||
}
|
|
||||||
H[0] = (CELL)attv;
|
|
||||||
H += 2;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (H != h0) {
|
|
||||||
H[-1] = TermNil;
|
|
||||||
return AbsPair(h0);
|
|
||||||
} else {
|
|
||||||
return TermNil;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static Int
|
static Int
|
||||||
p_put_att(void) {
|
p_put_att(void) {
|
||||||
/* receive a variable in ARG1 */
|
/* receive a variable in ARG1 */
|
||||||
@ -472,11 +427,12 @@ p_put_att(void) {
|
|||||||
int new = FALSE;
|
int new = FALSE;
|
||||||
|
|
||||||
if (IsAttachedTerm(inp)) {
|
if (IsAttachedTerm(inp)) {
|
||||||
attv = (attvar_record *)VarOfTerm(inp);
|
attv = RepAttVar(VarOfTerm(inp));
|
||||||
} else {
|
} else {
|
||||||
while (!(attv = BuildNewAttVar())) {
|
while (!(attv = BuildNewAttVar())) {
|
||||||
if (!Yap_growglobal(NULL)) {
|
Yap_Error_Size = sizeof(attvar_record);
|
||||||
Yap_Error(OUT_OF_ATTVARS_ERROR, ARG1, Yap_ErrorMessage);
|
if (!Yap_gcl(Yap_Error_Size, 5, ENV, gc_P(P,CP))) {
|
||||||
|
Yap_Error(OUT_OF_STACK_ERROR, TermNil, Yap_ErrorMessage);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
inp = Deref(ARG1);
|
inp = Deref(ARG1);
|
||||||
@ -491,7 +447,7 @@ p_put_att(void) {
|
|||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Yap_unify(ARG1, (Term)attv);
|
Yap_unify(ARG1, AbsAttVar(attv));
|
||||||
AddNewModule(attv,tatts,new,TRUE);
|
AddNewModule(attv,tatts,new,TRUE);
|
||||||
}
|
}
|
||||||
PutAtt(IntegerOfTerm(Deref(ARG4)), tatts, Deref(ARG5));
|
PutAtt(IntegerOfTerm(Deref(ARG4)), tatts, Deref(ARG5));
|
||||||
@ -512,11 +468,12 @@ p_put_att_term(void) {
|
|||||||
int new = FALSE;
|
int new = FALSE;
|
||||||
|
|
||||||
if (IsAttachedTerm(inp)) {
|
if (IsAttachedTerm(inp)) {
|
||||||
attv = (attvar_record *)VarOfTerm(inp);
|
attv = RepAttVar(VarOfTerm(inp));
|
||||||
} else {
|
} else {
|
||||||
while (!(attv = BuildNewAttVar())) {
|
while (!(attv = BuildNewAttVar())) {
|
||||||
if (!Yap_growglobal(NULL)) {
|
Yap_Error_Size = sizeof(attvar_record);
|
||||||
Yap_Error(OUT_OF_ATTVARS_ERROR, ARG1, Yap_ErrorMessage);
|
if (!Yap_gcl(Yap_Error_Size, 5, ENV, gc_P(P,CP))) {
|
||||||
|
Yap_Error(OUT_OF_STACK_ERROR, TermNil, Yap_ErrorMessage);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
inp = Deref(ARG1);
|
inp = Deref(ARG1);
|
||||||
@ -524,7 +481,7 @@ p_put_att_term(void) {
|
|||||||
new = TRUE;
|
new = TRUE;
|
||||||
}
|
}
|
||||||
if (new) {
|
if (new) {
|
||||||
Bind(VarOfTerm(inp), (CELL)attv);
|
Bind(VarOfTerm(inp), AbsAttVar(attv));
|
||||||
attv->Atts = Deref(ARG2);
|
attv->Atts = Deref(ARG2);
|
||||||
} else {
|
} else {
|
||||||
MaBind(&(attv->Atts), Deref(ARG2));
|
MaBind(&(attv->Atts), Deref(ARG2));
|
||||||
@ -550,17 +507,18 @@ p_rm_att(void) {
|
|||||||
int new = FALSE;
|
int new = FALSE;
|
||||||
|
|
||||||
if (IsAttachedTerm(inp)) {
|
if (IsAttachedTerm(inp)) {
|
||||||
attv = (attvar_record *)VarOfTerm(inp);
|
attv = RepAttVar(VarOfTerm(inp));
|
||||||
} else {
|
} else {
|
||||||
while (!(attv = BuildNewAttVar())) {
|
while (!(attv = BuildNewAttVar())) {
|
||||||
if (!Yap_growglobal(NULL)) {
|
Yap_Error_Size = sizeof(attvar_record);
|
||||||
Yap_Error(OUT_OF_ATTVARS_ERROR, ARG1, Yap_ErrorMessage);
|
if (!Yap_gcl(Yap_Error_Size, 5, ENV, gc_P(P,CP))) {
|
||||||
|
Yap_Error(OUT_OF_STACK_ERROR, TermNil, Yap_ErrorMessage);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
inp = Deref(ARG1);
|
inp = Deref(ARG1);
|
||||||
}
|
}
|
||||||
new = TRUE;
|
new = TRUE;
|
||||||
Yap_unify(ARG1, (Term)attv);
|
Yap_unify(ARG1, AbsAttVar(attv));
|
||||||
}
|
}
|
||||||
mfun= Yap_MkFunctor(modname,ar);
|
mfun= Yap_MkFunctor(modname,ar);
|
||||||
if (IsVarTerm(tatts = SearchAttsForModule(attv->Atts,mfun))) {
|
if (IsVarTerm(tatts = SearchAttsForModule(attv->Atts,mfun))) {
|
||||||
@ -595,17 +553,18 @@ p_put_atts(void) {
|
|||||||
int new = FALSE;
|
int new = FALSE;
|
||||||
|
|
||||||
if (IsAttachedTerm(inp)) {
|
if (IsAttachedTerm(inp)) {
|
||||||
attv = (attvar_record *)VarOfTerm(inp);
|
attv = RepAttVar(VarOfTerm(inp));
|
||||||
} else {
|
} else {
|
||||||
while (!(attv = BuildNewAttVar())) {
|
while (!(attv = BuildNewAttVar())) {
|
||||||
if (!Yap_growglobal(NULL)) {
|
Yap_Error_Size = sizeof(attvar_record);
|
||||||
Yap_Error(OUT_OF_ATTVARS_ERROR, ARG1, Yap_ErrorMessage);
|
if (!Yap_gcl(Yap_Error_Size, 5, ENV, gc_P(P,CP))) {
|
||||||
|
Yap_Error(OUT_OF_STACK_ERROR, TermNil, Yap_ErrorMessage);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
tatts = Deref(ARG2);
|
tatts = Deref(ARG2);
|
||||||
}
|
}
|
||||||
new = TRUE;
|
new = TRUE;
|
||||||
Yap_unify(ARG1, (Term)attv);
|
Yap_unify(ARG1, AbsAttVar(attv));
|
||||||
}
|
}
|
||||||
if (IsVarTerm(otatts = SearchAttsForModule(attv->Atts,mfun))) {
|
if (IsVarTerm(otatts = SearchAttsForModule(attv->Atts,mfun))) {
|
||||||
AddNewModule(attv,tatts,new,FALSE);
|
AddNewModule(attv,tatts,new,FALSE);
|
||||||
@ -632,7 +591,7 @@ p_del_atts(void) {
|
|||||||
Functor mfun = FunctorOfTerm(tatts);
|
Functor mfun = FunctorOfTerm(tatts);
|
||||||
|
|
||||||
if (IsAttachedTerm(inp)) {
|
if (IsAttachedTerm(inp)) {
|
||||||
attv = (attvar_record *)VarOfTerm(inp);
|
attv = RepAttVar(VarOfTerm(inp));
|
||||||
} else {
|
} else {
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
@ -656,7 +615,7 @@ p_del_all_atts(void) {
|
|||||||
if (IsVarTerm(inp) && IsAttachedTerm(inp)) {
|
if (IsVarTerm(inp) && IsAttachedTerm(inp)) {
|
||||||
attvar_record *attv;
|
attvar_record *attv;
|
||||||
|
|
||||||
attv = (attvar_record *)VarOfTerm(inp);
|
attv = RepAttVar(VarOfTerm(inp));
|
||||||
DelAllAtts(attv);
|
DelAllAtts(attv);
|
||||||
}
|
}
|
||||||
return TRUE;
|
return TRUE;
|
||||||
@ -674,7 +633,7 @@ p_get_att(void) {
|
|||||||
attvar_record *attv;
|
attvar_record *attv;
|
||||||
Term tout, tatts;
|
Term tout, tatts;
|
||||||
|
|
||||||
attv = (attvar_record *)VarOfTerm(inp);
|
attv = RepAttVar(VarOfTerm(inp));
|
||||||
if (IsVarTerm(tatts = SearchAttsForModuleName(attv->Atts,modname)))
|
if (IsVarTerm(tatts = SearchAttsForModuleName(attv->Atts,modname)))
|
||||||
return FALSE;
|
return FALSE;
|
||||||
tout = ArgOfTerm(IntegerOfTerm(Deref(ARG3)),tatts);
|
tout = ArgOfTerm(IntegerOfTerm(Deref(ARG3)),tatts);
|
||||||
@ -702,7 +661,7 @@ p_free_att(void) {
|
|||||||
attvar_record *attv;
|
attvar_record *attv;
|
||||||
Term tout, tatts;
|
Term tout, tatts;
|
||||||
|
|
||||||
attv = (attvar_record *)VarOfTerm(inp);
|
attv = RepAttVar(VarOfTerm(inp));
|
||||||
if (IsVarTerm(tatts = SearchAttsForModuleName(attv->Atts,modname)))
|
if (IsVarTerm(tatts = SearchAttsForModuleName(attv->Atts,modname)))
|
||||||
return TRUE;
|
return TRUE;
|
||||||
tout = ArgOfTerm(IntegerOfTerm(Deref(ARG3)),tatts);
|
tout = ArgOfTerm(IntegerOfTerm(Deref(ARG3)),tatts);
|
||||||
@ -731,7 +690,7 @@ p_get_atts(void) {
|
|||||||
UInt ar, i;
|
UInt ar, i;
|
||||||
CELL *old, *new;
|
CELL *old, *new;
|
||||||
|
|
||||||
attv = (attvar_record *)VarOfTerm(inp);
|
attv = RepAttVar(VarOfTerm(inp));
|
||||||
if (IsVarTerm(tatts = SearchAttsForModule(attv->Atts,mfun)))
|
if (IsVarTerm(tatts = SearchAttsForModule(attv->Atts,mfun)))
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
@ -769,7 +728,7 @@ p_has_atts(void) {
|
|||||||
Term access = Deref(ARG2);
|
Term access = Deref(ARG2);
|
||||||
Functor mfun = FunctorOfTerm(access);
|
Functor mfun = FunctorOfTerm(access);
|
||||||
|
|
||||||
attv = (attvar_record *)VarOfTerm(inp);
|
attv = RepAttVar(VarOfTerm(inp));
|
||||||
return !IsVarTerm(tatts = SearchAttsForModule(attv->Atts,mfun));
|
return !IsVarTerm(tatts = SearchAttsForModule(attv->Atts,mfun));
|
||||||
} else {
|
} else {
|
||||||
/* Yap_Error(INSTANTIATION_ERROR,inp,"get_att/2"); */
|
/* Yap_Error(INSTANTIATION_ERROR,inp,"get_att/2"); */
|
||||||
@ -788,7 +747,7 @@ p_bind_attvar(void) {
|
|||||||
/* if this is unbound, ok */
|
/* if this is unbound, ok */
|
||||||
if (IsVarTerm(inp)) {
|
if (IsVarTerm(inp)) {
|
||||||
if (IsAttachedTerm(inp)) {
|
if (IsAttachedTerm(inp)) {
|
||||||
attvar_record *attv = (attvar_record *)VarOfTerm(inp);
|
attvar_record *attv = RepAttVar(VarOfTerm(inp));
|
||||||
return(BindAttVar(attv));
|
return(BindAttVar(attv));
|
||||||
}
|
}
|
||||||
return(TRUE);
|
return(TRUE);
|
||||||
@ -805,7 +764,7 @@ p_unbind_attvar(void) {
|
|||||||
/* if this is unbound, ok */
|
/* if this is unbound, ok */
|
||||||
if (IsVarTerm(inp)) {
|
if (IsVarTerm(inp)) {
|
||||||
if (IsAttachedTerm(inp)) {
|
if (IsAttachedTerm(inp)) {
|
||||||
attvar_record *attv = (attvar_record *)VarOfTerm(inp);
|
attvar_record *attv = RepAttVar(VarOfTerm(inp));
|
||||||
return(UnBindAttVar(attv));
|
return(UnBindAttVar(attv));
|
||||||
}
|
}
|
||||||
return(TRUE);
|
return(TRUE);
|
||||||
@ -822,7 +781,7 @@ p_get_all_atts(void) {
|
|||||||
/* if this is unbound, ok */
|
/* if this is unbound, ok */
|
||||||
if (IsVarTerm(inp)) {
|
if (IsVarTerm(inp)) {
|
||||||
if (IsAttachedTerm(inp)) {
|
if (IsAttachedTerm(inp)) {
|
||||||
attvar_record *attv = (attvar_record *)VarOfTerm(inp);
|
attvar_record *attv = RepAttVar(VarOfTerm(inp));
|
||||||
return Yap_unify(ARG2,GetAllAtts(attv));
|
return Yap_unify(ARG2,GetAllAtts(attv));
|
||||||
}
|
}
|
||||||
return TRUE;
|
return TRUE;
|
||||||
@ -852,7 +811,7 @@ p_modules_with_atts(void) {
|
|||||||
/* if this is unbound, ok */
|
/* if this is unbound, ok */
|
||||||
if (IsVarTerm(inp)) {
|
if (IsVarTerm(inp)) {
|
||||||
if (IsAttachedTerm(inp)) {
|
if (IsAttachedTerm(inp)) {
|
||||||
attvar_record *attv = (attvar_record *)VarOfTerm(inp);
|
attvar_record *attv = RepAttVar(VarOfTerm(inp));
|
||||||
CELL *h0 = H;
|
CELL *h0 = H;
|
||||||
Term tatt;
|
Term tatt;
|
||||||
|
|
||||||
@ -889,7 +848,7 @@ p_swi_all_atts(void) {
|
|||||||
/* if this is unbound, ok */
|
/* if this is unbound, ok */
|
||||||
if (IsVarTerm(inp)) {
|
if (IsVarTerm(inp)) {
|
||||||
if (IsAttachedTerm(inp)) {
|
if (IsAttachedTerm(inp)) {
|
||||||
attvar_record *attv = (attvar_record *)VarOfTerm(inp);
|
attvar_record *attv = RepAttVar(VarOfTerm(inp));
|
||||||
CELL *h0 = H;
|
CELL *h0 = H;
|
||||||
Term tatt;
|
Term tatt;
|
||||||
|
|
||||||
@ -923,20 +882,7 @@ p_swi_all_atts(void) {
|
|||||||
static Int
|
static Int
|
||||||
p_all_attvars(void)
|
p_all_attvars(void)
|
||||||
{
|
{
|
||||||
do {
|
return Yap_unify(ARG1,TermNil);
|
||||||
Term out;
|
|
||||||
attvar_record *base;
|
|
||||||
|
|
||||||
base = (attvar_record *)Yap_ReadTimedVar(AttsMutableList);
|
|
||||||
if (!(out = AllAttVars(base))) {
|
|
||||||
if (!Yap_gcl(Yap_Error_Size, 1, ENV, gc_P(P,CP))) {
|
|
||||||
Yap_Error(OUT_OF_STACK_ERROR, TermNil, Yap_ErrorMessage);
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return Yap_unify(ARG1,out);
|
|
||||||
}
|
|
||||||
} while (TRUE);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static Int
|
static Int
|
||||||
@ -944,7 +890,7 @@ p_is_attvar(void)
|
|||||||
{
|
{
|
||||||
Term t = Deref(ARG1);
|
Term t = Deref(ARG1);
|
||||||
return(IsVarTerm(t) &&
|
return(IsVarTerm(t) &&
|
||||||
IsAttachedTerm(t));
|
IsAttVar(VarOfTerm(t)));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* check if we are not redoing effort */
|
/* check if we are not redoing effort */
|
||||||
@ -952,9 +898,10 @@ static Int
|
|||||||
p_attvar_bound(void)
|
p_attvar_bound(void)
|
||||||
{
|
{
|
||||||
Term t = Deref(ARG1);
|
Term t = Deref(ARG1);
|
||||||
return(IsVarTerm(t) &&
|
return
|
||||||
IsAttachedTerm(t) &&
|
IsVarTerm(t) &&
|
||||||
!IsUnboundVar(&((attvar_record *)VarOfTerm(t))->Done));
|
IsAttachedTerm(t) &&
|
||||||
|
!IsUnboundVar(&(RepAttVar(VarOfTerm(t))->Done));
|
||||||
}
|
}
|
||||||
|
|
||||||
static Int
|
static Int
|
||||||
|
Reference in New Issue
Block a user