allow easy shunting, but make sure we do not shunt chains below the current CP.
This commit is contained in:
parent
b5a5e10544
commit
4b91f13ee1
@ -24,7 +24,7 @@ static char SccsId[] = "%W% %G%";
|
|||||||
#include "attvar.h"
|
#include "attvar.h"
|
||||||
|
|
||||||
#if !defined(TABLING)
|
#if !defined(TABLING)
|
||||||
/* #define EASY_SHUNTING 1 */
|
#define EASY_SHUNTING 1
|
||||||
#endif /* !TABLING */
|
#endif /* !TABLING */
|
||||||
#define HYBRID_SCHEME 1
|
#define HYBRID_SCHEME 1
|
||||||
|
|
||||||
@ -1221,13 +1221,15 @@ mark_variable(CELL_PTR current)
|
|||||||
current = next;
|
current = next;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (IsVarTerm(cnext) &&
|
/* try to shorten chains if they go through the current CP */
|
||||||
|
} else if (next > HB &&
|
||||||
|
IsVarTerm(cnext) &&
|
||||||
UNMARK_CELL(cnext) != (CELL)next &&
|
UNMARK_CELL(cnext) != (CELL)next &&
|
||||||
current < LCL0) {
|
current < LCL0) {
|
||||||
/* This step is possible because we clean up the trail */
|
/* This step is possible because we clean up the trail */
|
||||||
*current = UNMARK_CELL(cnext);
|
*current = UNMARK_CELL(cnext);
|
||||||
UNMARK(current);
|
UNMARK(current);
|
||||||
if (current >= H0 && current < H) {
|
if (current >= H0 && current < H ) {
|
||||||
total_marked--;
|
total_marked--;
|
||||||
if (current < HGEN) {
|
if (current < HGEN) {
|
||||||
total_oldies--;
|
total_oldies--;
|
||||||
|
Reference in New Issue
Block a user