loops
This commit is contained in:
parent
ca2542c798
commit
fa96ffa932
@ -2854,12 +2854,12 @@ static Int undefp_handler(USES_REGS1) { /* '$undefp_handler'(P,Mod) */
|
||||
pe = Yap_get_pred(Deref(ARG1), Deref(ARG2), "undefined/1");
|
||||
PELOCK(59, pe);
|
||||
if (EndOfPAEntr(pe)) {
|
||||
UndefCode = FAILCODE;
|
||||
UndefCode = Yap_get_pred(TermFail, MkIntTerm(0), "no def");
|
||||
UNLOCKPE(59, pe);
|
||||
return false;
|
||||
}
|
||||
if (pe->OpcodeOfPred == UNDEF_OPCODE) {
|
||||
UndefCode = FAILCODE;
|
||||
UndefCode = Yap_get_pred(TermFail, MkIntTerm(0), "no def");
|
||||
UNLOCKPE(59, pe);
|
||||
return false;
|
||||
}
|
||||
|
13
C/write.c
13
C/write.c
@ -1107,15 +1107,9 @@ void Yap_plwrite(Term t, StreamDesc *mywrite, int max_depth, int flags,
|
||||
rwt.parent = NULL;
|
||||
wglb.Ignore_ops = flags & Ignore_ops_f;
|
||||
wglb.Write_strings = flags & BackQuote_String_f;
|
||||
if (!(flags & Ignore_cyclics_f) && false) {
|
||||
Term ts[2];
|
||||
ts[0] = Yap_BreakRational(t, 0, ts + 1, TermNil PASS_REGS);
|
||||
// fprintf(stderr, "%lx %lx %lx\n", t, ts[0], ts[1]);
|
||||
// Yap_DebugPlWriteln(ts[0]);
|
||||
// ap_DebugPlWriteln(ts[1[);
|
||||
if (ts[1] != TermNil) {
|
||||
t = Yap_MkApplTerm(FunctorAtSymbol, 2, ts);
|
||||
}
|
||||
// if (!(flags & Ignore_cyclics_f) && false)
|
||||
{
|
||||
t = Yap_CheckLoops(t, 1);
|
||||
}
|
||||
/* protect slots for portray */
|
||||
writeTerm(t, priority, 1, FALSE, &wglb, &rwt);
|
||||
@ -1135,3 +1129,4 @@ void Yap_plwrite(Term t, StreamDesc *mywrite, int max_depth, int flags,
|
||||
Yap_CloseSlots(sls);
|
||||
pop_text_stack(lvl);
|
||||
}
|
||||
|
||||
|
@ -482,6 +482,9 @@ set_property(DIRECTORY APPEND PROPERTY COMPILE_DEFINITIONS "_YAP_NOT_INSTALLED_=
|
||||
# Model Specific
|
||||
set_property(DIRECTORY APPEND PROPERTY COMPILE_DEFINITIONS $<$<CONFIG:Debug>:DEBUG=1>)
|
||||
|
||||
# debug across macros
|
||||
set_property(DIRECTORY APPEND PROPERTY COMPILE_OPTIONS $<$<CONFIG:Debug>:-g3>)
|
||||
|
||||
#ensure cells are properly aligned in code
|
||||
set(ALIGN_LONGS 1)
|
||||
|
||||
|
@ -444,6 +444,10 @@ extern bool Yap_ChDir(const char *path);
|
||||
bool Yap_isDirectory(const char *FileName);
|
||||
extern bool Yap_Exists(const char *f);
|
||||
|
||||
/* terms.c */
|
||||
extern Term Yap_CheckLoops(Term inp, UInt arity USES_REGS);
|
||||
extern void Yap_InitTermCPreds(void);
|
||||
|
||||
/* threads.c */
|
||||
extern void Yap_InitThreadPreds(void);
|
||||
extern void Yap_InitFirstWorkerThreadHandle(void);
|
||||
|
@ -285,4 +285,8 @@ INLINE_ONLY Term Yap_ensure_atom__(const char *fu, const char *fi, int line,
|
||||
yap_error_descriptor_t *new_error);
|
||||
extern yap_error_descriptor_t *Yap_popErrorContext(bool oerr, bool pass);
|
||||
|
||||
#define must_be_variable(t) if (!IsVarTerm(t)) Yap_ThrowError(UNINSTANTIATION_ERROR, v, NULL)
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
|
@ -103,14 +103,6 @@ Succeed if _Term1_ and _Term2_ are unifiable with substitution
|
||||
|
||||
|
||||
|
||||
*/
|
||||
/** @pred variable_in_term(? _Term_,? _Var_)
|
||||
|
||||
|
||||
Succeed if the second argument _Var_ is a variable and occurs in
|
||||
term _Term_.
|
||||
|
||||
|
||||
*/
|
||||
/** @pred variables_within_term(+ _Variables_,? _Term_, - _OutputVariables_)
|
||||
|
||||
@ -136,6 +128,7 @@ Succeed if _Term1_ and _Term2_ are variant terms.
|
||||
variant/2,
|
||||
unifiable/3,
|
||||
subsumes/2,
|
||||
|
||||
subsumes_chk/2,
|
||||
cyclic_term/1,
|
||||
variable_in_term/2,
|
||||
|
Reference in New Issue
Block a user