indenting & Android support (one big lib)
This commit is contained in:
parent
abe5953da7
commit
24e6924769
@ -4,8 +4,7 @@ set(SO_MAJOR 1)
|
|||||||
set(SO_MINOR 0)
|
set(SO_MINOR 0)
|
||||||
set(SO_PATCH 0)
|
set(SO_PATCH 0)
|
||||||
|
|
||||||
|
set (CXX_SOURCES
|
||||||
add_library (Yap++ SHARED
|
|
||||||
yapa.hh
|
yapa.hh
|
||||||
yapdb.hh
|
yapdb.hh
|
||||||
yapi.cpp
|
yapi.cpp
|
||||||
@ -13,9 +12,17 @@ add_library (Yap++ SHARED
|
|||||||
yapie.hh
|
yapie.hh
|
||||||
yapq.hh
|
yapq.hh
|
||||||
yapt.hh
|
yapt.hh
|
||||||
)
|
)
|
||||||
|
|
||||||
include_directories (H include ${CMAKE_BINARY_DIR} ${GMP_INCLUDE_DIR})
|
|
||||||
|
if (ANDROID)
|
||||||
|
add_library (Yap++ OBJECT
|
||||||
|
${CXX_SOURCES}
|
||||||
|
)
|
||||||
|
else()
|
||||||
|
add_library (Yap++ SHARED
|
||||||
|
${CXX_SOURCES}
|
||||||
|
)
|
||||||
|
|
||||||
target_link_libraries(Yap++ ${CMAKE_DL_LIBS} libYap)
|
target_link_libraries(Yap++ ${CMAKE_DL_LIBS} libYap)
|
||||||
|
|
||||||
@ -23,6 +30,9 @@ install(TARGETS Yap++
|
|||||||
LIBRARY DESTINATION ${libdir}
|
LIBRARY DESTINATION ${libdir}
|
||||||
ARCHIVE DESTINATION ${libdir}
|
ARCHIVE DESTINATION ${libdir}
|
||||||
)
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
include_directories (H include ${CMAKE_BINARY_DIR} ${GMP_INCLUDE_DIR})
|
||||||
|
|
||||||
set( CMAKE_REQUIRED_INCLUDES ${CMAKE_REQUIRED_INCLUDES} ${GMP_INCLUDE_DIR} )
|
set( CMAKE_REQUIRED_INCLUDES ${CMAKE_REQUIRED_INCLUDES} ${GMP_INCLUDE_DIR} )
|
||||||
#set( CMAKE_REQUIRED_LIBRARIES ${CMAKE_REQUIRED_LIBRARIES} ${GMP_LIBRARIES} )
|
#set( CMAKE_REQUIRED_LIBRARIES ${CMAKE_REQUIRED_LIBRARIES} ${GMP_LIBRARIES} )
|
||||||
|
354
CXX/yapi.cpp
354
CXX/yapi.cpp
@ -8,14 +8,16 @@ extern "C" {
|
|||||||
#include "YapInterface.h"
|
#include "YapInterface.h"
|
||||||
#include "blobs.h"
|
#include "blobs.h"
|
||||||
|
|
||||||
char *Yap_TermToString(Term t, char *s, size_t sz, size_t *length, encoding_t *encodingp, int flags);
|
char *Yap_TermToString(Term t, char *s, size_t sz, size_t *length,
|
||||||
|
encoding_t *encodingp, int flags);
|
||||||
|
|
||||||
void YAP_UserCPredicate(const char *, YAP_UserCPred, YAP_Arity arity);
|
void YAP_UserCPredicate(const char *, YAP_UserCPred, YAP_Arity arity);
|
||||||
void YAP_UserCPredicateWithArgs(const char *, YAP_UserCPred, YAP_Arity, YAP_Term);
|
void YAP_UserCPredicateWithArgs(const char *, YAP_UserCPred, YAP_Arity,
|
||||||
void YAP_UserBackCPredicate(const char *, YAP_UserCPred, YAP_UserCPred, YAP_Arity, YAP_Arity);
|
YAP_Term);
|
||||||
|
void YAP_UserBackCPredicate(const char *, YAP_UserCPred, YAP_UserCPred,
|
||||||
|
YAP_Arity, YAP_Arity);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
YAPAtomTerm::YAPAtomTerm(char *s) { // build string
|
YAPAtomTerm::YAPAtomTerm(char *s) { // build string
|
||||||
BACKUP_H();
|
BACKUP_H();
|
||||||
|
|
||||||
@ -25,12 +27,12 @@ YAPAtomTerm::YAPAtomTerm(char *s) { // build string
|
|||||||
inp.type = YAP_STRING_CHARS;
|
inp.type = YAP_STRING_CHARS;
|
||||||
out.type = YAP_STRING_ATOM;
|
out.type = YAP_STRING_ATOM;
|
||||||
if (Yap_CVT_Text(&inp, &out PASS_REGS))
|
if (Yap_CVT_Text(&inp, &out PASS_REGS))
|
||||||
mk ( MkAtomTerm(out.val.a) );
|
mk(MkAtomTerm(out.val.a));
|
||||||
else t = 0L;
|
else
|
||||||
|
t = 0L;
|
||||||
RECOVER_H();
|
RECOVER_H();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
YAPAtomTerm::YAPAtomTerm(char *s, size_t len) { // build string
|
YAPAtomTerm::YAPAtomTerm(char *s, size_t len) { // build string
|
||||||
BACKUP_H();
|
BACKUP_H();
|
||||||
|
|
||||||
@ -38,16 +40,17 @@ YAPAtomTerm::YAPAtomTerm(char *s, size_t len) { // build string
|
|||||||
seq_tv_t inp, out;
|
seq_tv_t inp, out;
|
||||||
inp.val.c = s;
|
inp.val.c = s;
|
||||||
inp.type = YAP_STRING_CHARS;
|
inp.type = YAP_STRING_CHARS;
|
||||||
out.type = YAP_STRING_ATOM|YAP_STRING_NCHARS|YAP_STRING_TRUNC;
|
out.type = YAP_STRING_ATOM | YAP_STRING_NCHARS | YAP_STRING_TRUNC;
|
||||||
out.sz = len;
|
out.sz = len;
|
||||||
out.max = len;
|
out.max = len;
|
||||||
if (Yap_CVT_Text(&inp, &out PASS_REGS))
|
if (Yap_CVT_Text(&inp, &out PASS_REGS))
|
||||||
mk ( MkAtomTerm(out.val.a) );
|
mk(MkAtomTerm(out.val.a));
|
||||||
else t = 0L;
|
else
|
||||||
|
t = 0L;
|
||||||
RECOVER_H();
|
RECOVER_H();
|
||||||
}
|
}
|
||||||
|
|
||||||
YAPAtomTerm::YAPAtomTerm(wchar_t *s): YAPTerm() { // build string
|
YAPAtomTerm::YAPAtomTerm(wchar_t *s) : YAPTerm() { // build string
|
||||||
BACKUP_H();
|
BACKUP_H();
|
||||||
|
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
@ -56,12 +59,12 @@ YAPAtomTerm::YAPAtomTerm(wchar_t *s): YAPTerm() { // build string
|
|||||||
inp.type = YAP_STRING_WCHARS;
|
inp.type = YAP_STRING_WCHARS;
|
||||||
out.type = YAP_STRING_ATOM;
|
out.type = YAP_STRING_ATOM;
|
||||||
if (Yap_CVT_Text(&inp, &out PASS_REGS))
|
if (Yap_CVT_Text(&inp, &out PASS_REGS))
|
||||||
mk ( MkAtomTerm(out.val.a) );
|
mk(MkAtomTerm(out.val.a));
|
||||||
else t = 0L;
|
else
|
||||||
|
t = 0L;
|
||||||
RECOVER_H();
|
RECOVER_H();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
YAPAtomTerm::YAPAtomTerm(wchar_t *s, size_t len) : YAPTerm() { // build string
|
YAPAtomTerm::YAPAtomTerm(wchar_t *s, size_t len) : YAPTerm() { // build string
|
||||||
BACKUP_H();
|
BACKUP_H();
|
||||||
|
|
||||||
@ -69,16 +72,16 @@ YAPAtomTerm::YAPAtomTerm(wchar_t *s, size_t len) : YAPTerm() { // build string
|
|||||||
seq_tv_t inp, out;
|
seq_tv_t inp, out;
|
||||||
inp.val.w = s;
|
inp.val.w = s;
|
||||||
inp.type = YAP_STRING_WCHARS;
|
inp.type = YAP_STRING_WCHARS;
|
||||||
out.type = YAP_STRING_ATOM|YAP_STRING_NCHARS|YAP_STRING_TRUNC;
|
out.type = YAP_STRING_ATOM | YAP_STRING_NCHARS | YAP_STRING_TRUNC;
|
||||||
out.sz = len;
|
out.sz = len;
|
||||||
out.max = len;
|
out.max = len;
|
||||||
if (Yap_CVT_Text(&inp, &out PASS_REGS))
|
if (Yap_CVT_Text(&inp, &out PASS_REGS))
|
||||||
mk ( MkAtomTerm(out.val.a) );
|
mk(MkAtomTerm(out.val.a));
|
||||||
else t = 0L;
|
else
|
||||||
|
t = 0L;
|
||||||
RECOVER_H();
|
RECOVER_H();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
YAPStringTerm::YAPStringTerm(char *s) { // build string
|
YAPStringTerm::YAPStringTerm(char *s) { // build string
|
||||||
BACKUP_H();
|
BACKUP_H();
|
||||||
|
|
||||||
@ -88,12 +91,12 @@ YAPStringTerm::YAPStringTerm(char *s) { // build string
|
|||||||
inp.type = YAP_STRING_CHARS;
|
inp.type = YAP_STRING_CHARS;
|
||||||
out.type = YAP_STRING_STRING;
|
out.type = YAP_STRING_STRING;
|
||||||
if (Yap_CVT_Text(&inp, &out PASS_REGS))
|
if (Yap_CVT_Text(&inp, &out PASS_REGS))
|
||||||
mk ( out.val.t );
|
mk(out.val.t);
|
||||||
else t = 0L;
|
else
|
||||||
|
t = 0L;
|
||||||
RECOVER_H();
|
RECOVER_H();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
YAPStringTerm::YAPStringTerm(char *s, size_t len) { // build string
|
YAPStringTerm::YAPStringTerm(char *s, size_t len) { // build string
|
||||||
BACKUP_H();
|
BACKUP_H();
|
||||||
|
|
||||||
@ -102,16 +105,17 @@ YAPStringTerm::YAPStringTerm(char *s, size_t len) { // build string
|
|||||||
seq_tv_t inp, out;
|
seq_tv_t inp, out;
|
||||||
inp.val.c = s;
|
inp.val.c = s;
|
||||||
inp.type = YAP_STRING_CHARS;
|
inp.type = YAP_STRING_CHARS;
|
||||||
out.type = YAP_STRING_STRING|YAP_STRING_NCHARS|YAP_STRING_TRUNC;
|
out.type = YAP_STRING_STRING | YAP_STRING_NCHARS | YAP_STRING_TRUNC;
|
||||||
out.sz = len;
|
out.sz = len;
|
||||||
out.max = len;
|
out.max = len;
|
||||||
if (Yap_CVT_Text(&inp, &out PASS_REGS))
|
if (Yap_CVT_Text(&inp, &out PASS_REGS))
|
||||||
mk ( out.val.t );
|
mk(out.val.t);
|
||||||
else t = 0L;
|
else
|
||||||
|
t = 0L;
|
||||||
RECOVER_H();
|
RECOVER_H();
|
||||||
}
|
}
|
||||||
|
|
||||||
YAPStringTerm::YAPStringTerm(wchar_t *s): YAPTerm() { // build string
|
YAPStringTerm::YAPStringTerm(wchar_t *s) : YAPTerm() { // build string
|
||||||
BACKUP_H();
|
BACKUP_H();
|
||||||
|
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
@ -121,13 +125,14 @@ YAPStringTerm::YAPStringTerm(wchar_t *s): YAPTerm() { // build string
|
|||||||
inp.type = YAP_STRING_WCHARS;
|
inp.type = YAP_STRING_WCHARS;
|
||||||
out.type = YAP_STRING_STRING;
|
out.type = YAP_STRING_STRING;
|
||||||
if (Yap_CVT_Text(&inp, &out PASS_REGS))
|
if (Yap_CVT_Text(&inp, &out PASS_REGS))
|
||||||
mk ( out.val.t );
|
mk(out.val.t);
|
||||||
else t = 0L;
|
else
|
||||||
|
t = 0L;
|
||||||
RECOVER_H();
|
RECOVER_H();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
YAPStringTerm::YAPStringTerm(wchar_t *s, size_t len)
|
||||||
YAPStringTerm::YAPStringTerm(wchar_t *s, size_t len) : YAPTerm() { // build string
|
: YAPTerm() { // build string
|
||||||
BACKUP_H();
|
BACKUP_H();
|
||||||
|
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
@ -135,60 +140,58 @@ YAPStringTerm::YAPStringTerm(wchar_t *s, size_t len) : YAPTerm() { // build stri
|
|||||||
seq_tv_t inp, out;
|
seq_tv_t inp, out;
|
||||||
inp.val.w = s;
|
inp.val.w = s;
|
||||||
inp.type = YAP_STRING_WCHARS;
|
inp.type = YAP_STRING_WCHARS;
|
||||||
out.type = YAP_STRING_STRING|YAP_STRING_NCHARS|YAP_STRING_TRUNC;
|
out.type = YAP_STRING_STRING | YAP_STRING_NCHARS | YAP_STRING_TRUNC;
|
||||||
out.sz = len;
|
out.sz = len;
|
||||||
out.max = len;
|
out.max = len;
|
||||||
if (Yap_CVT_Text(&inp, &out PASS_REGS))
|
if (Yap_CVT_Text(&inp, &out PASS_REGS))
|
||||||
mk ( out.val.t );
|
mk(out.val.t);
|
||||||
else t = 0L;
|
else
|
||||||
|
t = 0L;
|
||||||
RECOVER_H();
|
RECOVER_H();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
YAPApplTerm::YAPApplTerm(YAPFunctor f, YAPTerm ts[]) : YAPTerm() {
|
YAPApplTerm::YAPApplTerm(YAPFunctor f, YAPTerm ts[]) : YAPTerm() {
|
||||||
BACKUP_H();
|
BACKUP_H();
|
||||||
UInt arity = ArityOfFunctor(f.f);
|
UInt arity = ArityOfFunctor(f.f);
|
||||||
mk ( Yap_MkApplTerm( f.f, arity, (Term *)ts) );
|
mk(Yap_MkApplTerm(f.f, arity, (Term *)ts));
|
||||||
RECOVER_H();
|
RECOVER_H();
|
||||||
}
|
}
|
||||||
|
|
||||||
YAPApplTerm::YAPApplTerm(YAPFunctor f) : YAPTerm() {
|
YAPApplTerm::YAPApplTerm(YAPFunctor f) : YAPTerm() {
|
||||||
BACKUP_H();
|
BACKUP_H();
|
||||||
UInt arity = ArityOfFunctor(f.f);
|
UInt arity = ArityOfFunctor(f.f);
|
||||||
mk ( Yap_MkNewApplTerm( f.f, arity) );
|
mk(Yap_MkNewApplTerm(f.f, arity));
|
||||||
RECOVER_H();
|
RECOVER_H();
|
||||||
}
|
}
|
||||||
|
|
||||||
YAPTerm YAPApplTerm::getArg(int arg) {
|
YAPTerm YAPApplTerm::getArg(int arg) {
|
||||||
BACKUP_H();
|
BACKUP_H();
|
||||||
YAPTerm to = YAPTerm( ArgOfTerm(arg, gt() ) );
|
YAPTerm to = YAPTerm(ArgOfTerm(arg, gt()));
|
||||||
RECOVER_H();
|
RECOVER_H();
|
||||||
return to;
|
return to;
|
||||||
}
|
}
|
||||||
|
|
||||||
YAPFunctor YAPApplTerm::getFunctor() {
|
YAPFunctor YAPApplTerm::getFunctor() { return YAPFunctor(FunctorOfTerm(gt())); }
|
||||||
return YAPFunctor( FunctorOfTerm( gt( )) );
|
|
||||||
}
|
|
||||||
|
|
||||||
YAPPairTerm::YAPPairTerm(YAPTerm th, YAPTerm tl) : YAPTerm() {
|
YAPPairTerm::YAPPairTerm(YAPTerm th, YAPTerm tl) : YAPTerm() {
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
BACKUP_H();
|
BACKUP_H();
|
||||||
mk ( MkPairTerm( th.term(), tl.term() ) );
|
mk(MkPairTerm(th.term(), tl.term()));
|
||||||
RECOVER_H();
|
RECOVER_H();
|
||||||
}
|
}
|
||||||
|
|
||||||
YAPPairTerm::YAPPairTerm() : YAPTerm() {
|
YAPPairTerm::YAPPairTerm() : YAPTerm() {
|
||||||
BACKUP_H();
|
BACKUP_H();
|
||||||
t = Yap_MkNewPairTerm( );
|
t = Yap_MkNewPairTerm();
|
||||||
RECOVER_H();
|
RECOVER_H();
|
||||||
}
|
}
|
||||||
|
|
||||||
void YAPTerm::mk(Term t0) { CACHE_REGS t = Yap_InitSlot( t0 ); }
|
void YAPTerm::mk(Term t0) { CACHE_REGS t = Yap_InitSlot(t0); }
|
||||||
|
|
||||||
Term YAPTerm::gt() { CACHE_REGS return Yap_GetFromSlot( t ); }
|
Term YAPTerm::gt() { CACHE_REGS return Yap_GetFromSlot(t); }
|
||||||
|
|
||||||
YAP_tag_t YAPTerm::tag() {
|
YAP_tag_t YAPTerm::tag() {
|
||||||
Term tt = gt( );
|
Term tt = gt();
|
||||||
if (IsVarTerm(tt)) {
|
if (IsVarTerm(tt)) {
|
||||||
CELL *pt = VarOfTerm(tt);
|
CELL *pt = VarOfTerm(tt);
|
||||||
if (IsUnboundVar(pt)) {
|
if (IsUnboundVar(pt)) {
|
||||||
@ -235,10 +238,10 @@ YAPTerm YAPTerm::deepCopy() {
|
|||||||
Term tn;
|
Term tn;
|
||||||
BACKUP_MACHINE_REGS();
|
BACKUP_MACHINE_REGS();
|
||||||
|
|
||||||
tn = Yap_CopyTerm( gt() );
|
tn = Yap_CopyTerm(gt());
|
||||||
|
|
||||||
RECOVER_MACHINE_REGS();
|
RECOVER_MACHINE_REGS();
|
||||||
return new YAPTerm( tn );
|
return new YAPTerm(tn);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool YAPTerm::exactlyEqual(YAPTerm t1) {
|
bool YAPTerm::exactlyEqual(YAPTerm t1) {
|
||||||
@ -286,7 +289,7 @@ intptr_t YAPTerm::hashTerm(size_t sz, size_t depth, bool variant) {
|
|||||||
|
|
||||||
BACKUP_MACHINE_REGS();
|
BACKUP_MACHINE_REGS();
|
||||||
|
|
||||||
out = Yap_TermHash(gt(), sz, depth, variant) ;
|
out = Yap_TermHash(gt(), sz, depth, variant);
|
||||||
|
|
||||||
RECOVER_MACHINE_REGS();
|
RECOVER_MACHINE_REGS();
|
||||||
return out;
|
return out;
|
||||||
@ -299,23 +302,21 @@ const char *YAPTerm::text() {
|
|||||||
encoding_t enc = LOCAL_encoding;
|
encoding_t enc = LOCAL_encoding;
|
||||||
|
|
||||||
BACKUP_MACHINE_REGS();
|
BACKUP_MACHINE_REGS();
|
||||||
if (!(os = Yap_TermToString(Yap_GetFromSlot(t), os, sze, &length, &enc, 0))) { RECOVER_MACHINE_REGS();
|
if (!(os = Yap_TermToString(Yap_GetFromSlot(t), os, sze, &length, &enc, 0))) {
|
||||||
|
RECOVER_MACHINE_REGS();
|
||||||
return (char *)NULL;
|
return (char *)NULL;
|
||||||
}
|
}
|
||||||
RECOVER_MACHINE_REGS();
|
RECOVER_MACHINE_REGS();
|
||||||
return os;
|
return os;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *YAPQuery::text() {
|
const char *YAPQuery::text() { return goal.text(); }
|
||||||
|
|
||||||
return goal.text();
|
YAPIntegerTerm::YAPIntegerTerm(intptr_t i) {
|
||||||
|
CACHE_REGS Term tn = MkIntegerTerm(i);
|
||||||
|
mk(tn);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
YAPIntegerTerm::YAPIntegerTerm(intptr_t i) { CACHE_REGS Term tn = MkIntegerTerm( i ); mk( tn ); }
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
YAPTerm *YAPTerm::vars()
|
YAPTerm *YAPTerm::vars()
|
||||||
{
|
{
|
||||||
@ -329,18 +330,17 @@ YAPTerm *YAPTerm::vars()
|
|||||||
|
|
||||||
YAPTerm::YAPTerm(void *ptr) {
|
YAPTerm::YAPTerm(void *ptr) {
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
mk( MkIntegerTerm( (Int)ptr ) );
|
mk(MkIntegerTerm((Int)ptr));
|
||||||
}
|
}
|
||||||
|
|
||||||
YAPTerm::YAPTerm(intptr_t i) {
|
YAPTerm::YAPTerm(intptr_t i) {
|
||||||
CACHE_REGS Term tn = MkIntegerTerm( i );
|
CACHE_REGS Term tn = MkIntegerTerm(i);
|
||||||
mk( tn );
|
mk(tn);
|
||||||
}
|
}
|
||||||
|
|
||||||
YAPTerm YAPListTerm::car()
|
YAPTerm YAPListTerm::car() {
|
||||||
{
|
|
||||||
Term to = gt();
|
Term to = gt();
|
||||||
{ LOG( "to=%lx", to) ; }
|
{ LOG("to=%lx", to); }
|
||||||
if (IsPairTerm(to))
|
if (IsPairTerm(to))
|
||||||
return YAPTerm(HeadOfTerm(to));
|
return YAPTerm(HeadOfTerm(to));
|
||||||
else
|
else
|
||||||
@ -349,30 +349,29 @@ YAPTerm YAPListTerm::car()
|
|||||||
|
|
||||||
YAPVarTerm::YAPVarTerm() {
|
YAPVarTerm::YAPVarTerm() {
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
mk( MkVarTerm( ) );
|
mk(MkVarTerm());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
char *YAPAtom::getName(void) {
|
char *YAPAtom::getName(void) {
|
||||||
if (IsWideAtom(a)) {
|
if (IsWideAtom(a)) {
|
||||||
// return an UTF-8 version
|
// return an UTF-8 version
|
||||||
size_t sz = 512;
|
size_t sz = 512;
|
||||||
wchar_t * ptr = a->WStrOfAE;
|
wchar_t *ptr = a->WStrOfAE;
|
||||||
utf8proc_int32_t ch = -1;
|
utf8proc_int32_t ch = -1;
|
||||||
char *s = new char[sz], *op = s;
|
char *s = new char[sz], *op = s;
|
||||||
while (ch) {
|
while (ch) {
|
||||||
ch = *ptr++;
|
ch = *ptr++;
|
||||||
op += put_utf8( (unsigned char *)op, ch);
|
op += put_utf8((unsigned char *)op, ch);
|
||||||
}
|
}
|
||||||
sz = strlen(s)+1;
|
sz = strlen(s) + 1;
|
||||||
char *os = new char[sz];
|
char *os = new char[sz];
|
||||||
memcpy(os, s, sz);
|
memcpy(os, s, sz);
|
||||||
delete[] s;
|
delete[] s;
|
||||||
return os;
|
return os;
|
||||||
} else if (IsBlob(a)) {
|
} else if (IsBlob(a)) {
|
||||||
size_t sz = 1024;
|
size_t sz = 1024;
|
||||||
char *s = new char [sz+1];
|
char *s = new char[sz + 1];
|
||||||
return Yap_blob_to_string( RepAtom(a) , s, sz);
|
return Yap_blob_to_string(RepAtom(a), s, sz);
|
||||||
} else {
|
} else {
|
||||||
return (char *)a->StrOfAE;
|
return (char *)a->StrOfAE;
|
||||||
}
|
}
|
||||||
@ -382,36 +381,25 @@ void YAPQuery::initOpenQ() {
|
|||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
oq = LOCAL_execution;
|
oq = LOCAL_execution;
|
||||||
LOCAL_execution = this;
|
LOCAL_execution = this;
|
||||||
q_open=1;
|
q_open = 1;
|
||||||
q_state=0;
|
q_state = 0;
|
||||||
q_flags = true ; //PL_Q_PASS_EXCEPTION;
|
q_flags = true; // PL_Q_PASS_EXCEPTION;
|
||||||
|
|
||||||
q_p = P;
|
q_p = P;
|
||||||
q_cp = CP;
|
q_cp = CP;
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int YAPError::get() { return errNo; }
|
||||||
YAPError::get( )
|
|
||||||
{
|
|
||||||
return errNo;
|
|
||||||
}
|
|
||||||
|
|
||||||
const char *
|
const char *YAPError::text() { return "YAP Error"; }
|
||||||
YAPError::text()
|
|
||||||
{
|
|
||||||
return "YAP Error";
|
|
||||||
}
|
|
||||||
|
|
||||||
|
void YAPQuery::initQuery(Term t) {
|
||||||
void
|
|
||||||
YAPQuery::initQuery( Term t )
|
|
||||||
{
|
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
BACKUP_MACHINE_REGS();
|
BACKUP_MACHINE_REGS();
|
||||||
arity_t arity = ap->ArityOfPE;
|
arity_t arity = ap->ArityOfPE;
|
||||||
goal = YAPTerm( t );
|
goal = YAPTerm(t);
|
||||||
if (arity) {
|
if (arity) {
|
||||||
q_g = Yap_InitSlots( arity, RepAppl(t) + 1);
|
q_g = Yap_InitSlots(arity, RepAppl(t) + 1);
|
||||||
} else {
|
} else {
|
||||||
q_g = 0;
|
q_g = 0;
|
||||||
}
|
}
|
||||||
@ -419,69 +407,69 @@ YAPQuery::initQuery( Term t )
|
|||||||
RECOVER_MACHINE_REGS();
|
RECOVER_MACHINE_REGS();
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void YAPQuery::initQuery(YAPTerm ts[], arity_t arity) {
|
||||||
YAPQuery::initQuery( YAPTerm ts[], arity_t arity )
|
|
||||||
{
|
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
|
|
||||||
BACKUP_MACHINE_REGS();
|
BACKUP_MACHINE_REGS();
|
||||||
if (arity) {
|
if (arity) {
|
||||||
q_g = Yap_NewSlots( arity );
|
q_g = Yap_NewSlots(arity);
|
||||||
for (arity_t i=0; i < arity; i++) {
|
for (arity_t i = 0; i < arity; i++) {
|
||||||
Yap_PutInSlot(q_g+i, ts[i].term());
|
Yap_PutInSlot(q_g + i, ts[i].term());
|
||||||
}
|
}
|
||||||
Term t = Yap_MkApplTerm(ap->FunctorOfPred, ap->ArityOfPE, Yap_AddressFromSlot(q_g));
|
Term t = Yap_MkApplTerm(ap->FunctorOfPred, ap->ArityOfPE,
|
||||||
goal = YAPTerm( t );
|
Yap_AddressFromSlot(q_g));
|
||||||
|
goal = YAPTerm(t);
|
||||||
} else {
|
} else {
|
||||||
q_g = 0;
|
q_g = 0;
|
||||||
goal = YAPTerm( MkAtomTerm((Atom)ap->FunctorOfPred) );
|
goal = YAPTerm(MkAtomTerm((Atom)ap->FunctorOfPred));
|
||||||
}
|
}
|
||||||
initOpenQ();
|
initOpenQ();
|
||||||
RECOVER_MACHINE_REGS();
|
RECOVER_MACHINE_REGS();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
YAPQuery::YAPQuery(YAPFunctor f, YAPTerm mod, YAPTerm ts[])
|
||||||
YAPQuery::YAPQuery(YAPFunctor f, YAPTerm mod, YAPTerm ts[]): YAPPredicate(f, mod)
|
: YAPPredicate(f, mod) {
|
||||||
{
|
|
||||||
/* ignore flags for now */
|
/* ignore flags for now */
|
||||||
initQuery( ts , f.arity());
|
initQuery(ts, f.arity());
|
||||||
}
|
}
|
||||||
|
|
||||||
YAPQuery::YAPQuery(YAPFunctor f, YAPTerm ts[]): YAPPredicate(f)
|
YAPQuery::YAPQuery(YAPFunctor f, YAPTerm ts[]) : YAPPredicate(f) {
|
||||||
{
|
|
||||||
/* ignore flags for now */
|
/* ignore flags for now */
|
||||||
initQuery( ts , f.arity());
|
initQuery(ts, f.arity());
|
||||||
}
|
}
|
||||||
|
|
||||||
YAPQuery::YAPQuery(YAPPredicate p, YAPTerm ts[]): YAPPredicate(p.ap)
|
YAPQuery::YAPQuery(YAPPredicate p, YAPTerm ts[]) : YAPPredicate(p.ap) {
|
||||||
{
|
initQuery(ts, p.ap->ArityOfPE);
|
||||||
initQuery( ts , p.ap->ArityOfPE);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
YAPListTerm YAPQuery::namedVars() {
|
YAPListTerm YAPQuery::namedVars() {
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
Term o = vnames.term();
|
Term o = vnames.term();
|
||||||
Yap_DebugPlWrite(o); printf("<<<<<<<<<<<<<<<<-------------------------\n");
|
Yap_DebugPlWrite(o);
|
||||||
|
printf("<<<<<<<<<<<<<<<<-------------------------\n");
|
||||||
return o; // should be o
|
return o; // should be o
|
||||||
}
|
}
|
||||||
|
|
||||||
bool YAPQuery::next()
|
bool YAPQuery::next() {
|
||||||
{
|
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
int result;
|
int result;
|
||||||
|
|
||||||
Yap_DebugPlWrite(vnames.term()); fprintf(stderr,"++++++++++++++\n");
|
Yap_DebugPlWrite(vnames.term());
|
||||||
|
fprintf(stderr, "++++++++++++++\n");
|
||||||
|
|
||||||
BACKUP_MACHINE_REGS();
|
BACKUP_MACHINE_REGS();
|
||||||
if (q_open != 1) return false;
|
if (q_open != 1)
|
||||||
|
return false;
|
||||||
if (setjmp(q_env))
|
if (setjmp(q_env))
|
||||||
return false;
|
return false;
|
||||||
// don't forget, on success these guys must create slots
|
// don't forget, on success these guys must create slots
|
||||||
if (this->q_state == 0) {
|
if (this->q_state == 0) {
|
||||||
fprintf(stderr,"+++++ ap=%p +++++++++\n", ap);
|
fprintf(stderr, "+++++ ap=%p +++++++++\n", ap);
|
||||||
Yap_DebugPlWrite(Yap_GetFromSlot(q_g)); fprintf(stderr,"+++++ ap +++++++++\n");
|
Yap_DebugPlWrite(Yap_GetFromSlot(q_g));
|
||||||
result = (bool)YAP_EnterGoal((YAP_PredEntryPtr)ap, q_g, &q_h);
|
fprintf(stderr, "+++++ ap +++++++++\n");
|
||||||
Yap_DebugPlWrite(Yap_GetFromSlot(q_g)); fprintf(stderr,"+++++ ap=%d +++++++++\n", result);
|
result = (bool)YAP_EnterGoal((YAP_PredEntryPtr)ap, q_g, &q_h);
|
||||||
|
Yap_DebugPlWrite(Yap_GetFromSlot(q_g));
|
||||||
|
fprintf(stderr, "+++++ ap=%d +++++++++\n", result);
|
||||||
} else {
|
} else {
|
||||||
LOCAL_AllowRestart = q_open;
|
LOCAL_AllowRestart = q_open;
|
||||||
result = (bool)YAP_RetryGoal(&q_h);
|
result = (bool)YAP_RetryGoal(&q_h);
|
||||||
@ -495,20 +483,19 @@ result = (bool)YAP_EnterGoal((YAP_PredEntryPtr)ap, q_g, &q_h);
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void YAPQuery::cut()
|
void YAPQuery::cut() {
|
||||||
{
|
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
|
|
||||||
BACKUP_MACHINE_REGS();
|
BACKUP_MACHINE_REGS();
|
||||||
if (q_open != 1 || q_state == 0) return;
|
if (q_open != 1 || q_state == 0)
|
||||||
|
return;
|
||||||
YAP_LeaveGoal(FALSE, &q_h);
|
YAP_LeaveGoal(FALSE, &q_h);
|
||||||
q_open = 0;
|
q_open = 0;
|
||||||
LOCAL_execution = this;
|
LOCAL_execution = this;
|
||||||
RECOVER_MACHINE_REGS();
|
RECOVER_MACHINE_REGS();
|
||||||
}
|
}
|
||||||
|
|
||||||
void YAPQuery::close()
|
void YAPQuery::close() {
|
||||||
{
|
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
|
|
||||||
RECOVER_MACHINE_REGS();
|
RECOVER_MACHINE_REGS();
|
||||||
@ -533,73 +520,67 @@ static YAPEngine *curren;
|
|||||||
|
|
||||||
JNIEnv *Yap_jenv;
|
JNIEnv *Yap_jenv;
|
||||||
|
|
||||||
JNIEXPORT jint JNICALL JNI_OnLoad(JavaVM* vm, void* reserved) {
|
extern JNIEXPORT jint JNICALL JNI_MySQLOnLoad(JavaVM *vm, void *reserved);
|
||||||
JNIEnv* env;
|
|
||||||
if (vm->GetEnv(reinterpret_cast<void**>(&env), JNI_VERSION_1_6) != JNI_OK) {
|
JNIEXPORT jint JNICALL JNI_MySQLOnLoad(JavaVM *vm, void *reserved) {
|
||||||
|
JNIEnv *env;
|
||||||
|
if (vm->GetEnv(reinterpret_cast<void **>(&env), JNI_VERSION_1_6) != JNI_OK) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
Yap_jenv = env;
|
Yap_jenv = env;
|
||||||
|
|
||||||
return JNI_VERSION_1_6;
|
return JNI_VERSION_1_6;
|
||||||
}
|
}
|
||||||
|
|
||||||
extern char *Yap_AndroidBufp;
|
char *Yap_AndroidBufp;
|
||||||
|
|
||||||
static size_t Yap_AndroidMax, Yap_AndroidSz;
|
static size_t Yap_AndroidMax, Yap_AndroidSz;
|
||||||
|
|
||||||
extern void(*Yap_DisplayWithJava)(int c);
|
extern void (*Yap_DisplayWithJava)(int c);
|
||||||
|
|
||||||
static void
|
void Yap_displayWithJava(int c) {
|
||||||
displayWithJava(int c)
|
|
||||||
{
|
|
||||||
char *ptr = Yap_AndroidBufp;
|
char *ptr = Yap_AndroidBufp;
|
||||||
ptr[ Yap_AndroidSz++ ] = c;
|
if (!ptr)
|
||||||
if (Yap_AndroidMax-1 == Yap_AndroidSz) {
|
ptr = Yap_AndroidBufp = (char *)malloc(Yap_AndroidSz);
|
||||||
if (Yap_AndroidMax < 32*1024) {
|
ptr[Yap_AndroidSz++] = c;
|
||||||
|
if (Yap_AndroidMax - 1 == Yap_AndroidSz) {
|
||||||
|
if (Yap_AndroidMax < 32 * 1024) {
|
||||||
Yap_AndroidMax *= 2;
|
Yap_AndroidMax *= 2;
|
||||||
} else {
|
} else {
|
||||||
Yap_AndroidMax += 32*1024;
|
Yap_AndroidMax += 32 * 1024;
|
||||||
}
|
}
|
||||||
Yap_AndroidBufp = (char *)realloc( ptr, Yap_AndroidMax);
|
Yap_AndroidBufp = (char *)realloc(ptr, Yap_AndroidMax);
|
||||||
}
|
}
|
||||||
Yap_AndroidBufp[Yap_AndroidSz] = '\0';
|
Yap_AndroidBufp[Yap_AndroidSz] = '\0';
|
||||||
if (c == '\n' ) {
|
if (c == '\n') {
|
||||||
Yap_AndroidBufp[Yap_AndroidSz] = '\0';
|
Yap_AndroidBufp[Yap_AndroidSz] = '\0';
|
||||||
curren->run(Yap_AndroidBufp);
|
curren->run(Yap_AndroidBufp);
|
||||||
Yap_AndroidSz = 0;
|
Yap_AndroidSz = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" void Java_pt_up_fc_dcc_yap_JavaYap_load(JNIEnv *env0, jobject obj, jobject mgr);
|
extern "C" void Java_pt_up_fc_dcc_yap_JavaYap_load(JNIEnv *env0, jobject obj,
|
||||||
|
jobject mgr);
|
||||||
|
|
||||||
extern "C" void Java_pt_up_fc_dcc_yap_JavaYap_load
|
extern "C" void Java_pt_up_fc_dcc_yap_JavaYap_load(JNIEnv *env0, jobject obj,
|
||||||
(JNIEnv *env0, jobject obj, jobject asset_manager)
|
jobject asset_manager) {
|
||||||
{
|
|
||||||
AAssetManager *mgr = AAssetManager_fromJava(Yap_jenv, asset_manager);
|
AAssetManager *mgr = AAssetManager_fromJava(Yap_jenv, asset_manager);
|
||||||
if (mgr == NULL) {
|
if (mgr == NULL) {
|
||||||
LOG( "we're doomed, mgr = 0; bip bip bip");
|
LOG("we're doomed, mgr = 0; bip bip bip");
|
||||||
} else {
|
} else {
|
||||||
Yap_assetManager = mgr;
|
Yap_assetManager = mgr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
YAPEngine::YAPEngine(char *savedState, size_t stackSize, size_t trailSize,
|
||||||
YAPEngine::YAPEngine( char *savedState,
|
size_t maxStackSize, size_t maxTrailSize, char *libDir,
|
||||||
size_t stackSize,
|
char *bootFile, char *goal, char *topLevel, bool script,
|
||||||
size_t trailSize,
|
|
||||||
size_t maxStackSize,
|
|
||||||
size_t maxTrailSize,
|
|
||||||
char *libDir,
|
|
||||||
char *bootFile,
|
|
||||||
char *goal,
|
|
||||||
char *topLevel,
|
|
||||||
bool script,
|
|
||||||
bool fastBoot,
|
bool fastBoot,
|
||||||
YAPCallback *cb): _callback(0)
|
YAPCallback *cb)
|
||||||
{ // a single engine can be active
|
: _callback(0) { // a single engine can be active
|
||||||
#if __ANDROID__
|
#if __ANDROID__
|
||||||
Yap_DisplayWithJava = displayWithJava;
|
|
||||||
Yap_AndroidBufp = (char *)malloc(Yap_AndroidMax = 4096);
|
Yap_AndroidBufp = (char *)malloc(Yap_AndroidMax = 4096);
|
||||||
Yap_AndroidBufp[0] = '\0';
|
Yap_AndroidBufp[0] = '\0';
|
||||||
Yap_AndroidSz = 0;
|
Yap_AndroidSz = 0;
|
||||||
@ -618,32 +599,32 @@ YAPEngine::YAPEngine( char *savedState,
|
|||||||
init_args.FastBoot = fastBoot;
|
init_args.FastBoot = fastBoot;
|
||||||
yerror = YAPError();
|
yerror = YAPError();
|
||||||
delYAPCallback();
|
delYAPCallback();
|
||||||
if (cb) setYAPCallback(cb);
|
if (cb)
|
||||||
|
setYAPCallback(cb);
|
||||||
curren = this;
|
curren = this;
|
||||||
if (YAP_Init( &init_args ) == YAP_BOOT_ERROR)
|
if (YAP_Init(&init_args) == YAP_BOOT_ERROR)
|
||||||
throw(YAPError(SYSTEM_ERROR_INTERNAL));
|
throw(YAPError(SYSTEM_ERROR_INTERNAL));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
YAPPredicate::YAPPredicate(YAPAtom at) {
|
YAPPredicate::YAPPredicate(YAPAtom at) {
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
ap = RepPredProp(PredPropByAtom(at.a,Yap_CurrentModule()));
|
ap = RepPredProp(PredPropByAtom(at.a, Yap_CurrentModule()));
|
||||||
}
|
}
|
||||||
|
|
||||||
YAPPredicate::YAPPredicate(YAPAtom at, arity_t arity) {
|
YAPPredicate::YAPPredicate(YAPAtom at, arity_t arity) {
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
if (arity) {
|
if (arity) {
|
||||||
Functor f = Yap_MkFunctor(at.a, arity);
|
Functor f = Yap_MkFunctor(at.a, arity);
|
||||||
ap = RepPredProp(PredPropByFunc(f,Yap_CurrentModule()));
|
ap = RepPredProp(PredPropByFunc(f, Yap_CurrentModule()));
|
||||||
} else {
|
} else {
|
||||||
ap = RepPredProp(PredPropByAtom(at.a,Yap_CurrentModule()));
|
ap = RepPredProp(PredPropByAtom(at.a, Yap_CurrentModule()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// auxiliary routine to find a predicate in the current module.
|
/// auxiliary routine to find a predicate in the current module.
|
||||||
PredEntry *YAPPredicate::getPred( Term &t, Term* &outp ) {
|
PredEntry *YAPPredicate::getPred(Term &t, Term *&outp) {
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
Term m = Yap_CurrentModule() ;
|
Term m = Yap_CurrentModule();
|
||||||
t = Yap_StripModule(t, &m);
|
t = Yap_StripModule(t, &m);
|
||||||
if (IsVarTerm(t) || IsNumTerm(t)) {
|
if (IsVarTerm(t) || IsNumTerm(t)) {
|
||||||
throw YAPError(TYPE_ERROR_NUMBER);
|
throw YAPError(TYPE_ERROR_NUMBER);
|
||||||
@ -663,34 +644,24 @@ PredEntry *YAPPredicate::getPred( Term &t, Term* &outp ) {
|
|||||||
throw YAPError(TYPE_ERROR_NUMBER);
|
throw YAPError(TYPE_ERROR_NUMBER);
|
||||||
} else {
|
} else {
|
||||||
ap = RepPredProp(PredPropByFunc(f, m));
|
ap = RepPredProp(PredPropByFunc(f, m));
|
||||||
outp = RepAppl(t)+1;
|
outp = RepAppl(t) + 1;
|
||||||
}
|
}
|
||||||
return ap;
|
return ap;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
YAPPrologPredicate::YAPPrologPredicate(
|
||||||
YAPPrologPredicate::YAPPrologPredicate(YAPAtom name,
|
YAPAtom name, arity_t arity, YAPModule mod, bool tabled,
|
||||||
arity_t arity,
|
bool logical_updates, bool is_thread_local, bool sourced,
|
||||||
YAPModule mod,
|
bool discontiguous, bool multiFile, bool hidden, bool untraceable,
|
||||||
bool tabled,
|
bool unspyable, bool meta, bool moduleTransparent, bool quasiQuotable,
|
||||||
bool logical_updates,
|
size_t mega_clause)
|
||||||
bool is_thread_local,
|
: YAPPredicate(name, arity, mod) {
|
||||||
bool sourced,
|
if (!ap)
|
||||||
bool discontiguous,
|
return;
|
||||||
bool multiFile,
|
|
||||||
bool hidden,
|
|
||||||
bool untraceable,
|
|
||||||
bool unspyable,
|
|
||||||
bool meta,
|
|
||||||
bool moduleTransparent,
|
|
||||||
bool quasiQuotable,
|
|
||||||
size_t mega_clause
|
|
||||||
) : YAPPredicate(name, arity, mod) {
|
|
||||||
if (!ap) return;
|
|
||||||
if (is_thread_local) {
|
if (is_thread_local) {
|
||||||
if (ap->cs.p_code.NOfClauses || tabled)
|
if (ap->cs.p_code.NOfClauses || tabled)
|
||||||
return;
|
return;
|
||||||
ap->PredFlags |= (ThreadLocalPredFlag|LogUpdatePredFlag);
|
ap->PredFlags |= (ThreadLocalPredFlag | LogUpdatePredFlag);
|
||||||
} else if (logical_updates) {
|
} else if (logical_updates) {
|
||||||
if (ap->cs.p_code.NOfClauses || tabled)
|
if (ap->cs.p_code.NOfClauses || tabled)
|
||||||
return;
|
return;
|
||||||
@ -738,13 +709,15 @@ YAPPrologPredicate::YAPPrologPredicate(YAPAtom name,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void *YAPPrologPredicate::assertClause( YAPTerm clause, bool last, YAPTerm source) {
|
void *YAPPrologPredicate::assertClause(YAPTerm clause, bool last,
|
||||||
|
YAPTerm source) {
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
|
|
||||||
RECOVER_MACHINE_REGS();
|
RECOVER_MACHINE_REGS();
|
||||||
Term tt = clause.gt();
|
Term tt = clause.gt();
|
||||||
Term sourcet = source.gt();
|
Term sourcet = source.gt();
|
||||||
yamop *codeaddr = Yap_cclause(tt, PP->ArityOfPE, Yap_CurrentModule(), sourcet); /* vsc: give the number of arguments
|
yamop *codeaddr = Yap_cclause(tt, PP->ArityOfPE, Yap_CurrentModule(),
|
||||||
|
sourcet); /* vsc: give the number of arguments
|
||||||
to cclause in case there is overflow */
|
to cclause in case there is overflow */
|
||||||
Term ntt = clause.gt();
|
Term ntt = clause.gt();
|
||||||
if (LOCAL_ErrorMessage) {
|
if (LOCAL_ErrorMessage) {
|
||||||
@ -752,15 +725,14 @@ void *YAPPrologPredicate::assertClause( YAPTerm clause, bool last, YAPTerm sourc
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
Term *tref = &ntt;
|
Term *tref = &ntt;
|
||||||
if (Yap_addclause(ntt, codeaddr, (last ? TermAssertz : TermAsserta), Yap_CurrentModule(), tref)) {
|
if (Yap_addclause(ntt, codeaddr, (last ? TermAssertz : TermAsserta),
|
||||||
|
Yap_CurrentModule(), tref)) {
|
||||||
RECOVER_MACHINE_REGS();
|
RECOVER_MACHINE_REGS();
|
||||||
}
|
}
|
||||||
return tref;
|
return tref;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
void* YAPPrologPredicate::retractClause( YAPTerm skeleton, bool all) {
|
void *YAPPrologPredicate::retractClause(YAPTerm skeleton, bool all) {
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
void* YAPPrologPredicate::clause( YAPTerm skeleton, YAPTerm &body ) {
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
void *YAPPrologPredicate::clause(YAPTerm skeleton, YAPTerm &body) { return 0; }
|
||||||
|
Reference in New Issue
Block a user