From 40c2f19c7a50ea4eafaec086a4ca7d12cd04fc8d Mon Sep 17 00:00:00 2001 From: vsc Date: Wed, 19 Oct 2005 23:17:22 +0000 Subject: [PATCH] fix nb_terms git-svn-id: https://yap.svn.sf.net/svnroot/yap/trunk@1408 b08c6af1-5177-4d33-ba66-4b1c6b8b522a --- C/arrays.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/C/arrays.c b/C/arrays.c index e0b95e225..43d627d4a 100644 --- a/C/arrays.c +++ b/C/arrays.c @@ -182,17 +182,17 @@ GetNBTerm(live_term *ar, Int indx) } if (IsVarTerm(termt)) { Term livet = MkVarTerm(); - Bind(&(ar[indx].tlive), livet); + MaBind(&(ar[indx].tlive), livet); return livet; } else if (IsAtomicTerm(termt)) { - Bind(&(ar[indx].tlive), termt); + MaBind(&(ar[indx].tlive), termt); return termt; } else { DBTerm *ref = (DBTerm *)RepAppl(termt); if ((livet = GetTermFromArray(ref)) == TermNil) { return TermNil; } - Bind(&(ar[indx].tlive), livet); + MaBind(&(ar[indx].tlive), livet); return livet; } } @@ -1689,10 +1689,12 @@ p_assign_static(void) case array_of_nb_terms: - RESET_VARIABLE(&(ptr->ValueOfVE.lterms[indx].tlive)); { Term told = ptr->ValueOfVE.lterms[indx].tstore; Term tnew = Deref(ARG3); + + CELL *livep = &(ptr->ValueOfVE.lterms[indx].tlive); + MaBind(livep,(CELL)livep); /* recover space */ if (IsApplTerm(told)) { Yap_ReleaseTermFromDB((DBTerm *)RepAppl(told));