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
|
||||
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;
|
||||
struct cp_frame *to_visit = *to_visit_ptr;
|
||||
CELL *vt;
|
||||
|
||||
/* add a new attributed variable */
|
||||
newv = DelayTop();
|
||||
if ((ADDR)newv - Yap_GlobalBase < 1024*sizeof(CELL))
|
||||
if (!(newv = BuildNewAttVar()))
|
||||
return FALSE;
|
||||
newv--;
|
||||
RESET_VARIABLE(&(newv->Value));
|
||||
RESET_VARIABLE(&(newv->Done));
|
||||
vt = &(attv->Atts);
|
||||
to_visit->start_cp = vt-1;
|
||||
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_ptr = to_visit+1;
|
||||
*res = (CELL)&(newv->Done);
|
||||
SetDelayTop(newv);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
static Term
|
||||
AttVarToTerm(CELL *orig)
|
||||
{
|
||||
attvar_record *attv = (attvar_record *)orig;
|
||||
attvar_record *attv = RepAttVar(orig);
|
||||
|
||||
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
|
||||
TermToAttVar(Term attvar, Term to)
|
||||
{
|
||||
@ -130,7 +126,7 @@ TermToAttVar(Term attvar, Term to)
|
||||
if (!attv)
|
||||
return FALSE;
|
||||
attv->Atts = attvar;
|
||||
*VarOfTerm(to) = (CELL)attv;
|
||||
*VarOfTerm(to) = AbsAttVar(attv);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
@ -139,7 +135,7 @@ WakeAttVar(CELL* pt1, CELL reg2)
|
||||
{
|
||||
|
||||
/* 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 *bind_ptr;
|
||||
|
||||
@ -147,7 +143,7 @@ WakeAttVar(CELL* pt1, CELL reg2)
|
||||
if (pt1 == VarOfTerm(reg2))
|
||||
return;
|
||||
if (IsAttachedTerm(reg2)) {
|
||||
attvar_record *susp2 = (attvar_record *)VarOfTerm(reg2);
|
||||
attvar_record *susp2 = RepAttVar(VarOfTerm(reg2));
|
||||
|
||||
/* binding two suspended variables, be careful */
|
||||
if (susp2 >= attv) {
|
||||
@ -196,11 +192,7 @@ Yap_WakeUp(CELL *pt0) {
|
||||
static void
|
||||
mark_attvar(CELL *orig)
|
||||
{
|
||||
register attvar_record *attv = (attvar_record *)orig;
|
||||
|
||||
Yap_mark_external_reference(&(attv->Value));
|
||||
Yap_mark_external_reference(&(attv->Done));
|
||||
Yap_mark_external_reference(&(attv->Atts));
|
||||
return;
|
||||
}
|
||||
|
||||
static Term
|
||||
@ -388,11 +380,11 @@ BindAttVar(attvar_record *attv) {
|
||||
Term t = Deref(attv->Value);
|
||||
if (IsVarTerm(t)) {
|
||||
if (IsAttachedTerm(t)) {
|
||||
attvar_record *attv2 = (attvar_record *)VarOfTerm(t);
|
||||
attvar_record *attv2 = RepAttVar(VarOfTerm(t));
|
||||
if (attv2 < attv) {
|
||||
Bind_Global(&(attv->Done), t);
|
||||
} else {
|
||||
Bind_Global(&(attv2->Done), (CELL)attv);
|
||||
Bind_Global(&(attv2->Done), AbsAttVar(attv));
|
||||
}
|
||||
} else {
|
||||
Yap_Error(SYSTEM_ERROR,(CELL)&(attv->Done),"attvar was bound when unset");
|
||||
@ -421,43 +413,6 @@ GetAllAtts(attvar_record *attv) {
|
||||
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
|
||||
p_put_att(void) {
|
||||
/* receive a variable in ARG1 */
|
||||
@ -472,11 +427,12 @@ p_put_att(void) {
|
||||
int new = FALSE;
|
||||
|
||||
if (IsAttachedTerm(inp)) {
|
||||
attv = (attvar_record *)VarOfTerm(inp);
|
||||
attv = RepAttVar(VarOfTerm(inp));
|
||||
} else {
|
||||
while (!(attv = BuildNewAttVar())) {
|
||||
if (!Yap_growglobal(NULL)) {
|
||||
Yap_Error(OUT_OF_ATTVARS_ERROR, ARG1, Yap_ErrorMessage);
|
||||
Yap_Error_Size = sizeof(attvar_record);
|
||||
if (!Yap_gcl(Yap_Error_Size, 5, ENV, gc_P(P,CP))) {
|
||||
Yap_Error(OUT_OF_STACK_ERROR, TermNil, Yap_ErrorMessage);
|
||||
return FALSE;
|
||||
}
|
||||
inp = Deref(ARG1);
|
||||
@ -491,7 +447,7 @@ p_put_att(void) {
|
||||
return FALSE;
|
||||
}
|
||||
}
|
||||
Yap_unify(ARG1, (Term)attv);
|
||||
Yap_unify(ARG1, AbsAttVar(attv));
|
||||
AddNewModule(attv,tatts,new,TRUE);
|
||||
}
|
||||
PutAtt(IntegerOfTerm(Deref(ARG4)), tatts, Deref(ARG5));
|
||||
@ -512,11 +468,12 @@ p_put_att_term(void) {
|
||||
int new = FALSE;
|
||||
|
||||
if (IsAttachedTerm(inp)) {
|
||||
attv = (attvar_record *)VarOfTerm(inp);
|
||||
attv = RepAttVar(VarOfTerm(inp));
|
||||
} else {
|
||||
while (!(attv = BuildNewAttVar())) {
|
||||
if (!Yap_growglobal(NULL)) {
|
||||
Yap_Error(OUT_OF_ATTVARS_ERROR, ARG1, Yap_ErrorMessage);
|
||||
Yap_Error_Size = sizeof(attvar_record);
|
||||
if (!Yap_gcl(Yap_Error_Size, 5, ENV, gc_P(P,CP))) {
|
||||
Yap_Error(OUT_OF_STACK_ERROR, TermNil, Yap_ErrorMessage);
|
||||
return FALSE;
|
||||
}
|
||||
inp = Deref(ARG1);
|
||||
@ -524,7 +481,7 @@ p_put_att_term(void) {
|
||||
new = TRUE;
|
||||
}
|
||||
if (new) {
|
||||
Bind(VarOfTerm(inp), (CELL)attv);
|
||||
Bind(VarOfTerm(inp), AbsAttVar(attv));
|
||||
attv->Atts = Deref(ARG2);
|
||||
} else {
|
||||
MaBind(&(attv->Atts), Deref(ARG2));
|
||||
@ -550,17 +507,18 @@ p_rm_att(void) {
|
||||
int new = FALSE;
|
||||
|
||||
if (IsAttachedTerm(inp)) {
|
||||
attv = (attvar_record *)VarOfTerm(inp);
|
||||
attv = RepAttVar(VarOfTerm(inp));
|
||||
} else {
|
||||
while (!(attv = BuildNewAttVar())) {
|
||||
if (!Yap_growglobal(NULL)) {
|
||||
Yap_Error(OUT_OF_ATTVARS_ERROR, ARG1, Yap_ErrorMessage);
|
||||
Yap_Error_Size = sizeof(attvar_record);
|
||||
if (!Yap_gcl(Yap_Error_Size, 5, ENV, gc_P(P,CP))) {
|
||||
Yap_Error(OUT_OF_STACK_ERROR, TermNil, Yap_ErrorMessage);
|
||||
return FALSE;
|
||||
}
|
||||
inp = Deref(ARG1);
|
||||
}
|
||||
new = TRUE;
|
||||
Yap_unify(ARG1, (Term)attv);
|
||||
Yap_unify(ARG1, AbsAttVar(attv));
|
||||
}
|
||||
mfun= Yap_MkFunctor(modname,ar);
|
||||
if (IsVarTerm(tatts = SearchAttsForModule(attv->Atts,mfun))) {
|
||||
@ -595,17 +553,18 @@ p_put_atts(void) {
|
||||
int new = FALSE;
|
||||
|
||||
if (IsAttachedTerm(inp)) {
|
||||
attv = (attvar_record *)VarOfTerm(inp);
|
||||
attv = RepAttVar(VarOfTerm(inp));
|
||||
} else {
|
||||
while (!(attv = BuildNewAttVar())) {
|
||||
if (!Yap_growglobal(NULL)) {
|
||||
Yap_Error(OUT_OF_ATTVARS_ERROR, ARG1, Yap_ErrorMessage);
|
||||
Yap_Error_Size = sizeof(attvar_record);
|
||||
if (!Yap_gcl(Yap_Error_Size, 5, ENV, gc_P(P,CP))) {
|
||||
Yap_Error(OUT_OF_STACK_ERROR, TermNil, Yap_ErrorMessage);
|
||||
return FALSE;
|
||||
}
|
||||
tatts = Deref(ARG2);
|
||||
}
|
||||
new = TRUE;
|
||||
Yap_unify(ARG1, (Term)attv);
|
||||
Yap_unify(ARG1, AbsAttVar(attv));
|
||||
}
|
||||
if (IsVarTerm(otatts = SearchAttsForModule(attv->Atts,mfun))) {
|
||||
AddNewModule(attv,tatts,new,FALSE);
|
||||
@ -632,7 +591,7 @@ p_del_atts(void) {
|
||||
Functor mfun = FunctorOfTerm(tatts);
|
||||
|
||||
if (IsAttachedTerm(inp)) {
|
||||
attv = (attvar_record *)VarOfTerm(inp);
|
||||
attv = RepAttVar(VarOfTerm(inp));
|
||||
} else {
|
||||
return TRUE;
|
||||
}
|
||||
@ -656,7 +615,7 @@ p_del_all_atts(void) {
|
||||
if (IsVarTerm(inp) && IsAttachedTerm(inp)) {
|
||||
attvar_record *attv;
|
||||
|
||||
attv = (attvar_record *)VarOfTerm(inp);
|
||||
attv = RepAttVar(VarOfTerm(inp));
|
||||
DelAllAtts(attv);
|
||||
}
|
||||
return TRUE;
|
||||
@ -674,7 +633,7 @@ p_get_att(void) {
|
||||
attvar_record *attv;
|
||||
Term tout, tatts;
|
||||
|
||||
attv = (attvar_record *)VarOfTerm(inp);
|
||||
attv = RepAttVar(VarOfTerm(inp));
|
||||
if (IsVarTerm(tatts = SearchAttsForModuleName(attv->Atts,modname)))
|
||||
return FALSE;
|
||||
tout = ArgOfTerm(IntegerOfTerm(Deref(ARG3)),tatts);
|
||||
@ -702,7 +661,7 @@ p_free_att(void) {
|
||||
attvar_record *attv;
|
||||
Term tout, tatts;
|
||||
|
||||
attv = (attvar_record *)VarOfTerm(inp);
|
||||
attv = RepAttVar(VarOfTerm(inp));
|
||||
if (IsVarTerm(tatts = SearchAttsForModuleName(attv->Atts,modname)))
|
||||
return TRUE;
|
||||
tout = ArgOfTerm(IntegerOfTerm(Deref(ARG3)),tatts);
|
||||
@ -731,7 +690,7 @@ p_get_atts(void) {
|
||||
UInt ar, i;
|
||||
CELL *old, *new;
|
||||
|
||||
attv = (attvar_record *)VarOfTerm(inp);
|
||||
attv = RepAttVar(VarOfTerm(inp));
|
||||
if (IsVarTerm(tatts = SearchAttsForModule(attv->Atts,mfun)))
|
||||
return FALSE;
|
||||
|
||||
@ -769,7 +728,7 @@ p_has_atts(void) {
|
||||
Term access = Deref(ARG2);
|
||||
Functor mfun = FunctorOfTerm(access);
|
||||
|
||||
attv = (attvar_record *)VarOfTerm(inp);
|
||||
attv = RepAttVar(VarOfTerm(inp));
|
||||
return !IsVarTerm(tatts = SearchAttsForModule(attv->Atts,mfun));
|
||||
} else {
|
||||
/* Yap_Error(INSTANTIATION_ERROR,inp,"get_att/2"); */
|
||||
@ -788,7 +747,7 @@ p_bind_attvar(void) {
|
||||
/* if this is unbound, ok */
|
||||
if (IsVarTerm(inp)) {
|
||||
if (IsAttachedTerm(inp)) {
|
||||
attvar_record *attv = (attvar_record *)VarOfTerm(inp);
|
||||
attvar_record *attv = RepAttVar(VarOfTerm(inp));
|
||||
return(BindAttVar(attv));
|
||||
}
|
||||
return(TRUE);
|
||||
@ -805,7 +764,7 @@ p_unbind_attvar(void) {
|
||||
/* if this is unbound, ok */
|
||||
if (IsVarTerm(inp)) {
|
||||
if (IsAttachedTerm(inp)) {
|
||||
attvar_record *attv = (attvar_record *)VarOfTerm(inp);
|
||||
attvar_record *attv = RepAttVar(VarOfTerm(inp));
|
||||
return(UnBindAttVar(attv));
|
||||
}
|
||||
return(TRUE);
|
||||
@ -822,7 +781,7 @@ p_get_all_atts(void) {
|
||||
/* if this is unbound, ok */
|
||||
if (IsVarTerm(inp)) {
|
||||
if (IsAttachedTerm(inp)) {
|
||||
attvar_record *attv = (attvar_record *)VarOfTerm(inp);
|
||||
attvar_record *attv = RepAttVar(VarOfTerm(inp));
|
||||
return Yap_unify(ARG2,GetAllAtts(attv));
|
||||
}
|
||||
return TRUE;
|
||||
@ -852,7 +811,7 @@ p_modules_with_atts(void) {
|
||||
/* if this is unbound, ok */
|
||||
if (IsVarTerm(inp)) {
|
||||
if (IsAttachedTerm(inp)) {
|
||||
attvar_record *attv = (attvar_record *)VarOfTerm(inp);
|
||||
attvar_record *attv = RepAttVar(VarOfTerm(inp));
|
||||
CELL *h0 = H;
|
||||
Term tatt;
|
||||
|
||||
@ -889,7 +848,7 @@ p_swi_all_atts(void) {
|
||||
/* if this is unbound, ok */
|
||||
if (IsVarTerm(inp)) {
|
||||
if (IsAttachedTerm(inp)) {
|
||||
attvar_record *attv = (attvar_record *)VarOfTerm(inp);
|
||||
attvar_record *attv = RepAttVar(VarOfTerm(inp));
|
||||
CELL *h0 = H;
|
||||
Term tatt;
|
||||
|
||||
@ -923,20 +882,7 @@ p_swi_all_atts(void) {
|
||||
static Int
|
||||
p_all_attvars(void)
|
||||
{
|
||||
do {
|
||||
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);
|
||||
return Yap_unify(ARG1,TermNil);
|
||||
}
|
||||
|
||||
static Int
|
||||
@ -944,7 +890,7 @@ p_is_attvar(void)
|
||||
{
|
||||
Term t = Deref(ARG1);
|
||||
return(IsVarTerm(t) &&
|
||||
IsAttachedTerm(t));
|
||||
IsAttVar(VarOfTerm(t)));
|
||||
}
|
||||
|
||||
/* check if we are not redoing effort */
|
||||
@ -952,9 +898,10 @@ static Int
|
||||
p_attvar_bound(void)
|
||||
{
|
||||
Term t = Deref(ARG1);
|
||||
return(IsVarTerm(t) &&
|
||||
IsAttachedTerm(t) &&
|
||||
!IsUnboundVar(&((attvar_record *)VarOfTerm(t))->Done));
|
||||
return
|
||||
IsVarTerm(t) &&
|
||||
IsAttachedTerm(t) &&
|
||||
!IsUnboundVar(&(RepAttVar(VarOfTerm(t))->Done));
|
||||
}
|
||||
|
||||
static Int
|
||||
|
Reference in New Issue
Block a user