deb
This commit is contained in:
parent
4092003cd6
commit
933db5bc7e
329
C/terms.c
329
C/terms.c
@ -68,15 +68,6 @@ static int expand_vts(int args USES_REGS) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static inline void clean_tr(tr_fr_ptr TR0 USES_REGS) {
|
static inline void clean_tr(tr_fr_ptr TR0 USES_REGS) {
|
||||||
if (TR != TR0) {
|
|
||||||
do {
|
|
||||||
Term p = TrailTerm(--TR);
|
|
||||||
RESET_VARIABLE(p);
|
|
||||||
} while (TR != TR0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#if 0
|
|
||||||
static inline void clean_dirty_tr(tr_fr_ptr TR0 USES_REGS) {
|
|
||||||
tr_fr_ptr pt0 = TR;
|
tr_fr_ptr pt0 = TR;
|
||||||
while (pt0 != TR0) {
|
while (pt0 != TR0) {
|
||||||
Term p = TrailTerm(--pt0);
|
Term p = TrailTerm(--pt0);
|
||||||
@ -95,42 +86,7 @@ static inline void clean_dirty_tr(tr_fr_ptr TR0 USES_REGS) {
|
|||||||
TR = TR0;
|
TR = TR0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// @brief recover original term while fixing direct refs.
|
|
||||||
///
|
|
||||||
/// @param USES_REGS
|
|
||||||
///
|
|
||||||
|
|
||||||
static inline void clean_complex_tr(tr_fr_ptr TR0 USES_REGS) {
|
|
||||||
tr_fr_ptr pt0 = TR;
|
|
||||||
while (pt0 != TR0) {
|
|
||||||
Term p = TrailTerm(--pt0);
|
|
||||||
if (IsApplTerm(p)) {
|
|
||||||
/// pt: points to the address of the new term we may want to fix.
|
|
||||||
CELL *pt = RepAppl(p);
|
|
||||||
if (pt >= HB && pt < HR) { /// is it new?
|
|
||||||
Term v = pt[0];
|
|
||||||
if (IsApplTerm(v)) {
|
|
||||||
/// yes, more than a single ref
|
|
||||||
*pt = (CELL)RepAppl(v);
|
|
||||||
}
|
|
||||||
#ifndef FROZEN_STACKS
|
|
||||||
pt0--;
|
|
||||||
#endif /* FROZEN_STACKS */
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
#ifdef FROZEN_STACKS
|
|
||||||
pt[0] = TrailVal(pt0);
|
|
||||||
#else
|
|
||||||
pt[0] = TrailTerm(pt0 - 1);
|
|
||||||
pt0--;
|
|
||||||
#endif /* FROZEN_STACKS */
|
|
||||||
} else {
|
|
||||||
RESET_VARIABLE(p);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
TR = TR0;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
Term old_var;
|
Term old_var;
|
||||||
Term new_var;
|
Term new_var;
|
||||||
@ -143,22 +99,22 @@ typedef struct non_single_struct_t {
|
|||||||
} non_singletons_t;
|
} non_singletons_t;
|
||||||
|
|
||||||
#define WALK_COMPLEX_TERM__(LIST0, STRUCT0, PRIMI0) \
|
#define WALK_COMPLEX_TERM__(LIST0, STRUCT0, PRIMI0) \
|
||||||
int lvl = push_text_stack(); \
|
|
||||||
\
|
\
|
||||||
struct non_single_struct_t *to_visit = Malloc( \
|
struct non_single_struct_t *to_visit = Malloc( \
|
||||||
1024 * sizeof(struct non_single_struct_t)), \
|
1024 * sizeof(struct non_single_struct_t)), \
|
||||||
*to_visit0 = to_visit, \
|
*to_visit0 = to_visit, \
|
||||||
*to_visit_max = to_visit + 1024; \
|
*to_visit_max = to_visit + 1024; \
|
||||||
\
|
\
|
||||||
restart: \
|
do{ \
|
||||||
while (pt0 < pt0_end) { \
|
CELL d0; \
|
||||||
register CELL d0; \
|
CELL *ptd0; \
|
||||||
register CELL *ptd0; \
|
restart:\
|
||||||
|
while (pt0 < pt0_end) { \
|
||||||
++pt0; \
|
++pt0; \
|
||||||
ptd0 = pt0; \
|
ptd0 = pt0; \
|
||||||
d0 = *ptd0; \
|
d0 = *ptd0; \
|
||||||
list_loop: \
|
list_loop: \
|
||||||
fprintf(stderr,"%ld at %s\n", to_visit-to_visit0, __FUNCTION__);\
|
fprintf(stderr, "%ld at %s\n", to_visit - to_visit0, __FUNCTION__); \
|
||||||
deref_head(d0, var_in_term_unk); \
|
deref_head(d0, var_in_term_unk); \
|
||||||
var_in_term_nvar : { \
|
var_in_term_nvar : { \
|
||||||
if (IsPairTerm(d0)) { \
|
if (IsPairTerm(d0)) { \
|
||||||
@ -166,15 +122,15 @@ typedef struct non_single_struct_t {
|
|||||||
goto aux_overflow; \
|
goto aux_overflow; \
|
||||||
} \
|
} \
|
||||||
ptd0 = RepPair(d0); \
|
ptd0 = RepPair(d0); \
|
||||||
|
d0 = ptd0[0]; \
|
||||||
LIST0; \
|
LIST0; \
|
||||||
if (*ptd0 == TermFreeTerm) \
|
if (d0 == TermFreeTerm) \
|
||||||
goto restart; \
|
goto restart; \
|
||||||
to_visit->pt0 = pt0; \
|
to_visit->pt0 = pt0; \
|
||||||
to_visit->pt0_end = pt0_end; \
|
to_visit->pt0_end = pt0_end; \
|
||||||
to_visit->ptd0 = ptd0; \
|
to_visit->ptd0 = ptd0; \
|
||||||
to_visit->d0 = *ptd0; \
|
to_visit->d0 = d0; \
|
||||||
to_visit++; \
|
to_visit++; \
|
||||||
d0 = ptd0[0]; \
|
|
||||||
*ptd0 = TermFreeTerm; \
|
*ptd0 = TermFreeTerm; \
|
||||||
pt0 = ptd0; \
|
pt0 = ptd0; \
|
||||||
pt0_end = pt0 + 1; \
|
pt0_end = pt0 + 1; \
|
||||||
@ -189,9 +145,9 @@ typedef struct non_single_struct_t {
|
|||||||
goto aux_overflow; \
|
goto aux_overflow; \
|
||||||
} \
|
} \
|
||||||
STRUCT0; \
|
STRUCT0; \
|
||||||
if (IsExtensionFunctor(f) || IsAtomTerm((CELL)f)) { \
|
if (IsExtensionFunctor(f) || f == FunctorDollarVar || IsAtomTerm((CELL)f)) { \
|
||||||
\
|
\
|
||||||
goto restart; \
|
continue; \
|
||||||
} \
|
} \
|
||||||
to_visit->pt0 = pt0; \
|
to_visit->pt0 = pt0; \
|
||||||
to_visit->pt0_end = pt0_end; \
|
to_visit->pt0_end = pt0_end; \
|
||||||
@ -203,17 +159,28 @@ typedef struct non_single_struct_t {
|
|||||||
Term d1 = ArityOfFunctor(f); \
|
Term d1 = ArityOfFunctor(f); \
|
||||||
pt0 = ptd0; \
|
pt0 = ptd0; \
|
||||||
pt0_end = ptd0 + d1; \
|
pt0_end = ptd0 + d1; \
|
||||||
goto restart; \
|
continue; \
|
||||||
} else { \
|
} else { \
|
||||||
PRIMI0; \
|
PRIMI0; \
|
||||||
goto restart; \
|
continue; \
|
||||||
} \
|
|
||||||
} \
|
} \
|
||||||
derefa_body(d0, ptd0, var_in_term_unk, var_in_term_nvar);
|
derefa_body(d0, ptd0, var_in_term_unk, var_in_term_nvar);
|
||||||
|
|
||||||
#define WALK_COMPLEX_TERM() WALK_COMPLEX_TERM__({}, {}, {})
|
#define WALK_COMPLEX_TERM() WALK_COMPLEX_TERM__({}, {}, {})
|
||||||
|
|
||||||
#define END_WALK() goto restart;}
|
#define END_WALK() \
|
||||||
|
}\
|
||||||
|
}\
|
||||||
|
/* Do we still have compound terms to visit */ \
|
||||||
|
if (to_visit > to_visit0) {\
|
||||||
|
to_visit--;\
|
||||||
|
\
|
||||||
|
pt0 = to_visit->pt0;\
|
||||||
|
pt0_end = to_visit->pt0_end;\
|
||||||
|
*to_visit->ptd0 = to_visit->d0;\
|
||||||
|
} \
|
||||||
|
} while (to_visit>to_visit0); \
|
||||||
|
pop_text_stack(lvl);
|
||||||
|
|
||||||
#define def_aux_overflow() \
|
#define def_aux_overflow() \
|
||||||
aux_overflow : { \
|
aux_overflow : { \
|
||||||
@ -253,11 +220,12 @@ typedef struct non_single_struct_t {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#define CYC_LIST \
|
#define CYC_LIST \
|
||||||
if (*ptd0 == TermFreeTerm) { \
|
if (d0 == TermFreeTerm) { \
|
||||||
while (to_visit > to_visit0) { \
|
fprintf(stderr,"+%ld at %s\n", to_visit-to_visit0, __FUNCTION__);\
|
||||||
|
while (to_visit > to_visit0) { \
|
||||||
to_visit--; \
|
to_visit--; \
|
||||||
CELL *ptd0 = to_visit->ptd0; \
|
to_visit->ptd0[0] = \
|
||||||
*ptd0 = to_visit->d0; \
|
to_visit->d0; \
|
||||||
} \
|
} \
|
||||||
pop_text_stack(lvl); fprintf(stderr,"<%ld at %s\n", to_visit-to_visit0, __FUNCTION__);\
|
pop_text_stack(lvl); fprintf(stderr,"<%ld at %s\n", to_visit-to_visit0, __FUNCTION__);\
|
||||||
return true; \
|
return true; \
|
||||||
@ -267,10 +235,10 @@ typedef struct non_single_struct_t {
|
|||||||
if (IsAtomTerm((CELL)f)) { \
|
if (IsAtomTerm((CELL)f)) { \
|
||||||
while (to_visit > to_visit0) { \
|
while (to_visit > to_visit0) { \
|
||||||
to_visit--; \
|
to_visit--; \
|
||||||
CELL *ptd0 = to_visit->ptd0; \
|
to_visit->ptd0[0] = \
|
||||||
*ptd0 = to_visit->d0; \
|
to_visit->d0; \
|
||||||
} \
|
} \
|
||||||
pop_text_stack(lvl); fprintf(stderr,"<%d at %s\n", to_visit-to_visit0, __FUNCTION__);\
|
fprintf(stderr,"<%ld at %s\n", to_visit-to_visit0, __FUNCTION__);\
|
||||||
return true; \
|
return true; \
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -280,21 +248,11 @@ typedef struct non_single_struct_t {
|
|||||||
static Term cyclic_complex_term(register CELL *pt0,
|
static Term cyclic_complex_term(register CELL *pt0,
|
||||||
register CELL *pt0_end USES_REGS) {
|
register CELL *pt0_end USES_REGS) {
|
||||||
|
|
||||||
|
int lvl = push_text_stack(); \
|
||||||
WALK_COMPLEX_TERM__(CYC_LIST, CYC_APPL, {});
|
WALK_COMPLEX_TERM__(CYC_LIST, CYC_APPL, {});
|
||||||
/* leave an empty slot to fill in later */
|
/* leave an empty slot to fill in later */
|
||||||
goto restart;
|
|
||||||
END_WALK();
|
END_WALK();
|
||||||
/* Do we still have compound terms to visit */
|
|
||||||
if (to_visit > to_visit0) {
|
|
||||||
to_visit--;
|
|
||||||
|
|
||||||
pt0 = to_visit->pt0;
|
|
||||||
pt0_end = to_visit->pt0_end;
|
|
||||||
CELL *ptd0 = to_visit->ptd0;
|
|
||||||
*ptd0 = to_visit->d0;
|
|
||||||
goto restart;
|
|
||||||
}
|
|
||||||
pop_text_stack(lvl);
|
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
@ -332,6 +290,7 @@ static Int cyclic_term(USES_REGS1) /* cyclic_term(+T) */
|
|||||||
static bool ground_complex_term(register CELL *pt0,
|
static bool ground_complex_term(register CELL *pt0,
|
||||||
register CELL *pt0_end USES_REGS) {
|
register CELL *pt0_end USES_REGS) {
|
||||||
|
|
||||||
|
int lvl = push_text_stack(); \
|
||||||
WALK_COMPLEX_TERM();
|
WALK_COMPLEX_TERM();
|
||||||
/* leave an empty slot to fill in later */
|
/* leave an empty slot to fill in later */
|
||||||
while (to_visit > to_visit0) {
|
while (to_visit > to_visit0) {
|
||||||
@ -345,15 +304,7 @@ static bool ground_complex_term(register CELL *pt0,
|
|||||||
|
|
||||||
END_WALK();
|
END_WALK();
|
||||||
/* Do we still have compound terms to visit */
|
/* Do we still have compound terms to visit */
|
||||||
if (to_visit > to_visit0) {
|
|
||||||
to_visit--;
|
|
||||||
|
|
||||||
pt0 = to_visit->pt0;
|
|
||||||
pt0_end = to_visit->pt0_end;
|
|
||||||
CELL *ptd0 = to_visit->ptd0;
|
|
||||||
*ptd0 = to_visit->d0;
|
|
||||||
goto restart;
|
|
||||||
}
|
|
||||||
pop_text_stack(lvl);
|
pop_text_stack(lvl);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
@ -388,9 +339,10 @@ static Int ground(USES_REGS1) /* ground(+T) */
|
|||||||
static Int var_in_complex_term(register CELL *pt0, register CELL *pt0_end,
|
static Int var_in_complex_term(register CELL *pt0, register CELL *pt0_end,
|
||||||
Term v USES_REGS) {
|
Term v USES_REGS) {
|
||||||
|
|
||||||
|
int lvl = push_text_stack(); \
|
||||||
WALK_COMPLEX_TERM();
|
WALK_COMPLEX_TERM();
|
||||||
|
|
||||||
if ((CELL)d0 == v) { /* we found it */
|
if ((CELL)ptd0 == v) { /* we found it */
|
||||||
/* Do we still have compound terms to visit */
|
/* Do we still have compound terms to visit */
|
||||||
while (to_visit > to_visit0) {
|
while (to_visit > to_visit0) {
|
||||||
to_visit--;
|
to_visit--;
|
||||||
@ -452,7 +404,9 @@ static Term vars_in_complex_term(register CELL *pt0, register CELL *pt0_end,
|
|||||||
register tr_fr_ptr TR0 = TR;
|
register tr_fr_ptr TR0 = TR;
|
||||||
CELL *InitialH = HR;
|
CELL *InitialH = HR;
|
||||||
CELL output = AbsPair(HR);
|
CELL output = AbsPair(HR);
|
||||||
|
int lvl = push_text_stack();
|
||||||
|
|
||||||
|
push_text_stack(); \
|
||||||
WALK_COMPLEX_TERM();
|
WALK_COMPLEX_TERM();
|
||||||
/* do or pt2 are unbound */
|
/* do or pt2 are unbound */
|
||||||
*ptd0 = TermNil;
|
*ptd0 = TermNil;
|
||||||
@ -471,18 +425,8 @@ static Term vars_in_complex_term(register CELL *pt0, register CELL *pt0_end,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
TrailTerm(TR++) = (CELL)ptd0;
|
TrailTerm(TR++) = (CELL)ptd0;
|
||||||
goto restart;
|
|
||||||
END_WALK();
|
|
||||||
/* Do we still have compound terms to visit */
|
|
||||||
if (to_visit > to_visit0) {
|
|
||||||
|
|
||||||
to_visit--;
|
END_WALK();
|
||||||
pt0 = to_visit->pt0;
|
|
||||||
pt0_end = to_visit->pt0_end;
|
|
||||||
CELL *ptd0 = to_visit->ptd0;
|
|
||||||
*ptd0 = to_visit->d0;
|
|
||||||
goto restart;
|
|
||||||
}
|
|
||||||
|
|
||||||
clean_tr(TR0 PASS_REGS);
|
clean_tr(TR0 PASS_REGS);
|
||||||
pop_text_stack(lvl);
|
pop_text_stack(lvl);
|
||||||
@ -658,9 +602,9 @@ static Term attvars_in_complex_term(register CELL *pt0, register CELL *pt0_end,
|
|||||||
register tr_fr_ptr TR0 = TR;
|
register tr_fr_ptr TR0 = TR;
|
||||||
CELL *InitialH = HR;
|
CELL *InitialH = HR;
|
||||||
CELL output = inp;
|
CELL output = inp;
|
||||||
|
int lvl = push_text_stack(); \
|
||||||
|
|
||||||
WALK_COMPLEX_TERM();
|
WALK_COMPLEX_TERM();
|
||||||
|
|
||||||
if (IsAttVar(ptd0)) {
|
if (IsAttVar(ptd0)) {
|
||||||
/* do or pt2 are unbound */
|
/* do or pt2 are unbound */
|
||||||
attvar_record *a0 = RepAttVar(ptd0);
|
attvar_record *a0 = RepAttVar(ptd0);
|
||||||
@ -685,22 +629,11 @@ static Term attvars_in_complex_term(register CELL *pt0, register CELL *pt0_end,
|
|||||||
pt0_end = &RepAttVar(ptd0)->Atts;
|
pt0_end = &RepAttVar(ptd0)->Atts;
|
||||||
pt0 = pt0_end - 1;
|
pt0 = pt0_end - 1;
|
||||||
}
|
}
|
||||||
goto restart;
|
|
||||||
END_WALK();
|
|
||||||
/* Do we still have compound terms to visit */
|
|
||||||
if (to_visit > to_visit0) {
|
|
||||||
to_visit--;
|
|
||||||
|
|
||||||
pt0 = to_visit->pt0;
|
END_WALK();
|
||||||
pt0_end = to_visit->pt0_end;
|
|
||||||
CELL *ptd0 = to_visit->ptd0;
|
|
||||||
*ptd0 = to_visit->d0;
|
|
||||||
goto restart;
|
|
||||||
}
|
|
||||||
|
|
||||||
clean_tr(TR0 PASS_REGS);
|
clean_tr(TR0 PASS_REGS);
|
||||||
pop_text_stack(lvl);
|
pop_text_stack(lvl);
|
||||||
fprintf(stderr,"<%ld at %s\n", to_visit-to_visit0, __FUNCTION__);
|
|
||||||
if (HR != InitialH) {
|
if (HR != InitialH) {
|
||||||
/* close the list */
|
/* close the list */
|
||||||
Term t2 = Deref(inp);
|
Term t2 = Deref(inp);
|
||||||
@ -712,6 +645,7 @@ static Term attvars_in_complex_term(register CELL *pt0, register CELL *pt0_end,
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
fprintf(stderr,"<%ld at %s\n", to_visit-to_visit0, __FUNCTION__);
|
||||||
return (output);
|
return (output);
|
||||||
|
|
||||||
def_aux_overflow();
|
def_aux_overflow();
|
||||||
@ -753,16 +687,16 @@ static Term new_vars_in_complex_term(register CELL *pt0, register CELL *pt0_end,
|
|||||||
Term inp USES_REGS) {
|
Term inp USES_REGS) {
|
||||||
register tr_fr_ptr TR0 = TR;
|
register tr_fr_ptr TR0 = TR;
|
||||||
CELL *InitialH = HR;
|
CELL *InitialH = HR;
|
||||||
|
int lvl = push_text_stack(); \
|
||||||
HB=ASP;
|
HB=ASP;
|
||||||
CELL output = TermNil;
|
CELL output = TermNil;
|
||||||
|
|
||||||
{
|
{
|
||||||
while (!IsVarTerm(inp) && IsPairTerm(inp)) {
|
while (!IsVarTerm(inp) && IsPairTerm(inp)) {
|
||||||
Term t = HeadOfTerm(inp);
|
Term t = HeadOfTerm(inp);
|
||||||
if (IsVarTerm(t)) {
|
if (IsVarTerm(t)) {
|
||||||
YapBind( VarOfTerm(t), TermFoundVar );
|
YapBind( VarOfTerm(t), TermFoundVar );
|
||||||
if ((tr_fr_ptr)LOCAL_TrailTop - TR < 1024) {
|
if ((tr_fr_ptr)LOCAL_TrailTop - TR < 1024) {
|
||||||
int lvl = push_text_stack();
|
|
||||||
if (!Yap_growtrail((TR - TR0) * sizeof(tr_fr_ptr *), true)) {
|
if (!Yap_growtrail((TR - TR0) * sizeof(tr_fr_ptr *), true)) {
|
||||||
goto trail_overflow;
|
goto trail_overflow;
|
||||||
}
|
}
|
||||||
@ -785,15 +719,6 @@ static Term new_vars_in_complex_term(register CELL *pt0, register CELL *pt0_end,
|
|||||||
goto global_overflow;
|
goto global_overflow;
|
||||||
}
|
}
|
||||||
END_WALK();
|
END_WALK();
|
||||||
/* Do we still have compound terms to visit */
|
|
||||||
if (to_visit > to_visit0) {
|
|
||||||
to_visit--;
|
|
||||||
|
|
||||||
pt0 = to_visit->pt0;
|
|
||||||
pt0_end = to_visit->pt0_end;
|
|
||||||
CELL *ptd0 = to_visit->ptd0;
|
|
||||||
*ptd0 = to_visit->d0;
|
|
||||||
}
|
|
||||||
|
|
||||||
clean_tr(TR0 PASS_REGS);
|
clean_tr(TR0 PASS_REGS);
|
||||||
pop_text_stack(lvl);
|
pop_text_stack(lvl);
|
||||||
@ -856,6 +781,7 @@ static Term vars_within_complex_term(register CELL *pt0, register CELL *pt0_end,
|
|||||||
tr_fr_ptr TR0 = TR;
|
tr_fr_ptr TR0 = TR;
|
||||||
CELL *InitialH = HR;
|
CELL *InitialH = HR;
|
||||||
CELL output = AbsPair(HR);
|
CELL output = AbsPair(HR);
|
||||||
|
int lvl = push_text_stack();
|
||||||
|
|
||||||
while (!IsVarTerm(inp) && IsPairTerm(inp)) {
|
while (!IsVarTerm(inp) && IsPairTerm(inp)) {
|
||||||
Term t = HeadOfTerm(inp);
|
Term t = HeadOfTerm(inp);
|
||||||
@ -873,16 +799,6 @@ static Term vars_within_complex_term(register CELL *pt0, register CELL *pt0_end,
|
|||||||
WALK_COMPLEX_TERM__({}, {}, FOUND_VAR());
|
WALK_COMPLEX_TERM__({}, {}, FOUND_VAR());
|
||||||
goto restart;
|
goto restart;
|
||||||
END_WALK();
|
END_WALK();
|
||||||
/* Do we still have compound terms to visit */
|
|
||||||
if (to_visit > to_visit0) {
|
|
||||||
to_visit--;
|
|
||||||
|
|
||||||
pt0 = to_visit->pt0;
|
|
||||||
pt0_end = to_visit->pt0_end;
|
|
||||||
CELL *ptd0 = to_visit->ptd0;
|
|
||||||
*ptd0 = to_visit->d0;
|
|
||||||
goto restart;
|
|
||||||
}
|
|
||||||
|
|
||||||
clean_tr(TR0 PASS_REGS);
|
clean_tr(TR0 PASS_REGS);
|
||||||
pop_text_stack(lvl);
|
pop_text_stack(lvl);
|
||||||
@ -931,7 +847,7 @@ static Term free_vars_in_complex_term(CELL *pt0, CELL *pt0_end,
|
|||||||
tr_fr_ptr TR0 USES_REGS) {
|
tr_fr_ptr TR0 USES_REGS) {
|
||||||
Term o = TermNil;
|
Term o = TermNil;
|
||||||
CELL *InitialH = HR;
|
CELL *InitialH = HR;
|
||||||
|
int lvl = push_text_stack();
|
||||||
WALK_COMPLEX_TERM();
|
WALK_COMPLEX_TERM();
|
||||||
/* do or pt2 are unbound */
|
/* do or pt2 are unbound */
|
||||||
*ptd0 = TermNil;
|
*ptd0 = TermNil;
|
||||||
@ -952,19 +868,8 @@ static Term free_vars_in_complex_term(CELL *pt0, CELL *pt0_end,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
TrailTerm(TR++) = (CELL)ptd0;
|
TrailTerm(TR++) = (CELL)ptd0;
|
||||||
goto restart;
|
|
||||||
END_WALK();
|
END_WALK();
|
||||||
|
|
||||||
/* Do we still have compound terms to visit */
|
|
||||||
if (to_visit > to_visit0) {
|
|
||||||
to_visit--;
|
|
||||||
|
|
||||||
pt0 = to_visit->pt0;
|
|
||||||
pt0_end = to_visit->pt0_end;
|
|
||||||
CELL *ptd0 = to_visit->ptd0;
|
|
||||||
*ptd0 = to_visit->d0;
|
|
||||||
goto restart;
|
|
||||||
}
|
|
||||||
|
|
||||||
clean_tr(TR0 PASS_REGS);
|
clean_tr(TR0 PASS_REGS);
|
||||||
pop_text_stack(lvl);
|
pop_text_stack(lvl);
|
||||||
@ -980,7 +885,7 @@ static Term free_vars_in_complex_term(CELL *pt0, CELL *pt0_end,
|
|||||||
static Term bind_vars_in_complex_term(CELL *pt0, CELL *pt0_end,
|
static Term bind_vars_in_complex_term(CELL *pt0, CELL *pt0_end,
|
||||||
tr_fr_ptr TR0 USES_REGS) {
|
tr_fr_ptr TR0 USES_REGS) {
|
||||||
CELL *InitialH = HR;
|
CELL *InitialH = HR;
|
||||||
|
int lvl = push_text_stack();
|
||||||
WALK_COMPLEX_TERM();
|
WALK_COMPLEX_TERM();
|
||||||
/* do or pt2 are unbound */
|
/* do or pt2 are unbound */
|
||||||
*ptd0 = TermFoundVar;
|
*ptd0 = TermFoundVar;
|
||||||
@ -997,16 +902,8 @@ static Term bind_vars_in_complex_term(CELL *pt0, CELL *pt0_end,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
TrailTerm(TR++) = (CELL)ptd0;
|
TrailTerm(TR++) = (CELL)ptd0;
|
||||||
goto restart;
|
|
||||||
END_WALK();
|
|
||||||
|
|
||||||
/* Do we still have compound terms to visit */
|
END_WALK();
|
||||||
if (to_visit > to_visit0) {
|
|
||||||
to_visit--;
|
|
||||||
pt0 = to_visit->ptd0;
|
|
||||||
*pt0 = to_visit->d0;
|
|
||||||
goto list_loop;
|
|
||||||
}
|
|
||||||
|
|
||||||
pop_text_stack(lvl);
|
pop_text_stack(lvl);
|
||||||
return TermNil;
|
return TermNil;
|
||||||
@ -1083,22 +980,12 @@ static Term non_singletons_in_complex_term(CELL *pt0, CELL *pt0_end USES_REGS) {
|
|||||||
CELL *InitialH = HR;
|
CELL *InitialH = HR;
|
||||||
HB = (CELL *)ASP;
|
HB = (CELL *)ASP;
|
||||||
CELL output = AbsPair(HR);
|
CELL output = AbsPair(HR);
|
||||||
|
int lvl = push_text_stack();
|
||||||
WALK_COMPLEX_TERM__({}, {}, FOUND_VAR_AGAIN());
|
WALK_COMPLEX_TERM__({}, {}, FOUND_VAR_AGAIN());
|
||||||
/* do or pt2 are unbound */
|
/* do or pt2 are unbound */
|
||||||
YapBind(ptd0,TermFoundVar);
|
YapBind(ptd0,TermFoundVar);
|
||||||
goto restart;
|
goto restart;
|
||||||
END_WALK();
|
END_WALK();
|
||||||
/* Do we still have compound terms to visit */
|
|
||||||
if (to_visit > to_visit0) {
|
|
||||||
to_visit--;
|
|
||||||
|
|
||||||
pt0 = to_visit->pt0;
|
|
||||||
pt0_end = to_visit->pt0_end;
|
|
||||||
CELL *ptd0 = to_visit->ptd0;
|
|
||||||
*ptd0 = to_visit->d0;
|
|
||||||
goto restart;
|
|
||||||
}
|
|
||||||
|
|
||||||
clean_tr(TR0 PASS_REGS);
|
clean_tr(TR0 PASS_REGS);
|
||||||
|
|
||||||
@ -1164,6 +1051,7 @@ static Int numbervars_in_complex_term(CELL *pt0, CELL *pt0_end, Int numbv,
|
|||||||
|
|
||||||
tr_fr_ptr TR0 = TR;
|
tr_fr_ptr TR0 = TR;
|
||||||
CELL *InitialH = HR;
|
CELL *InitialH = HR;
|
||||||
|
int lvl = push_text_stack();
|
||||||
|
|
||||||
WALK_COMPLEX_TERM__({}, {}, {});
|
WALK_COMPLEX_TERM__({}, {}, {});
|
||||||
|
|
||||||
@ -1181,23 +1069,8 @@ static Int numbervars_in_complex_term(CELL *pt0, CELL *pt0_end, Int numbv,
|
|||||||
/* next make sure noone will see this as a variable again */
|
/* next make sure noone will see this as a variable again */
|
||||||
YapBind(ptd0, d0);
|
YapBind(ptd0, d0);
|
||||||
|
|
||||||
continue;
|
|
||||||
|
|
||||||
END_WALK();
|
END_WALK();
|
||||||
|
|
||||||
/* Do we still have compound terms to visit */
|
|
||||||
while (to_visit > to_visit0) {
|
|
||||||
to_visit--;
|
|
||||||
|
|
||||||
pt0 = to_visit->pt0;
|
|
||||||
pt0_end = to_visit->pt0_end;
|
|
||||||
CELL *ptd0 = to_visit->ptd0;
|
|
||||||
*ptd0 = to_visit->d0;
|
|
||||||
if (pt0 >= pt0_end)
|
|
||||||
continue;
|
|
||||||
goto restart;
|
|
||||||
}
|
|
||||||
|
|
||||||
pop_text_stack(lvl);
|
pop_text_stack(lvl);
|
||||||
return numbv;
|
return numbv;
|
||||||
|
|
||||||
@ -1267,7 +1140,7 @@ static Int p_numbervars(USES_REGS1) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int max_numbered_var(CELL *pt0, CELL *pt0_end, Int *maxp USES_REGS) {
|
static int max_numbered_var(CELL *pt0, CELL *pt0_end, Int *maxp USES_REGS) {
|
||||||
|
int lvl = push_text_stack();
|
||||||
WALK_COMPLEX_TERM__({}, MAX_NUMBERED, {});
|
WALK_COMPLEX_TERM__({}, MAX_NUMBERED, {});
|
||||||
END_WALK();
|
END_WALK();
|
||||||
/* Do we still have compound terms to visit */
|
/* Do we still have compound terms to visit */
|
||||||
@ -1333,49 +1206,62 @@ static Term UNFOLD_LOOP(Term t, Term *b) {
|
|||||||
static Term *loops_in_complex_term(CELL *pt0, CELL *pt0_end,
|
static Term *loops_in_complex_term(CELL *pt0, CELL *pt0_end,
|
||||||
Term *listp USES_REGS) {
|
Term *listp USES_REGS) {
|
||||||
int lvl = push_text_stack();
|
int lvl = push_text_stack();
|
||||||
|
CELL *ptf0 = HR;
|
||||||
|
tr_fr_ptr TR0 = TR;
|
||||||
|
|
||||||
struct non_single_struct_t *to_visit = Malloc(
|
struct non_single_struct_t *to_visit = Malloc(
|
||||||
1024 * sizeof(struct non_single_struct_t)),
|
1024 * sizeof(struct non_single_struct_t)),
|
||||||
*to_visit0 = to_visit,
|
*to_visit0 = to_visit,
|
||||||
*to_visit_max = to_visit + 1024;
|
*to_visit_max = to_visit + 1024;
|
||||||
CELL *ptd0;
|
do{
|
||||||
CELL *ptf0 = HR,
|
CELL *ptd0,
|
||||||
*ptf = HR;
|
*ptf = HR;
|
||||||
|
CELL d0;
|
||||||
restart:
|
restart:
|
||||||
while (pt0 < pt0_end) {
|
while (pt0 < pt0_end) {
|
||||||
CELL d0;
|
|
||||||
++pt0;
|
++pt0;
|
||||||
ptd0 = pt0;
|
ptd0 = pt0;
|
||||||
d0 = *ptd0;
|
d0 = *ptd0;
|
||||||
list_loop:
|
list_loop:
|
||||||
fprintf(stderr,"%d at %s\n", to_visit-to_visit0, __FUNCTION__);
|
{
|
||||||
|
fprintf(stderr,"%ld at %s\n", to_visit-to_visit0, __FUNCTION__);
|
||||||
deref_head(d0, vars_in_term_unk);
|
deref_head(d0, vars_in_term_unk);
|
||||||
vars_in_term_nvar:
|
vars_in_term_nvar:
|
||||||
if (IsPairTerm(d0)) {
|
if (IsPairTerm(d0)) {
|
||||||
if (to_visit + 32 >= to_visit_max) {
|
if (to_visit + 32 >= to_visit_max) {
|
||||||
goto aux_overflow;
|
goto aux_overflow;
|
||||||
}
|
}
|
||||||
CELL *ptd0 = RepPair(d0);
|
ptd0 = RepPair(d0);
|
||||||
d0 = ptd0[0];
|
d0 = ptd0[0];
|
||||||
if (IsAtomTerm(d0) && (CELL *)AtomOfTerm(d0) >= (CELL *)to_visit0 &&
|
if (listp) {
|
||||||
(CELL *)AtomOfTerm(d0) < (CELL *)to_visit) {
|
CELL *pt = VarOfTerm(d0);
|
||||||
|
if (pt &&pt >= ptf &&
|
||||||
|
pt < HR) {
|
||||||
// LIST0;
|
// LIST0;
|
||||||
|
*ptf++ = UNFOLD_LOOP(AbsPair(pt), listp);
|
||||||
|
continue;
|
||||||
|
} else {
|
||||||
|
*ptf++ = AbsPair(HR);
|
||||||
|
MaBind( ptd0, AbsPair(ptf - 1));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
struct non_single_struct_t *v0 =
|
struct non_single_struct_t *v0 =
|
||||||
(struct non_single_struct_t *)AtomOfTerm(d0);
|
(struct non_single_struct_t *)AtomOfTerm(d0);
|
||||||
if (listp) {
|
if (IsAtomTerm(d0) && v0 >= to_visit0 &&
|
||||||
*ptf++ = UNFOLD_LOOP(AbsPair(v0->ptf-1), listp);
|
(CELL *)AtomOfTerm(d0) < (CELL *)to_visit) {
|
||||||
} else {
|
// LIST0;
|
||||||
*ptf++ = BREAK_LOOP(to_visit - v0);
|
*ptf++ = BREAK_LOOP(to_visit - v0);
|
||||||
}
|
|
||||||
continue;
|
continue;
|
||||||
}
|
} else {
|
||||||
*ptf++ = AbsPair(HR);
|
*ptf++ = AbsPair(HR);
|
||||||
to_visit->pt0 = pt0;
|
|
||||||
to_visit->pt0_end = pt0_end;
|
|
||||||
to_visit->ptd0 = ptd0;
|
to_visit->ptd0 = ptd0;
|
||||||
to_visit->ptf = ptf;
|
|
||||||
to_visit->d0 = d0 = *ptd0;
|
to_visit->d0 = d0 = *ptd0;
|
||||||
*ptd0 = MkAtomTerm((AtomEntry *)to_visit);
|
*ptd0 = MkAtomTerm((AtomEntry *)to_visit);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
to_visit->pt0 = pt0;
|
||||||
|
to_visit->pt0_end = pt0_end;
|
||||||
|
to_visit->ptf = ptf;
|
||||||
to_visit++;
|
to_visit++;
|
||||||
pt0 = ptd0;
|
pt0 = ptd0;
|
||||||
pt0_end = pt0 + 1;
|
pt0_end = pt0 + 1;
|
||||||
@ -1389,30 +1275,43 @@ static Term *loops_in_complex_term(CELL *pt0, CELL *pt0_end,
|
|||||||
/* store the terms to visit */
|
/* store the terms to visit */
|
||||||
ptd0 = RepAppl(d0);
|
ptd0 = RepAppl(d0);
|
||||||
f = (Functor)(*ptd0);
|
f = (Functor)(*ptd0);
|
||||||
if (IsExtensionFunctor(f)) {
|
if (IsExtensionFunctor(f) || f == FunctorDollarVar) {
|
||||||
*ptf++ = d0;
|
*ptf++ = d0;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (IsAtomTerm((CELL)f)) {
|
|
||||||
struct non_single_struct_t *v0 = (struct non_single_struct_t *)AtomOfTerm(*ptd0);
|
|
||||||
if (listp) {
|
if (listp) {
|
||||||
*ptf++ = UNFOLD_LOOP(AbsAppl(v0->ptf-1), listp);
|
CELL *pt = (CELL *)f;
|
||||||
} else {
|
if (IsVarTerm(d0) && pt >= ptf0 &&
|
||||||
*ptf++ = BREAK_LOOP(to_visit - v0);
|
pt < HR) {
|
||||||
}
|
// LIST0;
|
||||||
|
*ptf++ = UNFOLD_LOOP(AbsAppl(pt), listp);
|
||||||
continue;
|
continue;
|
||||||
|
} else {
|
||||||
|
*ptf++ = AbsAppl(HR);
|
||||||
|
MaBind( pt, AbsAppl(ptf - 1));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
struct non_single_struct_t *v0 =
|
||||||
|
(struct non_single_struct_t *)AtomOfTerm(d0);
|
||||||
|
if (IsAtomTerm(d0) && v0 >= to_visit0 &&
|
||||||
|
v0 < to_visit) {
|
||||||
|
// LIST0;
|
||||||
|
*ptf++ = BREAK_LOOP(to_visit - v0);
|
||||||
|
continue;
|
||||||
|
} else {
|
||||||
|
*ptf++ = AbsAppl(HR);
|
||||||
|
to_visit->ptd0 = ptd0;
|
||||||
|
to_visit->d0 = d0;
|
||||||
|
*ptd0 = MkAtomTerm((AtomEntry *)to_visit);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// STRUCT0;
|
// STRUCT0;
|
||||||
if (to_visit + 32 >= to_visit_max) {
|
if (to_visit + 32 >= to_visit_max) {
|
||||||
goto aux_overflow;
|
goto aux_overflow;
|
||||||
}
|
}
|
||||||
*ptf++ = AbsAppl(HR);
|
|
||||||
to_visit->pt0 = pt0;
|
to_visit->pt0 = pt0;
|
||||||
to_visit->pt0_end = pt0_end;
|
to_visit->pt0_end = pt0_end;
|
||||||
to_visit->ptd0 = ptd0;
|
|
||||||
to_visit->d0 = *ptd0;
|
|
||||||
to_visit->ptf = ptf;
|
to_visit->ptf = ptf;
|
||||||
*ptd0 = MkAtomTerm((AtomEntry *)to_visit);
|
|
||||||
to_visit++;
|
to_visit++;
|
||||||
pt0 = ptd0;
|
pt0 = ptd0;
|
||||||
pt0_end = ptd0 + (ArityOfFunctor(f));
|
pt0_end = ptd0 + (ArityOfFunctor(f));
|
||||||
@ -1422,25 +1321,27 @@ static Term *loops_in_complex_term(CELL *pt0, CELL *pt0_end,
|
|||||||
} else {
|
} else {
|
||||||
*ptf++ = d0;
|
*ptf++ = d0;
|
||||||
}
|
}
|
||||||
goto restart;
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
derefa_body(d0, ptd0, vars_in_term_unk, vars_in_term_nvar);
|
derefa_body(d0, ptd0, vars_in_term_unk, vars_in_term_nvar);
|
||||||
*ptf++ = *ptd0;
|
*ptf++ = *ptd0;
|
||||||
goto restart;
|
continue;
|
||||||
}
|
}
|
||||||
/* Do we still have compound terms to visit */
|
/* Do we still have compound terms to visit */
|
||||||
if (to_visit > to_visit0) {
|
while (to_visit > to_visit0) {
|
||||||
to_visit--;
|
to_visit--;
|
||||||
|
|
||||||
pt0 = to_visit->pt0;
|
pt0 = to_visit->pt0;
|
||||||
ptf = to_visit->ptf;
|
ptf = to_visit->ptf;
|
||||||
pt0_end = to_visit->pt0_end;
|
pt0_end = to_visit->pt0_end;
|
||||||
ptd0 = to_visit->ptd0;
|
to_visit->ptd0[0] = to_visit->d0;
|
||||||
*ptd0 = to_visit->d0;
|
}
|
||||||
goto restart;
|
} while (to_visit > to_visit0) ;
|
||||||
|
fprintf(stderr,"exit %ld at %s\n", to_visit-to_visit0, __FUNCTION__);
|
||||||
|
if (listp) {
|
||||||
|
clean_tr(TR0);
|
||||||
}
|
}
|
||||||
fprintf(stderr,"exit %d at %s\n", to_visit-to_visit0, __FUNCTION__);
|
|
||||||
|
|
||||||
pop_text_stack(lvl);
|
pop_text_stack(lvl);
|
||||||
return ptf0;
|
return ptf0;
|
||||||
|
|
||||||
|
@ -95,13 +95,11 @@ d(X) :- X:=: f(_,A/[A]), A:=: f(B,[X,g(A)]), B:=:[C|B], C:=:[X].
|
|||||||
|
|
||||||
end :- writeln('....'), fail.
|
end :- writeln('....'), fail.
|
||||||
|
|
||||||
/*
|
|
||||||
e(X,Y) :- X :=: t(_A,B,_C,D), Y :=: [B,E].
|
e(X,Y) :- X :=: t(_A,B,_C,D), Y :=: [B,E].
|
||||||
e(X,Y) :- X :=: t(_A,_B,_C,_D), Y :=: [_,_E].
|
e(X,Y) :- X :=: t(_A,_B,_C,_D), Y :=: [_,_E].
|
||||||
e(X,Y) :- X :=: t(A,_B,C,_D), Y :=: [ A,C].
|
e(X,Y) :- X :=: t(A,_B,C,_D), Y :=: [ A,C].
|
||||||
e(X,Y) :- X :=: t(A,[X,_D]), Y :=: [A,_C,_E].
|
e(X,Y) :- X :=: t(A,[X,_D]), Y :=: [A,_C,_E].
|
||||||
e(X,Y) :- X :=: t(A,[X,C]), Y :=: [A,C,_E].
|
e(X,Y) :- X :=: t(A,[X,C]), Y :=: [A,C,_E].
|
||||||
*/
|
|
||||||
e(X,Y) :- X :=: t(A,X,_B,[X,C,_D]), Y :=: [A,C,_E].
|
e(X,Y) :- X :=: t(A,X,_B,[X,C,_D]), Y :=: [A,C,_E].
|
||||||
|
|
||||||
a(no, no).
|
a(no, no).
|
||||||
|
Reference in New Issue
Block a user