don't leave dangling pointers to switch tables, as they can be removed
easily. git-svn-id: https://yap.svn.sf.net/svnroot/yap/trunk@913 b08c6af1-5177-4d33-ba66-4b1c6b8b522a
This commit is contained in:
parent
009452e075
commit
a23c409540
@ -2099,7 +2099,7 @@ do_pass(void)
|
||||
/* index code */
|
||||
if (log_update) {
|
||||
if (pass_no) {
|
||||
cl_u->lui.ClFlags = LogUpdMask|IndexedPredFlag|IndexMask;
|
||||
cl_u->lui.ClFlags = LogUpdMask|IndexedPredFlag|IndexMask|SwitchRootMask;
|
||||
cl_u->lui.ChildIndex = NULL;
|
||||
cl_u->lui.SiblingIndex = NULL;
|
||||
cl_u->lui.u.pred = CurrentPred;
|
||||
|
@ -423,6 +423,13 @@ kill_first_log_iblock(LogUpdIndex *c, LogUpdIndex *cl, PredEntry *ap)
|
||||
Yap_FreeCodeSpace((CODEADDR)c);
|
||||
} else {
|
||||
c->ClFlags |= ErasedMask;
|
||||
/* try to move up, so that we don't hold an index */
|
||||
if (cl != NULL &&
|
||||
cl->ClFlags & SwitchTableMask) {
|
||||
c->u.ParentIndex = cl->u.ParentIndex;
|
||||
cl->u.ParentIndex->ClRefCount++;
|
||||
cl->ClRefCount--;
|
||||
}
|
||||
c->ChildIndex = NULL;
|
||||
}
|
||||
}
|
||||
|
@ -4140,6 +4140,7 @@ ExpandIndex(PredEntry *ap) {
|
||||
/* insert myself in the indexing code chain */
|
||||
nic->SiblingIndex = ic->ChildIndex;
|
||||
nic->u.ParentIndex = ic;
|
||||
nic->ClFlags &= ~SwitchRootMask;
|
||||
ic->ChildIndex = nic;
|
||||
ic->ClRefCount++;
|
||||
} else {
|
||||
|
@ -102,7 +102,7 @@ check_trail_consistency(void) {
|
||||
*/
|
||||
|
||||
|
||||
static int vsc_xstop = FALSE;
|
||||
static int vsc_xstop = FALSE;
|
||||
|
||||
void
|
||||
low_level_trace(yap_low_level_port port, PredEntry *pred, CELL *args)
|
||||
|
Reference in New Issue
Block a user