Merge ssh://ssh.dcc.fc.up.pt:31064/home/vsc/yap
This commit is contained in:
1
C/init.c
1
C/init.c
@@ -984,6 +984,7 @@ void Yap_InitCPredBack_(const char *Name, arity_t Arity, arity_t Extra,
|
|||||||
|
|
||||||
static void InitStdPreds(struct yap_boot_params *yapi)
|
static void InitStdPreds(struct yap_boot_params *yapi)
|
||||||
{
|
{
|
||||||
|
CurrentModule = PROLOG_MODULE;
|
||||||
Yap_InitCPreds();
|
Yap_InitCPreds();
|
||||||
Yap_InitBackCPreds();
|
Yap_InitBackCPreds();
|
||||||
BACKUP_MACHINE_REGS();
|
BACKUP_MACHINE_REGS();
|
||||||
|
2
C/text.c
2
C/text.c
@@ -557,10 +557,8 @@ unsigned char *Yap_readText(seq_tv_t *inp USES_REGS) {
|
|||||||
POPRET( (char*)latin2utf8(inp));
|
POPRET( (char*)latin2utf8(inp));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (inp->enc == ENC_ISO_UTF8) {
|
|
||||||
pop_text_stack(lvl);
|
pop_text_stack(lvl);
|
||||||
return inp->val.c;
|
return inp->val.c;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (inp->type & YAP_STRING_WCHARS) {
|
if (inp->type & YAP_STRING_WCHARS) {
|
||||||
// printf("%S\n",inp->val.w);
|
// printf("%S\n",inp->val.w);
|
||||||
|
77
CXX/yapi.cpp
77
CXX/yapi.cpp
@@ -125,6 +125,7 @@ YAPAtomTerm::YAPAtomTerm(char s[]) { // build string
|
|||||||
|
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
seq_tv_t inp, out;
|
seq_tv_t inp, out;
|
||||||
|
inp.enc = LOCAL_encoding;
|
||||||
inp.val.c = s;
|
inp.val.c = s;
|
||||||
inp.type = YAP_STRING_CHARS;
|
inp.type = YAP_STRING_CHARS;
|
||||||
out.type = YAP_STRING_ATOM;
|
out.type = YAP_STRING_ATOM;
|
||||||
@@ -142,7 +143,8 @@ 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;
|
inp.enc = LOCAL_encoding;
|
||||||
|
out.type = YAP_STRING_ATOM | YAP_STRING_NCHARS | YAP_STRING_TRUNC;
|
||||||
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));
|
||||||
@@ -253,15 +255,78 @@ YAPApplTerm::YAPApplTerm(YAPFunctor f, YAPTerm ts[]) {
|
|||||||
RECOVER_H();
|
RECOVER_H();
|
||||||
}
|
}
|
||||||
|
|
||||||
YAPApplTerm::YAPApplTerm(std::string f, std::vector<YAPTerm> ts) {
|
YAPApplTerm::YAPApplTerm(const std::string f, std::vector<Term> ts) {
|
||||||
|
BACKUP_H();
|
||||||
|
arity_t arity = ts.size();
|
||||||
|
Functor ff = Yap_MkFunctor(Yap_LookupAtom(f.c_str()), arity);
|
||||||
|
Term o = Yap_MkNewApplTerm(ff, arity);
|
||||||
|
Term *tt = RepAppl(o) + 1;
|
||||||
|
for (arity_t i = 0; i < arity; i++)
|
||||||
|
tt[i] = ts[i];
|
||||||
|
mk(o);
|
||||||
|
RECOVER_H();
|
||||||
|
}
|
||||||
|
|
||||||
|
YAPApplTerm::YAPApplTerm(const std::string f, std::vector<YAPTerm> ts) {
|
||||||
|
BACKUP_H();
|
||||||
|
arity_t arity = ts.size();
|
||||||
|
Functor ff = Yap_MkFunctor(Yap_LookupAtom(f.c_str()), arity);
|
||||||
|
Term o = Yap_MkNewApplTerm(ff, arity);
|
||||||
|
Term *tt = RepAppl(o) + 1;
|
||||||
|
for (arity_t i = 0; i < arity; i++)
|
||||||
|
tt[i] = ts[i].term();
|
||||||
|
mk(o);
|
||||||
|
RECOVER_H();
|
||||||
|
}
|
||||||
|
|
||||||
|
YAPApplTerm::YAPApplTerm(const std::string f, YAPTerm a1) {
|
||||||
BACKUP_H();
|
BACKUP_H();
|
||||||
arity_t arity = ts.size();
|
arity_t arity = 1;
|
||||||
Functor ff = Yap_MkFunctor(Yap_LookupAtom(f.c_str()), arity);
|
Functor ff = Yap_MkFunctor(Yap_LookupAtom(f.c_str()), arity);
|
||||||
Term o = Yap_MkNewApplTerm(ff, arity);
|
Term o = Yap_MkNewApplTerm(ff, arity);
|
||||||
Term *tt = RepAppl(o) + 1;
|
Term *tt = RepAppl(o) + 1;
|
||||||
for (arity_t i = 0; i < arity; i++)
|
tt[0] = a1.term();
|
||||||
tt[i] = ts[i].term();
|
|
||||||
mk(o);
|
mk(o);
|
||||||
|
RECOVER_H();
|
||||||
|
}
|
||||||
|
|
||||||
|
YAPApplTerm::YAPApplTerm(const std::string f, YAPTerm a1, YAPTerm a2) {
|
||||||
|
BACKUP_H();
|
||||||
|
arity_t arity = 2;
|
||||||
|
Functor ff = Yap_MkFunctor(Yap_LookupAtom(f.c_str()), arity);
|
||||||
|
Term o = Yap_MkNewApplTerm(ff, arity);
|
||||||
|
Term *tt = RepAppl(o) + 1;
|
||||||
|
tt[0] = a1.term();
|
||||||
|
tt[1] = a2.term();
|
||||||
|
mk(o);
|
||||||
|
RECOVER_H();
|
||||||
|
}
|
||||||
|
|
||||||
|
YAPApplTerm::YAPApplTerm(const std::string f, YAPTerm a1, YAPTerm a2, YAPTerm a3) {
|
||||||
|
BACKUP_H();
|
||||||
|
arity_t arity = 3;
|
||||||
|
Functor ff = Yap_MkFunctor(Yap_LookupAtom(f.c_str()), arity);
|
||||||
|
Term o = Yap_MkNewApplTerm(ff, arity);
|
||||||
|
Term *tt = RepAppl(o) + 1;
|
||||||
|
tt[0] = a1.term();
|
||||||
|
tt[2] = a2.term();
|
||||||
|
tt[3] = a3.term();
|
||||||
|
mk(o);
|
||||||
|
RECOVER_H();
|
||||||
|
}
|
||||||
|
|
||||||
|
YAPApplTerm::YAPApplTerm(const std::string f, YAPTerm a1, YAPTerm a2, YAPTerm a3, YAPTerm a4) {
|
||||||
|
BACKUP_H();
|
||||||
|
arity_t arity = 4;
|
||||||
|
Functor ff = Yap_MkFunctor(Yap_LookupAtom(f.c_str()), arity);
|
||||||
|
Term o = Yap_MkNewApplTerm(ff, arity);
|
||||||
|
Term *tt = RepAppl(o) + 1;
|
||||||
|
tt[0] = a1.term();
|
||||||
|
tt[2] = a2.term();
|
||||||
|
tt[3] = a3.term();
|
||||||
|
tt[4] = a4.term();
|
||||||
|
mk(o);
|
||||||
|
RECOVER_H();
|
||||||
}
|
}
|
||||||
|
|
||||||
YAPApplTerm::YAPApplTerm(YAPFunctor f) : YAPTerm() {
|
YAPApplTerm::YAPApplTerm(YAPFunctor f) : YAPTerm() {
|
||||||
@@ -525,7 +590,7 @@ bool YAPEngine::mgoal(Term t, Term tmod, bool release) {
|
|||||||
#endif
|
#endif
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
BACKUP_MACHINE_REGS();
|
BACKUP_MACHINE_REGS();
|
||||||
Term *ts = nullptr;
|
Term *ts = nullptr;
|
||||||
q.CurSlot = Yap_StartSlots();
|
q.CurSlot = Yap_StartSlots();
|
||||||
q.p = P;
|
q.p = P;
|
||||||
q.cp = CP;
|
q.cp = CP;
|
||||||
|
13
CXX/yapt.hh
13
CXX/yapt.hh
@@ -295,8 +295,8 @@ class X_API YAPApplTerm : public YAPTerm {
|
|||||||
friend class YAPTerm;
|
friend class YAPTerm;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
YAPApplTerm(Term t0) { mk(t0); }
|
YAPApplTerm(Term t0) { mk(t0); }
|
||||||
YAPApplTerm(Functor f, Term ts[]) {
|
YAPApplTerm(Functor f, Term ts[]) {
|
||||||
BACKUP_MACHINE_REGS();
|
BACKUP_MACHINE_REGS();
|
||||||
Term t0 = Yap_MkApplTerm(f, f->ArityOfFE, ts);
|
Term t0 = Yap_MkApplTerm(f, f->ArityOfFE, ts);
|
||||||
mk(t0);
|
mk(t0);
|
||||||
@@ -307,12 +307,17 @@ public:
|
|||||||
mk(Yap_MkNewApplTerm(Yap_MkFunctor(Yap_LookupAtom(s.c_str()), arity),
|
mk(Yap_MkNewApplTerm(Yap_MkFunctor(Yap_LookupAtom(s.c_str()), arity),
|
||||||
arity));
|
arity));
|
||||||
};
|
};
|
||||||
YAPApplTerm(const std::string s, std::vector<YAPTerm> ts);
|
YAPApplTerm(const std::string s, std::vector<Term> ts);
|
||||||
|
YAPApplTerm(const std::string s, std::vector<YAPTerm> ts);
|
||||||
YAPApplTerm(YAPFunctor f);
|
YAPApplTerm(YAPFunctor f);
|
||||||
inline Functor functor() { return FunctorOfTerm(gt()); }
|
inline Functor functor() { return FunctorOfTerm(gt()); }
|
||||||
inline YAPFunctor getFunctor() { return YAPFunctor(FunctorOfTerm(gt())); }
|
inline YAPFunctor getFunctor() { return YAPFunctor(FunctorOfTerm(gt())); }
|
||||||
|
YAPApplTerm(const std::string f, YAPTerm a1);
|
||||||
|
YAPApplTerm(const std::string f, YAPTerm a1, YAPTerm a2);
|
||||||
|
YAPApplTerm(const std::string f, YAPTerm a1, YAPTerm a2, YAPTerm a3);
|
||||||
|
YAPApplTerm(const std::string f, YAPTerm a1, YAPTerm a2, YAPTerm a3, YAPTerm a4);
|
||||||
|
|
||||||
Term getArg(arity_t i) {
|
Term getArg(arity_t i) {
|
||||||
BACKUP_MACHINE_REGS();
|
BACKUP_MACHINE_REGS();
|
||||||
Term t0 = gt();
|
Term t0 = gt();
|
||||||
Term tf;
|
Term tf;
|
||||||
|
@@ -1,7 +1,11 @@
|
|||||||
site_name: 'YAP'
|
site_name: 'YAP'
|
||||||
theme: 'readthedocs'
|
theme: 'readthedocs'
|
||||||
markdown_extensions:
|
markdown_extensions:
|
||||||
use_directory_urls: false
|
- smarty
|
||||||
|
- toc:
|
||||||
|
permalink: True
|
||||||
|
- sane_lists
|
||||||
|
use_directory_urls: false
|
||||||
plugins:
|
plugins:
|
||||||
- search
|
- search
|
||||||
- awesome-pages:
|
- awesome-pages:
|
||||||
|
@@ -835,11 +835,6 @@ static parser_state_t initParser(Term opts, FEnv *fe, REnv *re, int inp_stream,
|
|||||||
LOCAL_ErrorMessage = NULL;
|
LOCAL_ErrorMessage = NULL;
|
||||||
fe->old_TR = TR;
|
fe->old_TR = TR;
|
||||||
LOCAL_Error_TYPE = YAP_NO_ERROR;
|
LOCAL_Error_TYPE = YAP_NO_ERROR;
|
||||||
__android_log_print(ANDROID_LOG_INFO, "YAPDroid ", " open %s, %d",
|
|
||||||
CurrentModule == 0
|
|
||||||
? "prolog"
|
|
||||||
: RepAtom(AtomOfTerm(CurrentModule))->StrOfAE,
|
|
||||||
inp_stream);
|
|
||||||
LOCAL_SourceFileName = GLOBAL_Stream[inp_stream].name;
|
LOCAL_SourceFileName = GLOBAL_Stream[inp_stream].name;
|
||||||
LOCAL_eot_before_eof = false;
|
LOCAL_eot_before_eof = false;
|
||||||
fe->tpos = StreamPosition(inp_stream);
|
fe->tpos = StreamPosition(inp_stream);
|
||||||
|
@@ -1551,11 +1551,7 @@ FILE *Yap_FileDescriptorFromStream(Term t) {
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void Yap_InitBackIO(void)
|
||||||
|
|
||||||
Yap_InitBackIO (
|
|
||||||
|
|
||||||
void)
|
|
||||||
{
|
{
|
||||||
Yap_InitCPredBack("stream_property", 2, 2, stream_property,
|
Yap_InitCPredBack("stream_property", 2, 2, stream_property,
|
||||||
cont_stream_property, SafePredFlag | SyncPredFlag);
|
cont_stream_property, SafePredFlag | SyncPredFlag);
|
||||||
|
@@ -15,12 +15,15 @@
|
|||||||
* *
|
* *
|
||||||
*************************************************************************/
|
*************************************************************************/
|
||||||
#include "Yap.h"
|
#include "Yap.h"
|
||||||
#ifdef USE_MYDDAS
|
|
||||||
|
|
||||||
#include "Yatom.h"
|
#include "Yatom.h"
|
||||||
#include "cut_c.h"
|
|
||||||
#include "myddas.h"
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef USE_MYDDAS
|
||||||
|
|
||||||
|
#include "myddas.h"
|
||||||
|
|
||||||
#ifdef MYDDAS_STATS
|
#ifdef MYDDAS_STATS
|
||||||
#include "myddas_statistics.h"
|
#include "myddas_statistics.h"
|
||||||
#endif
|
#endif
|
||||||
@@ -678,30 +681,17 @@ void Yap_MYDDAS_delete_all_myddas_structs(void) {
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
void init_myddas(void) {
|
void init_myddas(void) {
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
|
if (myddas_initialised)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#if USE_MYDDAS
|
||||||
Term cm=CurrentModule;
|
Term cm=CurrentModule;
|
||||||
CurrentModule = USER_MODULE;
|
CurrentModule = USER_MODULE;
|
||||||
if (myddas_initialised)
|
|
||||||
return;
|
|
||||||
#ifdef __ANDROID__
|
|
||||||
init_sqlite3();
|
|
||||||
#endif
|
|
||||||
#if defined MYDDAS_ODBC
|
|
||||||
Yap_InitBackMYDDAS_ODBCPreds();
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
#if defined MYDDAS_ODBC
|
|
||||||
Yap_InitMYDDAS_ODBCPreds();
|
|
||||||
#endif
|
|
||||||
#if defined USE_MYDDAS
|
|
||||||
Yap_InitMYDDAS_SharedPreds();
|
|
||||||
#endif
|
|
||||||
#if defined MYDDAS_TOP_LEVEL && \
|
|
||||||
defined MYDDAS_MYSQL // && defined HAVE_LIBREADLINE
|
|
||||||
Yap_InitMYDDAS_TopLevelPreds();
|
|
||||||
#endif
|
|
||||||
#if USE_MYDDAS
|
|
||||||
#define stringify(X) _stringify(X)
|
#define stringify(X) _stringify(X)
|
||||||
#define _stringify(X) #X
|
#define _stringify(X) #X
|
||||||
Yap_REGS.MYDDAS_GLOBAL_POINTER = NULL;
|
Yap_REGS.MYDDAS_GLOBAL_POINTER = NULL;
|
||||||
@@ -709,12 +699,25 @@ void init_myddas(void) {
|
|||||||
MkAtomTerm(Yap_LookupAtom(stringify(MYDDAS_VERSION))));
|
MkAtomTerm(Yap_LookupAtom(stringify(MYDDAS_VERSION))));
|
||||||
Yap_HaltRegisterHook((HaltHookFunc)Yap_MYDDAS_delete_all_myddas_structs,
|
Yap_HaltRegisterHook((HaltHookFunc)Yap_MYDDAS_delete_all_myddas_structs,
|
||||||
NULL);
|
NULL);
|
||||||
|
Yap_InitMYDDAS_SharedPreds();
|
||||||
|
Yap_InitBackMYDDAS_SharedPreds();
|
||||||
#undef stringify
|
#undef stringify
|
||||||
#undef _stringify
|
#undef _stringify
|
||||||
Yap_MYDDAS_delete_all_myddas_structs();
|
Yap_MYDDAS_delete_all_myddas_structs();
|
||||||
|
#if defined MYDDAS_ODBC
|
||||||
|
Yap_InitBackMYDDAS_ODBCPreds();
|
||||||
|
Yap_InitMYDDAS_ODBCPreds();
|
||||||
|
#endif
|
||||||
|
#if defined MYDDAS_TOP_LEVEL && \
|
||||||
|
defined MYDDAS_MYSQL // && defined HAVE_LIBREADLINE
|
||||||
|
Yap_InitMYDDAS_TopLevelPreds();
|
||||||
#endif
|
#endif
|
||||||
c_db_initialize_myddas(PASS_REGS1);
|
c_db_initialize_myddas(PASS_REGS1);
|
||||||
myddas_initialised = TRUE;
|
#ifdef __ANDROID__
|
||||||
|
init_sqlite3();
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
myddas_initialised = true;
|
||||||
CurrentModule = cm;
|
CurrentModule = cm;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -22,6 +22,7 @@
|
|||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
:- yap_flag(single_var_warnings,on).
|
:- yap_flag(single_var_warnings,on).
|
||||||
|
:- yap_flag(write_strings,on).
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define SWITCH(Contype, G) \
|
#define SWITCH(Contype, G) \
|
||||||
@@ -181,7 +182,7 @@
|
|||||||
member/2
|
member/2
|
||||||
]).
|
]).
|
||||||
|
|
||||||
:- set(verbose,silent).
|
:- set_prolog_flag(verbose,silent).
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -230,108 +231,108 @@ db_open(postgres,Connection,Host/Db/Port,User,Password) :-
|
|||||||
integer(Port),!,
|
integer(Port),!,
|
||||||
db_open(postgres,Connection,Host/Db/Port/_,User,Password). % Var to be NULL, the default socket
|
db_open(postgres,Connection,Host/Db/Port/_,User,Password). % Var to be NULL, the default socket
|
||||||
db_open(postgres,Connection,Host/Db/Socket,User,Password) :- !,
|
db_open(postgres,Connection,Host/Db/Socket,User,Password) :- !,
|
||||||
db_open(postgres,Connection,Host/Db/0/Socket,User,Password). % 0 is default port
|
db_open(postgres,Connection,Host/Db/0/Socket,User,Password). % 0 is default port
|
||||||
db_open(postgres,Connection,Host/Db,User,Password) :-
|
db_open(postgres,Connection,Host/Db,User,Password) :-
|
||||||
db_open(postgres,Connection,Host/Db/0/_,User,Password). % 0 is default port and Var to be NULL, the default socpket
|
db_open(postgres,Connection,Host/Db/0/_,User,Password). % 0 is default port and Var to be NULL, the default socpket
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef MYDDAS_ODBC
|
#ifdef MYDDAS_ODBC
|
||||||
db_open(odbc,Connection,ODBCEntry,User,Password) :-
|
db_open(odbc,Connection,ODBCEntry,User,Password) :-
|
||||||
'$error_checks'(db_open(odbc,Connection,ODBCEntry,User,Password)),
|
'$error_checks'(db_open(odbc,Connection,ODBCEntry,User,Password)),
|
||||||
c_odbc_connect(ODBCEntry,User,Password,Con),
|
c_odbc_connect(ODBCEntry,User,Password,Con),
|
||||||
set_value(Connection,Con).
|
set_value(Connection,Con).
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
%% sqlite3
|
%% sqlite3
|
||||||
db_open(sqlite3,Connection,File,User,Password) :-
|
db_open(sqlite3,Connection,File,User,Password) :-
|
||||||
'$error_checks'(db_open(sqlite3,Connection,File,User,Password)),
|
'$error_checks'(db_open(sqlite3,Connection,File,User,Password)),
|
||||||
c_sqlite3_connect(File,User,Password,Con),
|
c_sqlite3_connect(File,User,Password,Con),
|
||||||
set_value(Connection,Con).
|
set_value(Connection,Con).
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
|
|
||||||
|
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
%% db_close/1
|
%% db_close/1
|
||||||
%% db_close/0
|
%% db_close/0
|
||||||
%
|
%
|
||||||
% close a connection _Con_: all its resources are returned, and all undefined
|
% close a connection _Con_: all its resources are returned, and all undefined
|
||||||
% predicates are abolished. Default is to close `myddas`.
|
% predicates are abolished. Default is to close `myddas`.
|
||||||
db_close:-
|
db_close:-
|
||||||
db_close(myddas).
|
db_close(myddas).
|
||||||
db_close(Protocol):-
|
db_close(Protocol):-
|
||||||
'$error_checks'(db_close(Protocol)),
|
'$error_checks'(db_close(Protocol)),
|
||||||
get_value(Protocol,Con),
|
get_value(Protocol,Con),
|
||||||
c_db_connection_type(Con,ConType),
|
c_db_connection_type(Con,ConType),
|
||||||
( '$abolish_all'(Con) ;
|
( '$abolish_all'(Con) ;
|
||||||
set_value(Protocol,[]), % "deletes" atom
|
set_value(Protocol,[]), % "deletes" atom
|
||||||
C_SWITCH( ConType, disconnect(Con) )
|
C_SWITCH( ConType, disconnect(Con) )
|
||||||
).
|
).
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
% db_verbose/1
|
% db_verbose/1
|
||||||
%
|
%
|
||||||
%
|
%
|
||||||
db_verbose(X):-
|
db_verbose(X):-
|
||||||
var(X),!,
|
var(X),!,
|
||||||
get_value(db_verbose,X).
|
get_value(db_verbose,X).
|
||||||
db_verbose(N):-!,
|
db_verbose(N):-!,
|
||||||
set_value(db_verbose,N).
|
set_value(db_verbose,N).
|
||||||
%default value
|
%default value
|
||||||
:- set_value(db_verbose,0).
|
:- set_value(db_verbose,0).
|
||||||
:- set_value(db_verbose_filename,myddas_queries).
|
:- set_value(db_verbose_filename,myddas_queries).
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
|
|
||||||
|
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
% db_module/1
|
% db_module/1
|
||||||
%
|
%
|
||||||
%
|
%
|
||||||
db_module(X):-
|
db_module(X):-
|
||||||
var(X),!,
|
var(X),!,
|
||||||
get_value(db_module,X).
|
get_value(db_module,X).
|
||||||
db_module(ModuleName):-
|
db_module(ModuleName):-
|
||||||
set_value(db_module,ModuleName).
|
set_value(db_module,ModuleName).
|
||||||
% default value
|
% default value
|
||||||
:- db_module(user).
|
:- db_module(user).
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
|
|
||||||
|
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
% db_is_database_predicate(+,+,+)
|
% db_is_database_predicate(+,+,+)
|
||||||
%
|
%
|
||||||
%
|
%
|
||||||
db_is_database_predicate(Module,PredName,Arity):-
|
db_is_database_predicate(Module,PredName,Arity):-
|
||||||
'$error_checks'(db_is_database_predicate(PredName,Arity,Module)),
|
'$error_checks'(db_is_database_predicate(PredName,Arity,Module)),
|
||||||
c_db_check_if_exists_pred(PredName,Arity,Module).
|
c_db_check_if_exists_pred(PredName,Arity,Module).
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
|
|
||||||
#ifdef MYDDAS_STATS
|
#ifdef MYDDAS_STATS
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
% db_stats(+,-)
|
% db_stats(+,-)
|
||||||
%
|
%
|
||||||
%
|
%
|
||||||
db_stats(List):-
|
db_stats(List):-
|
||||||
db_stats(myddas,List).
|
db_stats(myddas,List).
|
||||||
|
|
||||||
db_stats(Protocol,List):-
|
db_stats(Protocol,List):-
|
||||||
'$error_checks'(db_stats(Protocol,List)),
|
'$error_checks'(db_stats(Protocol,List)),
|
||||||
NumberOfStats = 10,
|
NumberOfStats = 10,
|
||||||
'$make_a_list'(NumberOfStats,ListX1),
|
'$make_a_list'(NumberOfStats,ListX1),
|
||||||
( var(Protocol) ->
|
( var(Protocol) ->
|
||||||
c_db_stats(0,ListX1)
|
c_db_stats(0,ListX1)
|
||||||
;
|
;
|
||||||
get_value(Protocol,Conn),
|
get_value(Protocol,Conn),
|
||||||
c_db_stats(Conn,ListX1)
|
c_db_stats(Conn,ListX1)
|
||||||
),
|
),
|
||||||
'$make_stats_list'(ListX1,List).
|
'$make_stats_list'(ListX1,List).
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
% db_stats_time(+,-)
|
% db_stats_time(+,-)
|
||||||
% Reference is C pointer (memory reference)
|
% Reference is C puuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuu;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uuuuu;ointer (memory reference)
|
||||||
%
|
%
|
||||||
db_stats_time(Reference,Time):-
|
db_stats_time(Reference,Time):-
|
||||||
'$error_checks'(db_stats_time(Reference,Time)),
|
'$error_checks'(db_stats_time(Reference,Time)),
|
||||||
@@ -449,7 +450,6 @@ db_assert(Connection,PredName):-
|
|||||||
'$error_checks'(db_insert2(Connection,PredName,Code)),
|
'$error_checks'(db_insert2(Connection,PredName,Code)),
|
||||||
'$get_values_for_insert'(Code,ValuesList,RelName),
|
'$get_values_for_insert'(Code,ValuesList,RelName),
|
||||||
'$make_atom'(['INSERT INTO `',RelName,'` VALUES '|ValuesList],SQL),
|
'$make_atom'(['INSERT INTO `',RelName,'` VALUES '|ValuesList],SQL),
|
||||||
|
|
||||||
get_value(Connection,Con),
|
get_value(Connection,Con),
|
||||||
c_db_connection_type(Con,ConType),
|
c_db_connection_type(Con,ConType),
|
||||||
'$write_or_not'(SQL),
|
'$write_or_not'(SQL),
|
||||||
@@ -685,17 +685,18 @@ db_describe(Connection,Y,Z) :-
|
|||||||
|
|
||||||
db_datalog_show_tables :-
|
db_datalog_show_tables :-
|
||||||
db_datalog_show_tables(myddas).
|
db_datalog_show_tables(myddas).
|
||||||
|
db_show_tables :-
|
||||||
|
'$error_checks'(db_datalog_show_tables),
|
||||||
|
get_value(myddas,Con),
|
||||||
|
c_db_connection_type(Con,DBMS),
|
||||||
|
DBMS:datalog_show_tables.
|
||||||
|
|
||||||
db_datalog_show_tables(Connection) :-
|
db_datalog_show_tables(Connection) :-
|
||||||
'$error_checks'(db_datalog_show_tables(Connection) ),
|
'$error_checks'(db_datalog_show_tables(Connection) ),
|
||||||
get_value(Connection,Con),
|
get_value(Connection,Con),
|
||||||
c_db_connection_type(Con,DBMS),
|
c_db_connection_type(Con,DBMS),
|
||||||
switch( DBMS, datalog_show_tables(Connection) ).
|
switch( DBMS, datalog_show_tables(Connection) ).
|
||||||
|
|
||||||
db_datalog_show_tables :-
|
|
||||||
'$error_checks'(db_datalog_show_tables),
|
|
||||||
get_value(myddas,Con),
|
|
||||||
c_db_connection_type(Con,DBMS),
|
|
||||||
DBMS:datalog_show_tables.
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@pred db_show_tables(+,?).
|
@pred db_show_tables(+,?).
|
||||||
|
@@ -230,7 +230,7 @@ db_abolish(PredName,Arity):-
|
|||||||
%
|
%
|
||||||
db_listing:-
|
db_listing:-
|
||||||
c_db_connection(Con),
|
c_db_connection(Con),
|
||||||
c_db_preds_conn(Con,Module,Name,Arity),
|
user:c_db_preds_conn(Con,Module,Name,Arity),
|
||||||
listing(Module:Name/Arity),
|
listing(Module:Name/Arity),
|
||||||
fail.
|
fail.
|
||||||
db_listing.
|
db_listing.
|
||||||
@@ -243,15 +243,15 @@ db_listing.
|
|||||||
%
|
%
|
||||||
db_listing(Module:Name/Arity):-!,
|
db_listing(Module:Name/Arity):-!,
|
||||||
c_db_connection(Con),
|
c_db_connection(Con),
|
||||||
c_db_preds_conn(Con,Module,Name,Arity),
|
user:c_db_preds_conn(Con,Module,Name,Arity),
|
||||||
listing(Module:Name/Arity).
|
listing(Module:Name/Arity).
|
||||||
db_listing(Name/Arity):-!,
|
db_listing(Name/Arity):-!,
|
||||||
c_db_connection(Con),
|
c_db_connection(Con),
|
||||||
c_db_preds_conn(Con,Module,Name,Arity),
|
user:c_db_preds_conn(Con,Module,Name,Arity),
|
||||||
listing(Module:Name/Arity).
|
listing(Module:Name/Arity).
|
||||||
db_listing(Name):-
|
db_listing(Name):-
|
||||||
c_db_connection(Con),
|
c_db_connection(Con),
|
||||||
c_db_preds_conn(Con,Module,Name,Arity),
|
user:c_db_preds_conn(Con,Module,Name,Arity),
|
||||||
listing(Module:Name/Arity).
|
listing(Module:Name/Arity).
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
|
|
||||||
@@ -260,13 +260,12 @@ db_listing(Name):-
|
|||||||
%
|
%
|
||||||
table_arity( Con, ConType, RelationName, Arity ) :-
|
table_arity( Con, ConType, RelationName, Arity ) :-
|
||||||
c_db_connection_type(Con,ConType),
|
c_db_connection_type(Con,ConType),
|
||||||
writeln( ConType ),
|
|
||||||
% get relation arity
|
% get relation arity
|
||||||
( ConType == mysql ->
|
( ConType == mysql ->
|
||||||
c_db_my_number_of_fields(RelationName,Con,Arity)
|
c_db_my_number_of_fields(RelationName,Con,Arity)
|
||||||
;
|
;
|
||||||
ConType == postgres ->
|
ConType == postgres ->
|
||||||
c_postgres_number_of_fields(RelationName,Con,Arity)
|
c_postgres_number_of_fields(RelationName,Con,Arit)
|
||||||
;
|
;
|
||||||
ConType == odbc ->
|
ConType == odbc ->
|
||||||
c_odbc_number_of_fields(RelationName,Con,Arity)
|
c_odbc_number_of_fields(RelationName,Con,Arity)
|
||||||
|
@@ -28,7 +28,7 @@
|
|||||||
#define NAME() 'YAPodbc'
|
#define NAME() 'YAPodbc'
|
||||||
#define MODULE() user
|
#define MODULE() user
|
||||||
#define INIT() init_odbc
|
#define INIT() init_odbc
|
||||||
#elif defined( postgres )
|
#elif defined( postrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrs )
|
||||||
#undef postgres
|
#undef postgres
|
||||||
#define DBMS(x) postgres_##x
|
#define DBMS(x) postgres_##x
|
||||||
#define c_DBMS(x) c_postgres_##x
|
#define c_DBMS(x) c_postgres_##x
|
||||||
@@ -101,7 +101,6 @@ DBMS(result_set)(store_result):-
|
|||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
% DBMS(db_datalog_describe)/2
|
% DBMS(db_datalog_describe)/2
|
||||||
%
|
%
|
||||||
|
@@ -1,4 +1,3 @@
|
|||||||
:- stop_low_level_trace.
|
|
||||||
|
|
||||||
|
|
||||||
:- use_module(library(lists)).
|
:- use_module(library(lists)).
|
||||||
@@ -14,10 +13,22 @@ main_ :-
|
|||||||
fail.
|
fail.
|
||||||
main_ .
|
main_ .
|
||||||
|
|
||||||
|
:- if( yap_flag(android,true) ).
|
||||||
|
init :-
|
||||||
|
db_open(sqlite3, '/data/user/0/pt.up.yap/files/chinook.db', _, _),
|
||||||
|
!,
|
||||||
|
writeln('chinook has landed').
|
||||||
|
|
||||||
|
init :-
|
||||||
|
catch(db_open(sqlite3,'chinook.db',_,_), _, fail),
|
||||||
|
% db_open(sqlite3, 'chinook.db', _, _),
|
||||||
|
writeln('chinook has landed').
|
||||||
|
:- else.
|
||||||
init :-
|
init :-
|
||||||
db_open(sqlite3, '/data/user/0/pt.up.yap.yapdroid/files/Yap/chinook.db', _, _),
|
db_open(sqlite3, '/data/user/0/pt.up.yap.yapdroid/files/Yap/chinook.db', _, _),
|
||||||
% db_open(sqlite3, 'chinook.db', _, _),
|
% db_open(sqlite3, 'chinook.db', _, _),
|
||||||
writeln('chinook has landed').
|
writeln('chinook has landed').
|
||||||
|
:-endif.
|
||||||
|
|
||||||
go :-
|
go :-
|
||||||
writeln(('db_import')),
|
writeln(('db_import')),
|
||||||
|
@@ -8,6 +8,8 @@
|
|||||||
#define PASS_REGS
|
#define PASS_REGS
|
||||||
#define USES_REGS
|
#define USES_REGS
|
||||||
|
|
||||||
|
#include "Yap.h"
|
||||||
|
|
||||||
//@{
|
//@{
|
||||||
|
|
||||||
/** @brief Prolog to Python library
|
/** @brief Prolog to Python library
|
||||||
|
@@ -591,7 +591,7 @@ static int python_import(term_t mname, term_t mod) {
|
|||||||
const char *sn, *as = NULL;
|
const char *sn, *as = NULL;
|
||||||
Term t = Deref(ARG1), sm;
|
Term t = Deref(ARG1), sm;
|
||||||
if (IsApplTerm(t)) {
|
if (IsApplTerm(t)) {
|
||||||
Functor f = FunctorOfTerm(t);
|
Functor f = (Functor)*RepAppl(t);
|
||||||
if (f != FunctorAs)
|
if (f != FunctorAs)
|
||||||
return false;
|
return false;
|
||||||
do_as = true;
|
do_as = true;
|
||||||
|
@@ -54,8 +54,7 @@ endif()
|
|||||||
COMMAND ${SWIG_EXECUTABLE} -c++ -python -O -py3 -module "yap" -addextern -I${CMAKE_SOURCE_DIR}/H -I${CMAKE_SOURCE_DIR}/H/generated -I${CMAKE_SOURCE_DIR}/include
|
COMMAND ${SWIG_EXECUTABLE} -c++ -python -O -py3 -module "yap" -addextern -I${CMAKE_SOURCE_DIR}/H -I${CMAKE_SOURCE_DIR}/H/generated -I${CMAKE_SOURCE_DIR}/include
|
||||||
-I${CMAKE_SOURCE_DIR}/OPTYap -I${CMAKE_SOURCE_DIR}/os -I${CMAKE_SOURCE_DIR}/utf8proc -I.././.. -I${CMAKE_SOURCE_DIR}/CXX -I${CMAKE_SOURCE_DIR}/packages/python
|
-I${CMAKE_SOURCE_DIR}/OPTYap -I${CMAKE_SOURCE_DIR}/os -I${CMAKE_SOURCE_DIR}/utf8proc -I.././.. -I${CMAKE_SOURCE_DIR}/CXX -I${CMAKE_SOURCE_DIR}/packages/python
|
||||||
-outdir ${CMAKE_CURRENT_BINARY_DIR}/yap4py -I${GMP_INCLUDE_DIRS} -DX_API="" -o ${CMAKE_CURRENT_BINARY_DIR}/yap4py/yap_wrap.cxx -oh ${CMAKE_CURRENT_BINARY_DIR}/yap4py/yap_wrap.hh ${SWIG_SOURCES}
|
-outdir ${CMAKE_CURRENT_BINARY_DIR}/yap4py -I${GMP_INCLUDE_DIRS} -DX_API="" -o ${CMAKE_CURRENT_BINARY_DIR}/yap4py/yap_wrap.cxx -oh ${CMAKE_CURRENT_BINARY_DIR}/yap4py/yap_wrap.hh ${SWIG_SOURCES}
|
||||||
COMMAND ${PYTHON_EXECUTABLE} setup.py sdist ${bdist}
|
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
|
||||||
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
DEPENDS ${SWIG_SOURCES} Py4YAP YAP++ yap4py/yapi.cpp YAP4PY_PY
|
DEPENDS ${SWIG_SOURCES} Py4YAP YAP++ yap4py/yapi.cpp YAP4PY_PY
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -70,7 +69,9 @@ endif()
|
|||||||
DEPENDS ${PYTHON_SOURCES}
|
DEPENDS ${PYTHON_SOURCES}
|
||||||
)
|
)
|
||||||
|
|
||||||
install(CODE "execute_process(COMMAND ${PYTHON_EXECUTABLE} -m pip install ${PYTHON_USER_INSTALL} --ignore-installed .
|
install(CODE "execute_process(
|
||||||
|
COMMAND ${PYTHON_EXECUTABLE} setup.py sdist ${bdist}
|
||||||
|
COMMAND ${PYTHON_EXECUTABLE} -m pip install ${PYTHON_USER_INSTALL} --ignore-installed .
|
||||||
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR})"
|
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR})"
|
||||||
DEPENDS Py4YAP ${CMAKE_BINARY_DIR}/${YAP_STARTUP} ${YAP_INSTALL_DLLDIR} )
|
DEPENDS Py4YAP ${CMAKE_BINARY_DIR}/${YAP_STARTUP} ${YAP_INSTALL_DLLDIR} )
|
||||||
|
|
||||||
|
@@ -84,8 +84,8 @@ native_sources = ["yap4py/yap_wrap.cxx","yap4py/yapi.cpp"]
|
|||||||
|
|
||||||
|
|
||||||
extensions = [Extension('_yap', native_sources,
|
extensions = [Extension('_yap', native_sources,
|
||||||
define_macros=[('MAJOR_VERSION', '1'),
|
define_macros=[('MAJOR_VERSION', '@YAP_MAJOR_VERSION@'),
|
||||||
('MINOR_VERSION', '0'),
|
('MINOR_VERSION', '@YAP_MINOR_VERSION@'),
|
||||||
('_YAP_NOT_INSTALLED_', '1'),
|
('_YAP_NOT_INSTALLED_', '1'),
|
||||||
('YAP_PYTHON', '1'),
|
('YAP_PYTHON', '1'),
|
||||||
('PYTHONSWIG', '1'),
|
('PYTHONSWIG', '1'),
|
||||||
@@ -104,7 +104,7 @@ extensions = [Extension('_yap', native_sources,
|
|||||||
'${CMAKE_SOURCE_DIR}/os',
|
'${CMAKE_SOURCE_DIR}/os',
|
||||||
'${CMAKE_SOURCE_DIR}/utf8proc',
|
'${CMAKE_SOURCE_DIR}/utf8proc',
|
||||||
'${CMAKE_SOURCE_DIR}/packages/python',
|
'${CMAKE_SOURCE_DIR}/packages/python',
|
||||||
'../../..',
|
'${CMAKE_BINARY_DIR}',
|
||||||
'${CMAKE_SOURCE_DIR}/CXX' ]
|
'${CMAKE_SOURCE_DIR}/CXX' ]
|
||||||
)]
|
)]
|
||||||
|
|
||||||
|
@@ -185,7 +185,6 @@ yap_ipython/sphinxext/ipython_console_highlighting.py
|
|||||||
yap_ipython/sphinxext/ipython_directive.py
|
yap_ipython/sphinxext/ipython_directive.py
|
||||||
yap_ipython/nbformat.py
|
yap_ipython/nbformat.py
|
||||||
yap_ipython/paths.py
|
yap_ipython/paths.py
|
||||||
yap_ipython/_version.py
|
|
||||||
yap_ipython/nbconvert.py
|
yap_ipython/nbconvert.py
|
||||||
yap_ipython/qt.py
|
yap_ipython/qt.py
|
||||||
yap_ipython/html.py
|
yap_ipython/html.py
|
||||||
@@ -413,23 +412,12 @@ add_custom_command(OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/kerne
|
|||||||
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/kernel.js
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/kernel.js
|
||||||
)
|
)
|
||||||
|
|
||||||
add_custom_command(OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/meta.js
|
|
||||||
COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_SOURCE_DIR}/misc/editors/meta.js ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/
|
|
||||||
DEPENDS ${CMAKE_SOURCE_DIR}/misc/editors/meta.js
|
|
||||||
)
|
|
||||||
|
|
||||||
add_custom_command(OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/prolog.js
|
add_custom_command(OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/prolog.js
|
||||||
COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_SOURCE_DIR}/misc/editors/yap.js ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/prolog.js
|
COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_SOURCE_DIR}/misc/editors/yap.js ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/prolog.js
|
||||||
DEPENDS ${CMAKE_SOURCE_DIR}/misc/editors/yap.js
|
DEPENDS ${CMAKE_SOURCE_DIR}/misc/editors/yap.js
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
add_custom_command(OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/mode.js
|
|
||||||
COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_SOURCE_DIR}/misc/editors/mode.js ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/
|
|
||||||
DEPENDS ${CMAKE_SOURCE_DIR}/misc/editors/mode.js
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
foreach(f ${FILES})
|
foreach(f ${FILES})
|
||||||
add_custom_command(OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${f}
|
add_custom_command(OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${f}
|
||||||
COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_CURRENT_SOURCE_DIR}/${f} ${CMAKE_CURRENT_BINARY_DIR}/${f}
|
COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_CURRENT_SOURCE_DIR}/${f} ${CMAKE_CURRENT_BINARY_DIR}/${f}
|
||||||
@@ -441,13 +429,13 @@ endforeach()
|
|||||||
|
|
||||||
|
|
||||||
add_custom_target(YAP_KERNEL ALL
|
add_custom_target(YAP_KERNEL ALL
|
||||||
COMMAND ${PYTHON_EXECUTABLE} ${SETUP_PY} build sdist bdist
|
|
||||||
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
|
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
|
||||||
DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/logo-32x32.png ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/logo-64x64.png ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/kernel.js ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/meta.js ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/prolog.js ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/mode.js ${OUTS} YAP4PY
|
DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/logo-32x32.png ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/logo-64x64.png ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/kernel.js ${CMAKE_CURRENT_BINARY_DIR}/yap_kernel/resources/prolog.js ${OUTS} YAP4PY
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
install(CODE "execute_process(
|
install(CODE "execute_process(
|
||||||
|
COMMAND ${PYTHON_EXECUTABLE} ${SETUP_PY} build sdist bdist
|
||||||
COMMAND ${PYTHON_EXECUTABLE} -m pip install ${PYTHON_USER_INSTALL} --ignore-installed --no-deps .
|
COMMAND ${PYTHON_EXECUTABLE} -m pip install ${PYTHON_USER_INSTALL} --ignore-installed --no-deps .
|
||||||
COMMAND ${PYTHON_EXECUTABLE} -m yap_kernel.kernelspec
|
COMMAND ${PYTHON_EXECUTABLE} -m yap_kernel.kernelspec
|
||||||
ERROR_VARIABLE setupErr
|
ERROR_VARIABLE setupErr
|
||||||
|
@@ -36,12 +36,12 @@ DEPENDS pllibpl ${pl_os_library}
|
|||||||
)
|
)
|
||||||
|
|
||||||
add_custom_command (OUTPUT ${CMAKE_SWIG_OUTPUT}/swig_streamer.cpp
|
add_custom_command (OUTPUT ${CMAKE_SWIG_OUTPUT}/swig_streamer.cpp
|
||||||
COMMAND ${SWIG_EXECUTABLE} -c++ -java -package ${SWIG_MODULE_NAME} -outdir ${CMAKE_SWIG_OUTDIR} -addextern -I${CMAKE_CURRENT_SOURCE_DIR} -o ${CMAKE_SWIG_OUTPUT}/swig_streamer.cpp -oh ${CMAKE_SWIG_OUTPUT}/swig_streamer.hh streamer.i
|
COMMAND ${SWIG_EXECUTABLE} -c++ -java -package ${SWIG_MODULE_NAME} -O -outdir ${CMAKE_SWIG_OUTDIR} -addextern -I${CMAKE_CURRENT_SOURCE_DIR} -o ${CMAKE_SWIG_OUTPUT}/swig_streamer.cpp -oh ${CMAKE_SWIG_OUTPUT}/swig_streamer.hh streamer.i
|
||||||
DEPENDS streamer.i
|
DEPENDS streamer.i
|
||||||
)
|
)
|
||||||
|
|
||||||
add_custom_command (OUTPUT ${CMAKE_SWIG_OUTPUT}/yap_swig.cpp
|
add_custom_command (OUTPUT ${CMAKE_SWIG_OUTPUT}/yap_swig.cpp
|
||||||
COMMAND ${SWIG_EXECUTABLE} -c++ -java -package ${SWIG_MODULE_NAME} -outdir ${CMAKE_SWIG_OUTDIR} -addextern -I${CMAKE_SOURCE_DIR}/CXX -I${CMAKE_SOURCE_DIR}/include -I${CMAKE_SOURCE_DIR}/H -I${CMAKE_SOURCE_DIR}/os -I${CMAKE_SOURCE_DIR}/OPTYap -I${CMAKE_BINARY_DIR} -I${GMP_INCLUDE_DIRS} -DX_API="" -o ${CMAKE_SWIG_OUTPUT}/yap_swig.cpp -oh ${CMAKE_SWIG_OUTPUT}/yap_swig.hh ${SWIG_SOURCES}
|
COMMAND ${SWIG_EXECUTABLE} -c++ -java -package ${SWIG_MODULE_NAME} -O -outdir ${CMAKE_SWIG_OUTDIR} -addextern -I${CMAKE_SOURCE_DIR}/CXX -I${CMAKE_SOURCE_DIR}/include -I${CMAKE_SOURCE_DIR}/H -I${CMAKE_SOURCE_DIR}/os -I${CMAKE_SOURCE_DIR}/OPTYap -I${CMAKE_BINARY_DIR} -I${GMP_INCLUDE_DIRS} -DX_API="" -o ${CMAKE_SWIG_OUTPUT}/yap_swig.cpp -oh ${CMAKE_SWIG_OUTPUT}/yap_swig.hh ${SWIG_SOURCES}
|
||||||
DEPENDS pllibos ${SWIG_SOURCES} YAP++)
|
DEPENDS pllibos ${SWIG_SOURCES} YAP++)
|
||||||
|
|
||||||
|
|
||||||
|
@@ -124,6 +124,19 @@ YAPError = _yap.YAPError
|
|||||||
|
|
||||||
%typecheck(0) YAPTerm { $1 = !PyUnicode_Check($input); }
|
%typecheck(0) YAPTerm { $1 = !PyUnicode_Check($input); }
|
||||||
|
|
||||||
|
%exception {
|
||||||
|
try {
|
||||||
|
$action
|
||||||
|
} catch (const std::out_of_range& e) {
|
||||||
|
SWIG_exception(SWIG_IndexError, e.what());
|
||||||
|
} catch (const std::exception& e) {
|
||||||
|
SWIG_exception(SWIG_RuntimeError, e.what());
|
||||||
|
} catch (...) {
|
||||||
|
SWIG_exception(SWIG_RuntimeError, "unknown exception");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
%typemap(in) arity_t { (jlong)($input); }
|
%typemap(in) arity_t { (jlong)($input); }
|
||||||
@@ -139,19 +152,6 @@ YAPError = _yap.YAPError
|
|||||||
// Language independent exception handler
|
// Language independent exception handler
|
||||||
// simplified version
|
// simplified version
|
||||||
%include <exception.i>
|
%include <exception.i>
|
||||||
|
|
||||||
%exception {
|
|
||||||
try {
|
|
||||||
$action
|
|
||||||
} catch (const std::out_of_range& e) {
|
|
||||||
SWIG_exception(SWIG_IndexError, e.what());
|
|
||||||
} catch (const std::exception& e) {
|
|
||||||
SWIG_exception(SWIG_RuntimeError, e.what());
|
|
||||||
} catch (...) {
|
|
||||||
SWIG_exception(SWIG_RuntimeError, "unknown exception");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
@@ -351,8 +351,9 @@ static void
|
|||||||
};
|
};
|
||||||
|
|
||||||
%init %{
|
%init %{
|
||||||
PyObject * pYAPError = PyErr_NewException("_yap.YAPError", NULL, NULL);
|
#ifdef SWIGYTHON
|
||||||
Py_INCREF(pYAPError);
|
PyObject * pYAPError = PyErr_NewException("_yap.YAPError", NULL, NULL);
|
||||||
PyModule_AddObject(m, "YAPError", pYAPError);
|
Py_INCREF(pYAPError);
|
||||||
|
PyModule_AddObject(m, "YAPError", pYAPError);
|
||||||
|
#endif
|
||||||
%}
|
%}
|
||||||
|
@@ -478,4 +478,8 @@ If this hook preodicate succeeds it must instantiate the _Action_ argument to t
|
|||||||
:- ensure_loaded('../pl/pathconf.yap').
|
:- ensure_loaded('../pl/pathconf.yap').
|
||||||
|
|
||||||
:- yap_flag(user:unknown,error).
|
:- yap_flag(user:unknown,error).
|
||||||
|
|
||||||
|
:- ensure_loaded('../android.yap').
|
||||||
|
|
||||||
|
|
||||||
%% @}
|
%% @}
|
||||||
|
489
pl/preds.yap
489
pl/preds.yap
@@ -112,7 +112,7 @@ undefined results.
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
assert_static(C) :-
|
assert_static(C) :-
|
||||||
'$assert'(C , assertz_static, _ ).
|
'$assert'(C , assertz_static, _ ).
|
||||||
|
|
||||||
/** @pred asserta_static(: _C_)
|
/** @pred asserta_static(: _C_)
|
||||||
|
|
||||||
@@ -122,7 +122,7 @@ Adds clause _C_ as the first clause for a static procedure.
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
asserta_static(C) :-
|
asserta_static(C) :-
|
||||||
'$assert'(C , asserta_static, _ ).
|
'$assert'(C , asserta_static, _ ).
|
||||||
|
|
||||||
|
|
||||||
/** @pred assertz_static(: _C_)
|
/** @pred assertz_static(: _C_)
|
||||||
@@ -142,7 +142,7 @@ static predicates, if source mode was on when they were compiled:
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
assertz_static(C) :-
|
assertz_static(C) :-
|
||||||
'$assert'(C , assertz_static, _ ).
|
'$assert'(C , assertz_static, _ ).
|
||||||
|
|
||||||
/** @pred clause(+ _H_, _B_) is iso
|
/** @pred clause(+ _H_, _B_) is iso
|
||||||
|
|
||||||
@@ -158,9 +158,9 @@ This predicate is applicable to static procedures compiled with
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
clause(V0,Q) :-
|
clause(V0,Q) :-
|
||||||
'$yap_strip_module'(V0, M, V),
|
'$yap_strip_module'(V0, M, V),
|
||||||
must_be_of_type( callable, V ),
|
must_be_of_type( callable, V ),
|
||||||
'$clause'(V,M,Q,_).
|
'$clause'(V,M,Q,_).
|
||||||
|
|
||||||
/** @pred clause(+ _H_, _B_,- _R_)
|
/** @pred clause(+ _H_, _B_,- _R_)
|
||||||
|
|
||||||
@@ -170,9 +170,9 @@ to access the reference's value. Note that you may not use
|
|||||||
erase/1 on the reference on static procedures.
|
erase/1 on the reference on static procedures.
|
||||||
*/
|
*/
|
||||||
clause(P,Q,R) :-
|
clause(P,Q,R) :-
|
||||||
'$instance_module'(R,M0), !,
|
'$instance_module'(R,M0), !,
|
||||||
instance(R,T0),
|
instance(R,T0),
|
||||||
( T0 = (H :- B) -> Q = B ; H=T0, Q = true),
|
( T0 = (H :- B) -> Q = B ; H=T0, Q = true),
|
||||||
'$yap_strip_module'(P, M, T),
|
'$yap_strip_module'(P, M, T),
|
||||||
'$yap_strip_module'(M0:H, M1, H1),
|
'$yap_strip_module'(M0:H, M1, H1),
|
||||||
(
|
(
|
||||||
@@ -183,44 +183,44 @@ clause(P,Q,R) :-
|
|||||||
M1:H1 = T
|
M1:H1 = T
|
||||||
).
|
).
|
||||||
clause(V0,Q,R) :-
|
clause(V0,Q,R) :-
|
||||||
'$yap_strip_module'(V0, M, V),
|
'$yap_strip_module'(V0, M, V),
|
||||||
must_be_of_type( callable, V ),
|
must_be_of_type( callable, V ),
|
||||||
'$clause'(V,M,Q,R).
|
'$clause'(V,M,Q,R).
|
||||||
|
|
||||||
'$clause'(P,M,Q,R) :-
|
'$clause'(P,M,Q,R) :-
|
||||||
'$is_exo'(P, M), !,
|
'$is_exo'(P, M), !,
|
||||||
Q = true,
|
Q = true,
|
||||||
R = '$exo_clause'(M,P),
|
R = '$exo_clause'(M,P),
|
||||||
'$execute0'(P, M).
|
'$execute0'(P, M).
|
||||||
'$clause'(P,M,Q,R) :-
|
'$clause'(P,M,Q,R) :-
|
||||||
'$is_log_updatable'(P, M), !,
|
'$is_log_updatable'(P, M), !,
|
||||||
'$log_update_clause'(P,M,Q,R).
|
'$log_update_clause'(P,M,Q,R).
|
||||||
'$clause'(P,M,Q,R) :-
|
'$clause'(P,M,Q,R) :-
|
||||||
'$is_source'(P, M), !,
|
'$is_source'(P, M), !,
|
||||||
'$static_clause'(P,M,Q,R).
|
'$static_clause'(P,M,Q,R).
|
||||||
'$clause'(P,M,Q,R) :-
|
'$clause'(P,M,Q,R) :-
|
||||||
'$some_recordedp'(M:P), !,
|
'$some_recordedp'(M:P), !,
|
||||||
'$recordedp'(M:P,(P:-Q),R).
|
'$recordedp'(M:P,(P:-Q),R).
|
||||||
'$clause'(P,M,Q,R) :-
|
'$clause'(P,M,Q,R) :-
|
||||||
\+ '$undefined'(P,M),
|
\+ '$undefined'(P,M),
|
||||||
( '$is_system_predicate'(P,M) -> true ;
|
( '$is_system_predicate'(P,M) -> true ;
|
||||||
'$number_of_clauses'(P,M,N), N > 0 ),
|
'$number_of_clauses'(P,M,N), N > 0 ),
|
||||||
functor(P,Name,Arity),
|
functor(P,Name,Arity),
|
||||||
'$do_error'(permission_error(access,private_procedure,Name/Arity),
|
'$do_error'(permission_error(access,private_procedure,Name/Arity),
|
||||||
clause(M:P,Q,R)).
|
clause(M:P,Q,R)).
|
||||||
|
|
||||||
'$init_preds' :-
|
'$init_preds' :-
|
||||||
once('$do_static_clause'(_,_,_,_,_)),
|
once('$do_static_clause'(_,_,_,_,_)),
|
||||||
fail.
|
fail.
|
||||||
'$init_preds' :-
|
'$init_preds' :-
|
||||||
once('$do_log_upd_clause0'(_,_,_,_,_,_)),
|
once('$do_log_upd_clause0'(_,_,_,_,_,_)),
|
||||||
fail.
|
fail.
|
||||||
'$init_preds' :-
|
'$init_preds' :-
|
||||||
once('$do_log_upd_clause'(_,_,_,_,_,_)),
|
once('$do_log_upd_clause'(_,_,_,_,_,_)),
|
||||||
fail.
|
fail.
|
||||||
'$init_preds' :-
|
'$init_preds' :-
|
||||||
once('$do_log_upd_clause_erase'(_,_,_,_,_,_)),
|
once('$do_log_upd_clause_erase'(_,_,_,_,_,_)),
|
||||||
fail.
|
fail.
|
||||||
|
|
||||||
'$init_preds'.
|
'$init_preds'.
|
||||||
|
|
||||||
@@ -237,16 +237,16 @@ and _I_ is bound to its position.
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
nth_clause(V,I,R) :-
|
nth_clause(V,I,R) :-
|
||||||
strip_module(V, M1, P), !,
|
strip_module(V, M1, P), !,
|
||||||
'$nth_clause'(P, M1, I, R).
|
'$nth_clause'(P, M1, I, R).
|
||||||
|
|
||||||
|
|
||||||
'$nth_clause'(P,M,I,R) :-
|
'$nth_clause'(P,M,I,R) :-
|
||||||
var(I), var(R), !,
|
var(I), var(R), !,
|
||||||
'$clause'(P,M,_,R),
|
'$clause'(P,M,_,R),
|
||||||
'$fetch_nth_clause'(P,M,I,R).
|
'$fetch_nth_clause'(P,M,I,R).
|
||||||
'$nth_clause'(P,M,I,R) :-
|
'$nth_clause'(P,M,I,R) :-
|
||||||
'$fetch_nth_clause'(P,M,I,R).
|
'$fetch_nth_clause'(P,M,I,R).
|
||||||
|
|
||||||
/** @pred abolish(+ _P_,+ _N_)
|
/** @pred abolish(+ _P_,+ _N_)
|
||||||
|
|
||||||
@@ -256,19 +256,19 @@ including whether it is dynamic or static, multifile, or
|
|||||||
meta-predicate, will be lost.
|
meta-predicate, will be lost.
|
||||||
*/
|
*/
|
||||||
abolish(N0,A) :-
|
abolish(N0,A) :-
|
||||||
strip_module(N0, Mod, N), !,
|
strip_module(N0, Mod, N), !,
|
||||||
'$abolish'(N,A,Mod).
|
'$abolish'(N,A,Mod).
|
||||||
|
|
||||||
'$abolish'(N,A,M) :- var(N), !,
|
'$abolish'(N,A,M) :- var(N), !,
|
||||||
'$do_error'(instantiation_error,abolish(M:N,A)).
|
'$do_error'(instantiation_error,abolish(M:N,A)).
|
||||||
'$abolish'(N,A,M) :- var(A), !,
|
'$abolish'(N,A,M) :- var(A), !,
|
||||||
'$do_error'(instantiation_error,abolish(M:N,A)).
|
'$do_error'(instantiation_error,abolish(M:N,A)).
|
||||||
'$abolish'(N,A,M) :-
|
'$abolish'(N,A,M) :-
|
||||||
( recorded('$predicate_defs','$predicate_defs'(N,A,M,_),R) -> erase(R) ),
|
( recorded('$predicate_defs','$predicate_defs'(N,A,M,_),R) -> erase(R) ),
|
||||||
fail.
|
fail.
|
||||||
'$abolish'(N,A,M) :- functor(T,N,A),
|
'$abolish'(N,A,M) :- functor(T,N,A),
|
||||||
( '$is_dynamic'(T, M) -> '$abolishd'(T,M) ;
|
( '$is_dynamic'(T, M) -> '$abolishd'(T,M) ;
|
||||||
/* else */ '$abolishs'(T,M) ).
|
/* else */ '$abolishs'(T,M) ).
|
||||||
|
|
||||||
/** @pred abolish(+ _PredSpec_) is iso
|
/** @pred abolish(+ _PredSpec_) is iso
|
||||||
|
|
||||||
@@ -283,141 +283,141 @@ dynamic procedures. Under other modes it will abolish any procedures.
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
abolish(X0) :-
|
abolish(X0) :-
|
||||||
strip_module(X0,M,X),
|
strip_module(X0,M,X),
|
||||||
'$abolish'(X,M).
|
'$abolish'(X,M).
|
||||||
|
|
||||||
'$abolish'(X,M) :-
|
'$abolish'(X,M) :-
|
||||||
current_prolog_flag(language, sicstus), !,
|
current_prolog_flag(language, sicstus), !,
|
||||||
'$new_abolish'(X,M).
|
'$new_abolish'(X,M).
|
||||||
'$abolish'(X, M) :-
|
'$abolish'(X, M) :-
|
||||||
'$old_abolish'(X,M).
|
'$old_abolish'(X,M).
|
||||||
|
|
||||||
'$new_abolish'(V,M) :- var(V), !,
|
'$new_abolish'(V,M) :- var(V), !,
|
||||||
'$abolish_all'(M).
|
'$abolish_all_in_module'(M).
|
||||||
'$new_abolish'(A/V,M) :- atom(A), var(V), !,
|
'$new_abolish'(A/V,M) :- atom(A), var(V), !,
|
||||||
'$abolish_all_atoms'(A,M).
|
'$abolish_all_atoms'(A,M).
|
||||||
'$new_abolish'(Na//Ar1, M) :-
|
'$new_abolish'(Na//Ar1, M) :-
|
||||||
integer(Ar1),
|
integer(Ar1),
|
||||||
!,
|
!,
|
||||||
Ar is Ar1+2,
|
Ar is Ar1+2,
|
||||||
'$new_abolish'(Na//Ar, M).
|
'$new_abolish'(Na//Ar, M).
|
||||||
'$new_abolish'(Na/Ar, M) :-
|
'$new_abolish'(Na/Ar, M) :-
|
||||||
functor(H, Na, Ar),
|
functor(H, Na, Ar),
|
||||||
'$is_dynamic'(H, M), !,
|
'$is_dynamic'(H, M), !,
|
||||||
'$abolishd'(H, M).
|
'$abolishd'(H, M).
|
||||||
'$new_abolish'(Na/Ar, M) :- % succeed for undefined procedures.
|
'$new_abolish'(Na/Ar, M) :- % succeed for undefined procedures.
|
||||||
functor(T, Na, Ar),
|
functor(T, Na, Ar),
|
||||||
'$undefined'(T, M), !.
|
'$undefined'(T, M), !.
|
||||||
'$new_abolish'(Na/Ar, M) :-
|
'$new_abolish'(Na/Ar, M) :-
|
||||||
'$do_error'(permission_error(modify,static_procedure,Na/Ar),abolish(M:Na/Ar)).
|
'$do_error'(permission_error(modify,static_procedure,Na/Ar),abolish(M:Na/Ar)).
|
||||||
'$new_abolish'(T, M) :-
|
'$new_abolish'(T, M) :-
|
||||||
'$do_error'(type_error(predicate_indicator,T),abolish(M:T)).
|
'$do_error'(type_error(predicate_indicator,T),abolish(M:T)).
|
||||||
|
|
||||||
'$abolish_all'(M) :-
|
'$abolish_all_in_module'(M) :-
|
||||||
'$current_predicate'(Na, M, S, _),
|
'$current_predicate'(Na, M, S, _),
|
||||||
functor(S, Na, Ar),
|
functor(S, Na, Ar),
|
||||||
'$new_abolish'(Na/Ar, M),
|
'$new_abolish'(Na/Ar, M),
|
||||||
fail.
|
fail.
|
||||||
'$abolish_all'(_).
|
'$abolish_all_in_module'(_).
|
||||||
|
|
||||||
'$abolish_all_atoms'(Na, M) :-
|
'$abolish_all_atoms'(Na, M) :-
|
||||||
'$current_predicate'(Na,M,S,_),
|
'$current_predicate'(Na,M,S,_),
|
||||||
functor(S, Na, Ar),
|
functor(S, Na, Ar),
|
||||||
'$new_abolish'(Na/Ar, M),
|
'$new_abolish'(Na/Ar, M),
|
||||||
fail.
|
fail.
|
||||||
'$abolish_all_atoms'(_,_).
|
'$abolish_all_atoms'(_,_).
|
||||||
|
|
||||||
'$check_error_in_predicate_indicator'(V, Msg) :-
|
'$check_error_in_predicate_indicator'(V, Msg) :-
|
||||||
var(V), !,
|
var(V), !,
|
||||||
'$do_error'(instantiation_error, Msg).
|
'$do_error'(instantiation_error, Msg).
|
||||||
'$check_error_in_predicate_indicator'(M:S, Msg) :- !,
|
'$check_error_in_predicate_indicator'(M:S, Msg) :- !,
|
||||||
'$check_error_in_module'(M, Msg),
|
'$check_error_in_module'(M, Msg),
|
||||||
'$check_error_in_predicate_indicator'(S, Msg).
|
'$check_error_in_predicate_indicator'(S, Msg).
|
||||||
'$check_error_in_predicate_indicator'(S, Msg) :-
|
'$check_error_in_predicate_indicator'(S, Msg) :-
|
||||||
S \= _/_,
|
S \= _/_,
|
||||||
S \= _//_, !,
|
S \= _//_, !,
|
||||||
'$do_error'(type_error(predicate_indicator,S), Msg).
|
'$do_error'(type_error(predicate_indicator,S), Msg).
|
||||||
'$check_error_in_predicate_indicator'(Na/_, Msg) :-
|
'$check_error_in_predicate_indicator'(Na/_, Msg) :-
|
||||||
var(Na), !,
|
var(Na), !,
|
||||||
'$do_error'(instantiation_error, Msg).
|
'$do_error'(instantiation_error, Msg).
|
||||||
'$check_error_in_predicate_indicator'(Na/_, Msg) :-
|
'$check_error_in_predicate_indicator'(Na/_, Msg) :-
|
||||||
\+ atom(Na), !,
|
\+ atom(Na), !,
|
||||||
'$do_error'(type_error(atom,Na), Msg).
|
'$do_error'(type_error(atom,Na), Msg).
|
||||||
'$check_error_in_predicate_indicator'(_/Ar, Msg) :-
|
'$check_error_in_predicate_indicator'(_/Ar, Msg) :-
|
||||||
var(Ar), !,
|
var(Ar), !,
|
||||||
'$do_error'(instantiation_error, Msg).
|
'$do_error'(instantiation_error, Msg).
|
||||||
'$check_error_in_predicate_indicator'(_/Ar, Msg) :-
|
'$check_error_in_predicate_indicator'(_/Ar, Msg) :-
|
||||||
\+ integer(Ar), !,
|
\+ integer(Ar), !,
|
||||||
'$do_error'(type_error(integer,Ar), Msg).
|
'$do_error'(type_error(integer,Ar), Msg).
|
||||||
'$check_error_in_predicate_indicator'(_/Ar, Msg) :-
|
'$check_error_in_predicate_indicator'(_/Ar, Msg) :-
|
||||||
Ar < 0, !,
|
Ar < 0, !,
|
||||||
'$do_error'(domain_error(not_less_than_zero,Ar), Msg).
|
'$do_error'(domain_error(not_less_than_zero,Ar), Msg).
|
||||||
% not yet implemented!
|
% not yet implemented!
|
||||||
%'$check_error_in_predicate_indicator'(Na/Ar, Msg) :-
|
%'$check_error_in_predicate_indicator'(Na/Ar, Msg) :-
|
||||||
% Ar < maxarity, !,
|
% Ar < maxarity, !,
|
||||||
% '$do_error'(type_error(representation_error(max_arity),Ar), Msg).
|
% '$do_error'(type_error(representation_error(max_arity),Ar), Msg).
|
||||||
|
|
||||||
'$check_error_in_module'(M, Msg) :-
|
'$check_error_in_module'(M, Msg) :-
|
||||||
var(M), !,
|
var(M), !,
|
||||||
'$do_error'(instantiation_error, Msg).
|
'$do_error'(instantiation_error, Msg).
|
||||||
'$check_error_in_module'(M, Msg) :-
|
'$check_error_in_module'(M, Msg) :-
|
||||||
\+ atom(M), !,
|
\+ atom(M), !,
|
||||||
'$do_error'(type_error(atom,M), Msg).
|
'$do_error'(type_error(atom,M), Msg).
|
||||||
|
|
||||||
'$old_abolish'(V,M) :- var(V), !,
|
'$old_abolish'(V,M) :- var(V), !,
|
||||||
( true -> % current_prolog_flag(language, sicstus) ->
|
( true -> % current_prolog_flag(language, sicstus) ->
|
||||||
'$do_error'(instantiation_error,abolish(M:V))
|
'$do_error'(instantiation_error,abolish(M:V))
|
||||||
;
|
;
|
||||||
'$abolish_all_old'(M)
|
'$abolish_all_old'(M)
|
||||||
).
|
).
|
||||||
'$old_abolish'(N/A, M) :- !,
|
'$old_abolish'(N/A, M) :- !,
|
||||||
'$abolish'(N, A, M).
|
'$abolish'(N, A, M).
|
||||||
'$old_abolish'(A,M) :- atom(A), !,
|
'$old_abolish'(A,M) :- atom(A), !,
|
||||||
( current_prolog_flag(language, iso) ->
|
( current_prolog_flag(language, iso) ->
|
||||||
'$do_error'(type_error(predicate_indicator,A),abolish(M:A))
|
'$do_error'(type_error(predicate_indicator,A),abolish(M:A))
|
||||||
;
|
;
|
||||||
'$abolish_all_atoms_old'(A,M)
|
'$abolish_all_atoms_old'(A,M)
|
||||||
).
|
).
|
||||||
'$old_abolish'([], _) :- !.
|
'$old_abolish'([], _) :- !.
|
||||||
'$old_abolish'([H|T], M) :- !, '$old_abolish'(H, M), '$old_abolish'(T, M).
|
'$old_abolish'([H|T], M) :- !, '$old_abolish'(H, M), '$old_abolish'(T, M).
|
||||||
'$old_abolish'(T, M) :-
|
'$old_abolish'(T, M) :-
|
||||||
'$do_error'(type_error(predicate_indicator,T),abolish(M:T)).
|
'$do_error'(type_error(predicate_indicator,T),abolish(M:T)).
|
||||||
|
|
||||||
'$abolish_all_old'(M) :-
|
'$abolish_all_old'(M) :-
|
||||||
'$current_predicate'(Na, M, S, _),
|
'$current_predicate'(Na, M, S, _),
|
||||||
functor( S, Na, Ar ),
|
functor( S, Na, Ar ),
|
||||||
'$abolish'(Na, Ar, M),
|
'$abolish'(Na, Ar, M),
|
||||||
fail.
|
fail.
|
||||||
'$abolish_all_old'(_).
|
'$abolish_all_old'(_).
|
||||||
|
|
||||||
'$abolish_all_atoms_old'(Na, M) :-
|
'$abolish_all_atoms_old'(Na, M) :-
|
||||||
'$current_predicate'(Na, M, S, _),
|
'$current_predicate'(Na, M, S, _),
|
||||||
functor(S, Na, Ar),
|
functor(S, Na, Ar),
|
||||||
'$abolish'(Na, Ar, M),
|
'$abolish'(Na, Ar, M),
|
||||||
fail.
|
fail.
|
||||||
'$abolish_all_atoms_old'(_,_).
|
'$abolish_all_atoms_old'(_,_).
|
||||||
|
|
||||||
'$abolishs'(G, M) :- '$system_predicate'(G,M), !,
|
'$abolishs'(G, M) :- '$system_predicate'(G,M), !,
|
||||||
functor(G,Name,Arity),
|
functor(G,Name,Arity),
|
||||||
'$do_error'(permission_error(modify,static_procedure,Name/Arity),abolish(M:G)).
|
'$do_error'(permission_error(modify,static_procedure,Name/Arity),abolish(M:G)).
|
||||||
'$abolishs'(G, Module) :-
|
'$abolishs'(G, Module) :-
|
||||||
current_prolog_flag(language, sicstus), % only do this in sicstus mode
|
current_prolog_flag(language, sicstus), % only do this in sicstus mode
|
||||||
'$undefined'(G, Module),
|
'$undefined'(G, Module),
|
||||||
functor(G,Name,Arity),
|
functor(G,Name,Arity),
|
||||||
print_message(warning,no_match(abolish(Module:Name/Arity))).
|
print_message(warning,no_match(abolish(Module:Name/Arity))).
|
||||||
'$abolishs'(G, M) :-
|
'$abolishs'(G, M) :-
|
||||||
'$is_multifile'(G,M),
|
'$is_multifile'(G,M),
|
||||||
functor(G,Name,Arity),
|
functor(G,Name,Arity),
|
||||||
recorded('$mf','$mf_clause'(_,Name,Arity,M,_Ref),R),
|
recorded('$mf','$mf_clause'(_,Name,Arity,M,_Ref),R),
|
||||||
erase(R),
|
erase(R),
|
||||||
% no need erase(Ref),
|
% no need erase(Ref),
|
||||||
fail.
|
fail.
|
||||||
'$abolishs'(T, M) :-
|
'$abolishs'(T, M) :-
|
||||||
recorded('$import','$import'(_,M,_,_,T,_,_),R),
|
recorded('$import','$import'(_,M,_,_,T,_,_),R),
|
||||||
erase(R),
|
erase(R),
|
||||||
fail.
|
fail.
|
||||||
'$abolishs'(G, M) :-
|
'$abolishs'(G, M) :-
|
||||||
'$purge_clauses'(G, M), fail.
|
'$purge_clauses'(G, M), fail.
|
||||||
'$abolishs'(_, _).
|
'$abolishs'(_, _).
|
||||||
|
|
||||||
/** @pred stash_predicate(+ _Pred_)
|
/** @pred stash_predicate(+ _Pred_)
|
||||||
@@ -426,16 +426,16 @@ Make predicate _Pred_ invisible to new code, and to `current_predicate/2`,
|
|||||||
functor can be declared.
|
functor can be declared.
|
||||||
**/
|
**/
|
||||||
stash_predicate(P0) :-
|
stash_predicate(P0) :-
|
||||||
strip_module(P0, M, P),
|
strip_module(P0, M, P),
|
||||||
'$stash_predicate2'(P, M).
|
'$stash_predicate2'(P, M).
|
||||||
|
|
||||||
'$stash_predicate2'(V, M) :- var(V), !,
|
'$stash_predicate2'(V, M) :- var(V), !,
|
||||||
'$do_error'(instantiation_error,stash_predicate(M:V)).
|
'$do_error'(instantiation_error,stash_predicate(M:V)).
|
||||||
'$stash_predicate2'(N/A, M) :- !,
|
'$stash_predicate2'(N/A, M) :- !,
|
||||||
functor(S,N,A),
|
functor(S,N,A),
|
||||||
'$stash_predicate'(S, M) .
|
'$stash_predicate'(S, M) .
|
||||||
'$stash_predicate2'(PredDesc, M) :-
|
'$stash_predicate2'(PredDesc, M) :-
|
||||||
'$do_error'(type_error(predicate_indicator,PredDesc),stash_predicate(M:PredDesc)).
|
'$do_error'(type_error(predicate_indicator,PredDesc),stash_predicate(M:PredDesc)).
|
||||||
|
|
||||||
/** @pred hide_predicate(+ _Pred_)
|
/** @pred hide_predicate(+ _Pred_)
|
||||||
Make predicate _Pred_ invisible to `current_predicate/2`,
|
Make predicate _Pred_ invisible to `current_predicate/2`,
|
||||||
@@ -443,9 +443,9 @@ Make predicate _Pred_ invisible to `current_predicate/2`,
|
|||||||
|
|
||||||
**/
|
**/
|
||||||
hide_predicate(P0) :-
|
hide_predicate(P0) :-
|
||||||
'$yap_strip_module'(P0, M, P),
|
'$yap_strip_module'(P0, M, P),
|
||||||
must_be_of_type(callable, M:P),
|
must_be_of_type(callable, M:P),
|
||||||
'$hide_predicate'(P, M).
|
'$hide_predicate'(P, M).
|
||||||
|
|
||||||
/** @pred predicate_property( _P_, _Prop_) is iso
|
/** @pred predicate_property( _P_, _Prop_) is iso
|
||||||
|
|
||||||
@@ -492,8 +492,8 @@ or built-in.
|
|||||||
*/
|
*/
|
||||||
predicate_property(Pred,Prop) :-
|
predicate_property(Pred,Prop) :-
|
||||||
(
|
(
|
||||||
current_predicate(_,Pred),
|
current_predicate(_,Pred),
|
||||||
'$yap_strip_module'(Pred, Mod, TruePred)
|
'$yap_strip_module'(Pred, Mod, TruePred)
|
||||||
;
|
;
|
||||||
'$current_predicate'(_,M,Pred,system),
|
'$current_predicate'(_,M,Pred,system),
|
||||||
'$yap_strip_module'(M:Pred, Mod, TruePred)
|
'$yap_strip_module'(M:Pred, Mod, TruePred)
|
||||||
@@ -506,41 +506,41 @@ predicate_property(Pred,Prop) :-
|
|||||||
NPred = TruePred
|
NPred = TruePred
|
||||||
;
|
;
|
||||||
'$get_undefined_pred'(TruePred, Mod, NPred, M)
|
'$get_undefined_pred'(TruePred, Mod, NPred, M)
|
||||||
),
|
),
|
||||||
'$predicate_property'(NPred,M,Mod,Prop).
|
'$predicate_property'(NPred,M,Mod,Prop).
|
||||||
|
|
||||||
'$predicate_property'(P,M,_,built_in) :-
|
'$predicate_property'(P,M,_,built_in) :-
|
||||||
'$is_system_predicate'(P,M).
|
'$is_system_predicate'(P,M).
|
||||||
'$predicate_property'(P,M,_,source) :-
|
'$predicate_property'(P,M,_,source) :-
|
||||||
'$predicate_flags'(P,M,F,F),
|
'$predicate_flags'(P,M,F,F),
|
||||||
F /\ 0x00400000 =\= 0.
|
F /\ 0x00400000 =\= 0.
|
||||||
'$predicate_property'(P,M,_,tabled) :-
|
'$predicate_property'(P,M,_,tabled) :-
|
||||||
'$predicate_flags'(P,M,F,F),
|
'$predicate_flags'(P,M,F,F),
|
||||||
F /\ 0x00000040 =\= 0.
|
F /\ 0x00000040 =\= 0.
|
||||||
'$predicate_property'(P,M,_,dynamic) :-
|
'$predicate_property'(P,M,_,dynamic) :-
|
||||||
'$is_dynamic'(P,M).
|
'$is_dynamic'(P,M).
|
||||||
'$predicate_property'(P,M,_,static) :-
|
'$predicate_property'(P,M,_,static) :-
|
||||||
\+ '$is_dynamic'(P,M),
|
\+ '$is_dynamic'(P,M),
|
||||||
\+ '$undefined'(P,M).
|
\+ '$undefined'(P,M).
|
||||||
'$predicate_property'(P,M,_,meta_predicate(Q)) :-
|
'$predicate_property'(P,M,_,meta_predicate(Q)) :-
|
||||||
functor(P,Na,Ar),
|
functor(P,Na,Ar),
|
||||||
prolog:'$meta_predicate'(Na,M,Ar,Q).
|
prolog:'$meta_predicate'(Na,M,Ar,Q).
|
||||||
'$predicate_property'(P,M,_,multifile) :-
|
'$predicate_property'(P,M,_,multifile) :-
|
||||||
'$is_multifile'(P,M).
|
'$is_multifile'(P,M).
|
||||||
'$predicate_property'(P,M,_,public) :-
|
'$predicate_property'(P,M,_,public) :-
|
||||||
'$is_public'(P,M).
|
'$is_public'(P,M).
|
||||||
'$predicate_property'(P,M,_,thread_local) :-
|
'$predicate_property'(P,M,_,thread_local) :-
|
||||||
'$is_thread_local'(P,M).
|
'$is_thread_local'(P,M).
|
||||||
'$predicate_property'(P,M,M,exported) :-
|
'$predicate_property'(P,M,M,exported) :-
|
||||||
functor(P,N,A),
|
functor(P,N,A),
|
||||||
once(recorded('$module','$module'(_TFN,M,_S,Publics,_L),_)),
|
once(recorded('$module','$module'(_TFN,M,_S,Publics,_L),_)),
|
||||||
lists:memberchk(N/A,Publics).
|
lists:memberchk(N/A,Publics).
|
||||||
'$predicate_property'(P,M,M0,imported_from(M0)) :-
|
'$predicate_property'(P,M,M0,imported_from(M0)) :-
|
||||||
M \= M0.
|
M \= M0.
|
||||||
'$predicate_property'(P,Mod,_,number_of_clauses(NCl)) :-
|
'$predicate_property'(P,Mod,_,number_of_clauses(NCl)) :-
|
||||||
'$number_of_clauses'(P,Mod,NCl).
|
'$number_of_clauses'(P,Mod,NCl).
|
||||||
'$predicate_property'(P,Mod,_,file(F)) :-
|
'$predicate_property'(P,Mod,_,file(F)) :-
|
||||||
'$owner_file'(P,Mod,F).
|
'$owner_file'(P,Mod,F).
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -552,22 +552,22 @@ Given predicate _P_, _NCls_ is the number of clauses for
|
|||||||
indices to those clauses (in bytes).
|
indices to those clauses (in bytes).
|
||||||
*/
|
*/
|
||||||
predicate_statistics(V,NCls,Sz,ISz) :- var(V), !,
|
predicate_statistics(V,NCls,Sz,ISz) :- var(V), !,
|
||||||
'$do_error'(instantiation_error,predicate_statistics(V,NCls,Sz,ISz)).
|
'$do_error'(instantiation_error,predicate_statistics(V,NCls,Sz,ISz)).
|
||||||
predicate_statistics(P0,NCls,Sz,ISz) :-
|
predicate_statistics(P0,NCls,Sz,ISz) :-
|
||||||
strip_module(P0, M, P),
|
strip_module(P0, M, P),
|
||||||
'$predicate_statistics'(P,M,NCls,Sz,ISz).
|
'$predicate_statistics'(P,M,NCls,Sz,ISz).
|
||||||
|
|
||||||
'$predicate_statistics'(M:P,_,NCls,Sz,ISz) :- !,
|
'$predicate_statistics'(M:P,_,NCls,Sz,ISz) :- !,
|
||||||
'$predicate_statistics'(P,M,NCls,Sz,ISz).
|
'$predicate_statistics'(P,M,NCls,Sz,ISz).
|
||||||
'$predicate_statistics'(P,M,NCls,Sz,ISz) :-
|
'$predicate_statistics'(P,M,NCls,Sz,ISz) :-
|
||||||
'$is_log_updatable'(P, M), !,
|
'$is_log_updatable'(P, M), !,
|
||||||
'$lu_statistics'(P,NCls,Sz,ISz,M).
|
'$lu_statistics'(P,NCls,Sz,ISz,M).
|
||||||
'$predicate_statistics'(P,M,_,_,_) :-
|
'$predicate_statistics'(P,M,_,_,_) :-
|
||||||
'$is_system_predicate'(P,M), !, fail.
|
'$is_system_predicate'(P,M), !, fail.
|
||||||
'$predicate_statistics'(P,M,_,_,_) :-
|
'$predicate_statistics'(P,M,_,_,_) :-
|
||||||
'$undefined'(P,M), !, fail.
|
'$undefined'(P,M), !, fail.
|
||||||
'$predicate_statistics'(P,M,NCls,Sz,ISz) :-
|
'$predicate_statistics'(P,M,NCls,Sz,ISz) :-
|
||||||
'$static_pred_statistics'(P,M,NCls,Sz,ISz).
|
'$static_pred_statistics'(P,M,NCls,Sz,ISz).
|
||||||
|
|
||||||
/** @pred predicate_erased_statistics( _P_, _NCls_, _Sz_, _IndexSz_)
|
/** @pred predicate_erased_statistics( _P_, _NCls_, _Sz_, _IndexSz_)
|
||||||
|
|
||||||
@@ -580,36 +580,36 @@ of space required to store indices to those clauses (in bytes).
|
|||||||
*/
|
*/
|
||||||
predicate_erased_statistics(P,NCls,Sz,ISz) :-
|
predicate_erased_statistics(P,NCls,Sz,ISz) :-
|
||||||
var(P), !,
|
var(P), !,
|
||||||
current_predicate(_,P),
|
current_predicate(_,P),
|
||||||
predicate_erased_statistics(P,NCls,Sz,ISz).
|
predicate_erased_statistics(P,NCls,Sz,ISz).
|
||||||
predicate_erased_statistics(P0,NCls,Sz,ISz) :-
|
predicate_erased_statistics(P0,NCls,Sz,ISz) :-
|
||||||
strip_module(P0,M,P),
|
strip_module(P0,M,P),
|
||||||
'$predicate_erased_statistics'(M:P,NCls,Sz,_,ISz).
|
'$predicate_erased_statistics'(M:P,NCls,Sz,_,ISz).
|
||||||
|
|
||||||
/** @pred current_predicate( _A_, _P_)
|
/** @pred current_predicate( _A_, _P_)
|
||||||
|
|
||||||
Defines the relation: _P_ is a currently defined predicate whose name is the atom _A_.
|
Defines the relation: _P_ is a currently defined predicate whose name is the atom _A_.
|
||||||
*/
|
*/
|
||||||
current_predicate(A,T0) :-
|
current_predicate(A,T0) :-
|
||||||
'$yap_strip_module'(T0, M, T),
|
'$yap_strip_module'(T0, M, T),
|
||||||
( var(Mod)
|
( var(Mod)
|
||||||
->
|
->
|
||||||
'$all_current_modules'(M)
|
'$all_current_modules'(M)
|
||||||
;
|
;
|
||||||
true
|
true
|
||||||
),
|
),
|
||||||
(nonvar(T) -> functor(T, A, _) ; true ),
|
(nonvar(T) -> functor(T, A, _) ; true ),
|
||||||
(
|
(
|
||||||
'$current_predicate'(A,M, T, user)
|
'$current_predicate'(A,M, T, user)
|
||||||
;
|
;
|
||||||
(nonvar(T)
|
(nonvar(T)
|
||||||
->
|
->
|
||||||
'$imported_predicate'(T, M, T1, M1)
|
'$imported_predicate'(T, M, T1, M1)
|
||||||
;
|
;
|
||||||
'$generate_imported_predicate'(T, M, T1, M1)
|
'$generate_imported_predicate'(T, M, T1, M1)
|
||||||
),
|
),
|
||||||
functor(T1, A, _),
|
functor(T1, A, _),
|
||||||
\+ '$is_system_predicate'(T1,M1)
|
\+ '$is_system_predicate'(T1,M1)
|
||||||
).
|
).
|
||||||
|
|
||||||
/** @pred system_predicate( ?_P_ )
|
/** @pred system_predicate( ?_P_ )
|
||||||
@@ -617,7 +617,7 @@ current_predicate(A,T0) :-
|
|||||||
Defines the relation: indicator _P_ refers to a currently defined system predicate.
|
Defines the relation: indicator _P_ refers to a currently defined system predicate.
|
||||||
*/
|
*/
|
||||||
system_predicate(P0) :-
|
system_predicate(P0) :-
|
||||||
'$yap_strip_module'(P0, M0, P),
|
'$yap_strip_module'(P0, M0, P),
|
||||||
( M= M0 ; M0 \= user, M = user ; M0 \= prolog, M = prolog ),
|
( M= M0 ; M0 \= user, M = user ; M0 \= prolog, M = prolog ),
|
||||||
(
|
(
|
||||||
var(P)
|
var(P)
|
||||||
@@ -668,7 +668,7 @@ system_predicate(P0) :-
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
system_predicate(A, P0) :-
|
system_predicate(A, P0) :-
|
||||||
'$yap_strip_module'(P0, M, P),
|
'$yap_strip_module'(P0, M, P),
|
||||||
(
|
(
|
||||||
nonvar(P)
|
nonvar(P)
|
||||||
->
|
->
|
||||||
@@ -688,35 +688,35 @@ system_predicate(A, P0) :-
|
|||||||
_Na_ is the name of the predicate, and _Ar_ its arity.
|
_Na_ is the name of the predicate, and _Ar_ its arity.
|
||||||
*/
|
*/
|
||||||
current_predicate(F0) :-
|
current_predicate(F0) :-
|
||||||
'$yap_strip_module'(F0, M, F),
|
'$yap_strip_module'(F0, M, F),
|
||||||
must_bind_to_type( predicate_indicator, F ),
|
must_bind_to_type( predicate_indicator, F ),
|
||||||
'$c_i_predicate'( F, M ).
|
'$c_i_predicate'( F, M ).
|
||||||
|
|
||||||
'$c_i_predicate'( A/N, M ) :-
|
'$c_i_predicate'( A/N, M ) :-
|
||||||
!,
|
!,
|
||||||
(
|
(
|
||||||
ground(A/N)
|
ground(A/N)
|
||||||
->
|
->
|
||||||
atom(A), integer(N),
|
atom(A), integer(N),
|
||||||
functor(S, A, N),
|
functor(S, A, N),
|
||||||
current_predicate(A, M:S)
|
current_predicate(A, M:S)
|
||||||
;
|
;
|
||||||
current_predicate(A, M:S),
|
current_predicate(A, M:S),
|
||||||
functor(S, A, N)
|
functor(S, A, N)
|
||||||
).
|
).
|
||||||
'$c_i_predicate'( A//N, M ) :-
|
'$c_i_predicate'( A//N, M ) :-
|
||||||
(
|
(
|
||||||
ground(A)
|
ground(A)
|
||||||
->
|
->
|
||||||
atom(A), integer(N),
|
atom(A), integer(N),
|
||||||
N2 is N+2,
|
N2 is N+2,
|
||||||
functor(S, A, N2),
|
functor(S, A, N2),
|
||||||
current_predicate(A, M:S)
|
current_predicate(A, M:S)
|
||||||
;
|
;
|
||||||
current_predicate(A, M:S),
|
current_predicate(A, M:S),
|
||||||
functor(S, A, N2),
|
functor(S, A, N2),
|
||||||
N is N2-2
|
N is N2-2
|
||||||
).
|
).
|
||||||
|
|
||||||
/** @pred current_key(? _A_,? _K_)
|
/** @pred current_key(? _A_,? _K_)
|
||||||
|
|
||||||
@@ -726,17 +726,17 @@ name is the atom _A_. It can be used to generate all the keys for
|
|||||||
the internal data-base.
|
the internal data-base.
|
||||||
*/
|
*/
|
||||||
current_key(A,K) :-
|
current_key(A,K) :-
|
||||||
'$current_predicate'(A,idb,K,user).
|
'$current_predicate'(A,idb,K,user).
|
||||||
|
|
||||||
% do nothing for now.
|
% do nothing for now.
|
||||||
'$noprofile'(_, _).
|
'$noprofile'(_, _).
|
||||||
|
|
||||||
'$ifunctor'(Pred,Na,Ar) :-
|
'$ifunctor'(Pred,Na,Ar) :-
|
||||||
(Ar > 0 ->
|
(Ar > 0 ->
|
||||||
functor(Pred, Na, Ar)
|
functor(Pred, Na, Ar)
|
||||||
;
|
;
|
||||||
Pred = Na
|
Pred = Na
|
||||||
).
|
).
|
||||||
|
|
||||||
|
|
||||||
/** @pred compile_predicates(: _ListOfNameArity_)
|
/** @pred compile_predicates(: _ListOfNameArity_)
|
||||||
@@ -752,68 +752,69 @@ of the program that is generated at runtime but does not change during
|
|||||||
the remainder of the program execution.
|
the remainder of the program execution.
|
||||||
*/
|
*/
|
||||||
compile_predicates(Ps) :-
|
compile_predicates(Ps) :-
|
||||||
'$current_module'(Mod),
|
'$current_module'(Mod),
|
||||||
'$compile_predicates'(Ps, Mod, compile_predicates(Ps)).
|
'$compile_predicates'(Ps, Mod, compile_predicates(Ps)).
|
||||||
|
|
||||||
'$compile_predicates'(V, _, Call) :-
|
'$compile_predicates'(V, _, Call) :-
|
||||||
var(V), !,
|
var(V), !,
|
||||||
'$do_error'(instantiation_error,Call).
|
'$do_error'(instantiation_error,Call).
|
||||||
'$compile_predicates'(M:Ps, _, Call) :-
|
'$compile_predicates'(M:Ps, _, Call) :-
|
||||||
'$compile_predicates'(Ps, M, Call).
|
'$compile_predicates'(Ps, M, Call).
|
||||||
'$compile_predicates'([], _, _).
|
'$compile_predicates'([], _, _).
|
||||||
'$compile_predicates'([P|Ps], M, Call) :-
|
'$compile_predicates'([P|Ps], M, Call) :-
|
||||||
'$compile_predicate'(P, M, Call),
|
'$compile_predicate'(P, M, Call),
|
||||||
'$compile_predicates'(Ps, M, Call).
|
'$compile_predicates'(Ps, M, Call).
|
||||||
|
|
||||||
'$compile_predicate'(P, _M, Call) :-
|
'$compile_predicate'(P, _M, Call) :-
|
||||||
var(P), !,
|
var(P), !,
|
||||||
'$do_error'(instantiation_error,Call).
|
'$do_error'(instantiation_error,Call).
|
||||||
'$compile_predicate'(M:P, _, Call) :-
|
'$compile_predicate'(M:P, _, Call) :-
|
||||||
'$compile_predicate'(P, M, Call).
|
'$compile_predicate'(P, M, Call).
|
||||||
'$compile_predicate'(Na/Ar, Mod, _Call) :-
|
'$compile_predicate'(Na/Ar, Mod, _Call) :-
|
||||||
functor(G, Na, Ar),
|
functor(G, Na, Ar),
|
||||||
findall([G|B],clause(Mod:G,B),Cls),
|
findall([G|B],clause(Mod:G,B),Cls),
|
||||||
abolish(Mod:Na,Ar),
|
abolish(Mod:Na,Ar),
|
||||||
'$add_all'(Cls, Mod).
|
'$add_all'(Cls, Mod).
|
||||||
|
|
||||||
'$add_all'([], _).
|
'$add_all'([], _).
|
||||||
'$add_all'([[G|B]|Cls], Mod) :-
|
'$add_all'([[G|B]|Cls], Mod) :-
|
||||||
assert_static(Mod:(G:-B)),
|
assert_static(Mod:(G:-B)),
|
||||||
'$add_all'(Cls, Mod).
|
'$add_all'(Cls, Mod).
|
||||||
|
|
||||||
|
|
||||||
clause_property(ClauseRef, file(FileName)) :-
|
clause_property(ClauseRef, file(FileName)) :-
|
||||||
( recorded('$mf','$mf_clause'(FileName,_Name,_Arity,_Module,ClauseRef),_R)
|
( recorded('$mf','$mf_clause'(FileName,_Name,_Arity,_Module,ClauseRef),_R)
|
||||||
-> true
|
-> true
|
||||||
;
|
;
|
||||||
instance_property(ClauseRef, 2, FileName) ).
|
instance_property(ClauseRef, 2, FileName) ).
|
||||||
clause_property(ClauseRef, source(FileName)) :-
|
clause_property(ClauseRef, source(FileName)) :-
|
||||||
( recorded('$mf','$mf_clause'(FileName,_Name,_Arity,_Module,ClauseRef),_R)
|
( recorded('$mf','$mf_clause'(FileName,_Name,_Arity,_Module,ClauseRef),_R)
|
||||||
-> true
|
-> true
|
||||||
;
|
;
|
||||||
instance_property(ClauseRef, 2, FileName) ).
|
instance_property(ClauseRef, 2, FileName) ).
|
||||||
clause_property(ClauseRef, line_count(LineNumber)) :-
|
clause_property(ClauseRef, line_count(LineNumber)) :-
|
||||||
instance_property(ClauseRef, 4, LineNumber),
|
instance_property(ClauseRef, 4, LineNumber),
|
||||||
LineNumber > 0.
|
LineNumber > 0.
|
||||||
clause_property(ClauseRef, fact) :-
|
clause_property(ClauseRef, fact) :-
|
||||||
instance_property(ClauseRef, 3, true).
|
instance_property(ClauseRef, 3, true).
|
||||||
clause_property(ClauseRef, erased) :-
|
clause_property(ClauseRef, erased) :-
|
||||||
instance_property(ClauseRef, 0, true).
|
instance_property(ClauseRef, 0, true).
|
||||||
clause_property(ClauseRef, predicate(PredicateIndicator)) :-
|
clause_property(ClauseRef, predicate(PredicateIndicator)) :-
|
||||||
instance_property(ClauseRef, 1, PredicateIndicator).
|
instance_property(ClauseRef, 1, PredicateIndicator).
|
||||||
|
|
||||||
'$set_predicate_attribute'(M:N/Ar, Flag, V) :-
|
'$set_predicate_attribute'(M:N/Ar, Flag, V) :-
|
||||||
functor(P, N, Ar),
|
functor(P, N, Ar),
|
||||||
'$set_flag'(P, M, Flag, V).
|
'$set_flag'(P, M, Flag, V).
|
||||||
|
|
||||||
%% '$set_flag'(P, M, trace, off) :-
|
%% '$set_flag'(P, M, trace, off) :-
|
||||||
% set a predicate flag
|
% set a predicate flag
|
||||||
%
|
%
|
||||||
'$set_flag'(P, M, trace, off) :-
|
'$set_flag'(P, M, trace, off) :-
|
||||||
'$predicate_flags'(P,M,F,F),
|
'$predicate_flags'(P,M,F,F),
|
||||||
FN is F \/ 0x400000000,
|
FN is F \/ 0x400000000,
|
||||||
'$predicate_flags'(P,M,F,FN).
|
'$predicate_flags'(P,M,F,FN).
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@}
|
@}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user