new version of attributed variable code, using arena to store variables and

removing variable chain.
This commit is contained in:
Vitor Santos Costa 2010-03-08 09:18:52 +00:00
parent 76c6e06b45
commit e992b0dcf0

View File

@ -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