From 5ae92827f4efbc43881d6b5f89314675e9e3644f Mon Sep 17 00:00:00 2001 From: vsc Date: Sun, 10 Apr 2005 04:31:12 +0000 Subject: [PATCH] fix case where people used nth_instance on predicate entries git-svn-id: https://yap.svn.sf.net/svnroot/yap/trunk@1271 b08c6af1-5177-4d33-ba66-4b1c6b8b522a --- C/dbase.c | 44 ++++++++++++++++---------------------------- 1 file changed, 16 insertions(+), 28 deletions(-) diff --git a/C/dbase.c b/C/dbase.c index 07a9e1576..6ea6fe08d 100644 --- a/C/dbase.c +++ b/C/dbase.c @@ -2391,7 +2391,8 @@ GetDBLUKey(PredEntry *ap) Int id = ap->src.IndxId; READ_UNLOCK(ap->PRWLock); return MkIntegerTerm(id); - } else if (ap->PredFlags & AtomDBPredFlag) { + } else if (ap->PredFlags & AtomDBPredFlag || + (ap->ModuleOfPred != IDB_MODULE && ap->ArityOfPE == 0)) { Atom at = (Atom)ap->FunctorOfPred; READ_UNLOCK(ap->PRWLock); return MkAtomTerm(at); @@ -3482,35 +3483,22 @@ p_recorded(void) } if (ref->Flags & LogUpdMask) { LogUpdClause *cl = (LogUpdClause *)ref; - PredEntry *ap; - if (Yap_op_from_opcode(cl->ClCode->opc) == _unify_idb_term) { - if (!Yap_unify(ARG2, cl->ClSource->Entry)) { - return FALSE; - } + PredEntry *ap = cl->ClPred; + op_numbers opc = Yap_op_from_opcode(P->opc); + + if (!Yap_unify(GetDBLUKey(ap), ARG1)) + return FALSE; + + if (opc == _procceed) { + P = cl->ClCode; } else { - Term TermDB; - while ((TermDB = GetDBTerm(cl->ClSource)) == (CELL)0) { - /* oops, we are in trouble, not enough stack space */ - if (Yap_Error_TYPE == OUT_OF_ATTVARS_ERROR) { - Yap_Error_TYPE = YAP_NO_ERROR; - if (!Yap_growglobal(NULL)) { - Yap_Error(OUT_OF_ATTVARS_ERROR, TermNil, Yap_ErrorMessage); - return FALSE; - } - } else { - Yap_Error_TYPE = YAP_NO_ERROR; - if (!Yap_gcl(Yap_Error_Size, 3, ENV, P)) { - Yap_Error(OUT_OF_STACK_ERROR, TermNil, Yap_ErrorMessage); - return(FALSE); - } - } - } - if (!Yap_unify(ARG2,TermDB)) { - return FALSE; - } - ap = cl->ClPred; - return Yap_unify(GetDBLUKey(ap), ARG1); + CP = P; + P = cl->ClCode; + ENV = YENV; + YENV = ASP; + YENV[E_CB] = (CELL) B; } + return TRUE; } else { Term TermDB; while ((TermDB = GetDBTermFromDBEntry(ref)) == (CELL)0) {