This commit is contained in:
Vítor Santos Costa 2018-05-26 00:22:27 +01:00
parent c4a0d5766b
commit 4fe08fd82a
10 changed files with 68 additions and 61 deletions

View File

@ -1738,6 +1738,8 @@ X_API bool YAP_EnterGoal(YAP_PredEntryPtr ape, CELL *ptr, YAP_dogoalinfo *dgi) {
// slot=%d", pe, pe->CodeOfPred->opc, FAILCODE, Deref(ARG1), Deref(ARG2), // slot=%d", pe, pe->CodeOfPred->opc, FAILCODE, Deref(ARG1), Deref(ARG2),
// LOCAL_CurSlot); // LOCAL_CurSlot);
dgi->b = dgi->b0 = LCL0 - (CELL *)B; dgi->b = dgi->b0 = LCL0 - (CELL *)B;
dgi->h = HR-H0;
dgi->tr = (CELL*)TR-LCL0;
fprintf(stderr,"PrepGoal: H=%d ENV=%p B=%d TR=%d P=%p CP=%p Slots=%d\n", fprintf(stderr,"PrepGoal: H=%d ENV=%p B=%d TR=%d P=%p CP=%p Slots=%d\n",
HR-H0,LCL0-ENV,LCL0-(CELL*)B,(CELL*)TR-LCL0, P, CP, LOCAL_CurSlot); HR-H0,LCL0-ENV,LCL0-(CELL*)B,(CELL*)TR-LCL0, P, CP, LOCAL_CurSlot);
out = Yap_exec_absmi(true, false); out = Yap_exec_absmi(true, false);

View File

@ -1513,7 +1513,6 @@ static bool exec_absmi(bool top, yap_reset_t reset_mode USES_REGS) {
Yap_JumpToEnv(); Yap_JumpToEnv();
Yap_CloseTemporaryStreams(); Yap_CloseTemporaryStreams();
Yap_CloseSlots(sls); Yap_CloseSlots(sls);
pop_text_stack(i);
ASP = (CELL *) PROTECT_FROZEN_B(B); ASP = (CELL *) PROTECT_FROZEN_B(B);
if (B == NULL || B->cp_b == NULL || (CELL*)(B->cp_b) > LCL0 - LOCAL_CBorder) { if (B == NULL || B->cp_b == NULL || (CELL*)(B->cp_b) > LCL0 - LOCAL_CBorder) {
@ -2092,7 +2091,6 @@ static Int JumpToEnv(USES_REGS1) {
handler->cp_ap = TRUSTFAILCODE; handler->cp_ap = TRUSTFAILCODE;
handler = handler->cp_b; handler = handler->cp_b;
} }
pop_text_stack(1);
if (LOCAL_PrologMode & AsyncIntMode) { if (LOCAL_PrologMode & AsyncIntMode) {
Yap_signal(YAP_FAIL_SIGNAL); Yap_signal(YAP_FAIL_SIGNAL);
} }

View File

@ -477,6 +477,8 @@ const char *YAPAtom::getName(void) { return Yap_AtomToUTF8Text(a); }
void YAPQuery::openQuery() { void YAPQuery::openQuery() {
CACHE_REGS CACHE_REGS
lvl = AllocLevel();
if (ap == NULL || ap->OpcodeOfPred == UNDEF_OPCODE) { if (ap == NULL || ap->OpcodeOfPred == UNDEF_OPCODE) {
ap = rewriteUndefQuery(); ap = rewriteUndefQuery();
} }
@ -492,13 +494,13 @@ bool YAPEngine::call(YAPPredicate ap, YAPTerm ts[]) {
bool result; bool result;
YAP_dogoalinfo q; YAP_dogoalinfo q;
for (arity_t i = 0; i < arity; i++)
XREGS[i + 1] = ts[i].term();
q.CurSlot = Yap_StartSlots(); q.CurSlot = Yap_StartSlots();
q.p = P; q.p = P;
q.cp = CP; q.cp = CP;
for (arity_t i = 0; i < arity; i++)
XREGS[i + 1] = ts[i].term();
// allow Prolog style exceotion handling // allow Prolog style exceotion handling
// don't forget, on success these bindings will still be there); // don't forget, on success these bindings will still be there);
result = YAP_LeaveGoal(true, &q); result = YAP_LeaveGoal(true, &q);
@ -506,6 +508,7 @@ bool YAPEngine::call(YAPPredicate ap, YAPTerm ts[]) {
YAPCatchError(); YAPCatchError();
Yap_CloseHandles(q.CurSlot); Yap_CloseHandles(q.CurSlot);
pop_text_stack(q.lvl+1);
RECOVER_MACHINE_REGS(); RECOVER_MACHINE_REGS();
return result; return result;
} }
@ -519,6 +522,9 @@ bool YAPEngine::mgoal(Term t, Term tmod, bool release) {
CACHE_REGS CACHE_REGS
BACKUP_MACHINE_REGS(); BACKUP_MACHINE_REGS();
Term *ts = nullptr; Term *ts = nullptr;
q.CurSlot = Yap_StartSlots();
q.p = P;
q.cp = CP;
try { try {
if (IsStringTerm(tmod)) if (IsStringTerm(tmod))
tmod = MkAtomTerm(Yap_LookupAtom(StringOfTerm(tmod))); tmod = MkAtomTerm(Yap_LookupAtom(StringOfTerm(tmod)));
@ -540,9 +546,6 @@ bool YAPEngine::mgoal(Term t, Term tmod, bool release) {
} }
ts = nullptr; ts = nullptr;
bool result; bool result;
q.CurSlot = Yap_StartSlots();
q.p = P;
q.cp = CP;
// allow Prolog style exception handling // allow Prolog style exception handling
// don't forget, on success these guys may create slots // don't forget, on success these guys may create slots
__android_log_print(ANDROID_LOG_INFO, "YAPDroid", "exec "); __android_log_print(ANDROID_LOG_INFO, "YAPDroid", "exec ");
@ -1041,20 +1044,18 @@ std::stringstream s;
void YAPEngine::reSet() { void YAPEngine::reSet() {
/* ignore flags for now */ /* ignore flags for now */
BACKUP_MACHINE_REGS(); BACKUP_MACHINE_REGS();
Yap_RebootHandles(worker_id);
while (B && B->cp_b) choiceptr b = (choiceptr)(LCL0-q.b);
B = B->cp_b; if (b > B) B = b;
if (B) {
P = FAILCODE; P = FAILCODE;
Yap_exec_absmi(true, YAP_EXEC_ABSMI); Yap_exec_absmi(true, YAP_EXEC_ABSMI);
/* recover stack space */ /* recover stack space */
HR = B->cp_h; LOCAL_ActiveError->errorNo = YAP_NO_ERROR;
TR = B->cp_tr; if (H0+q.h < HR)
#ifdef DEPTH_LIMIT HR = H0+q.h;
DEPTH = B->cp_depth; if (LCL0+q.tr < (CELL*)TR)
#endif /* DEPTH_LIMIT */ TR = (tr_fr_ptr)(LCL0+q.tr);
YENV = ENV = B->cp_env; Yap_CloseHandles( q.CurSlot );
}
RECOVER_MACHINE_REGS(); RECOVER_MACHINE_REGS();
} }

View File

@ -45,6 +45,7 @@ class X_API YAPQuery : public YAPPredicate {
YAPPairTerm names; YAPPairTerm names;
YAPTerm goal; YAPTerm goal;
// temporaries // temporaries
int lvl;
YAPError *e; YAPError *e;
inline void setNext() { // oq = LOCAL_execution; inline void setNext() { // oq = LOCAL_execution;
@ -338,7 +339,7 @@ public:
/// current directory for the engine /// current directory for the engine
bool call(YAPPredicate ap, YAPTerm ts[]); bool call(YAPPredicate ap, YAPTerm ts[]);
/// current directory for the engine /// current directory for the engine
bool goal(YAPTerm Yt, YAPModule module) { return mgoal(Yt.term(),module.term()); }; bool goal(YAPTerm Yt, YAPModule module, bool release=false) { return mgoal(Yt.term(),module.term(), release); };
/// ru1n a goal in a module. /// ru1n a goal in a module.
/// ///
/// By default, memory will only be fully /// By default, memory will only be fully

View File

@ -52,20 +52,20 @@ extern const void *MallocExportAsRO(const void *blk);
extern int AllocLevel(void); extern int AllocLevel(void);
#define push_text_stack() \ #define push_text_stack() \
(/* fprintf(stderr, "^ %*c %s:%s:%d\n", AllocLevel(), AllocLevel()+'0', \ (/* fprintf(stderr, " + *** %d %s:%s:%d\n", AllocLevel(),*/ \
__FILE__, __FUNCTION__, __LINE__), */ \ /* __FILE__, __FUNCTION__, __LINE__), */ \
push_text_stack__(PASS_REGS1)) push_text_stack__(PASS_REGS1))
extern int push_text_stack__(USES_REGS1); extern int push_text_stack__(USES_REGS1);
#define pop_text_stack(lvl) \ #define pop_text_stack(lvl) \
(/*fprintf(stderr, "v %*c %s:%s:%d\n", AllocLevel(), ' ', __FILE__, \ (/* fprintf(stderr, " - *** %d %s:%s:%d\n", AllocLevel(), __FILE__,*/ \
__FUNCTION__, __LINE__),*/ \ /* __FUNCTION__, __LINE__), */ \
pop_text_stack__(lvl)) pop_text_stack__(lvl))
extern int pop_text_stack__(int lvl USES_REGS); extern int pop_text_stack__(int lvl USES_REGS);
#define pop_output_text_stack(lvl,p) \ #define pop_output_text_stack(lvl,p) \
(/*fprintf(stderr, "v %*c %s:%s:%d\n", AllocLevel(), ' ', __FILE__, \ (/*fprintf(stderr, "-- *** %d %s:%s:%d\n", AllocLevel(), __FILE__,*/ \
__FUNCTION__, __LINE__),*/ \ /* __FUNCTION__, __LINE__),*/ \
pop_output_text_stack__(lvl,p)) pop_output_text_stack__(lvl,p))
extern void *pop_output_text_stack__(int lvl, const void *ox USES_REGS); extern void *pop_output_text_stack__(int lvl, const void *ox USES_REGS);

View File

@ -297,6 +297,8 @@ typedef struct {
YAP_handle_t EndSlot; //> variables at successful execution YAP_handle_t EndSlot; //> variables at successful execution
struct yami *p; //> Program Counter at entry struct yami *p; //> Program Counter at entry
struct yami *cp; //> Continuation PC at entry struct yami *cp; //> Continuation PC at entry
int lvl;
unsigned long tr, h;
} YAP_dogoalinfo; } YAP_dogoalinfo;
// query manipulation support // query manipulation support

View File

@ -1583,9 +1583,18 @@ int Yap_OpenStream(Term tin, const char *io_mode, Term user_name,
UNLOCK(st->streamlock); UNLOCK(st->streamlock);
} else { } else {
st->file = fopen(fname, io_mode); st->file = fopen(fname, io_mode);
if (st->file == NULL) {
UNLOCK(st->streamlock);
if (errno == ENOENT && !strchr(io_mode, 'r')) {
PlIOError(EXISTENCE_ERROR_SOURCE_SINK, tin, "%s: %s", fname,
strerror(errno));
} else {
PlIOError(PERMISSION_ERROR_OPEN_SOURCE_SINK, tin, "%s: %s", fname,
strerror(errno));
} }
if (!st->file) { }
fprintf(stderr, "trying %s\n", fname); }
if (!st->file && !st->vfs) {
PlIOError(EXISTENCE_ERROR_SOURCE_SINK, tin, "%s", fname); PlIOError(EXISTENCE_ERROR_SOURCE_SINK, tin, "%s", fname);
/* extract BACK info passed through the stream descriptor */ /* extract BACK info passed through the stream descriptor */
return -1; return -1;
@ -1629,18 +1638,8 @@ int Yap_OpenStream(Term tin, const char *io_mode, Term user_name,
pop_text_stack(i); pop_text_stack(i);
} }
} }
if (st->file == NULL) {
if (!strchr(io_mode, 'b') && binary_file(fname)) { if (!strchr(io_mode, 'b') && binary_file(fname)) {
UNLOCK(st->streamlock); flags |= Binary_Stream_f;
if (errno == ENOENT && !strchr(io_mode, 'r')) {
PlIOError(EXISTENCE_ERROR_SOURCE_SINK, tin, "%s: %s", fname,
strerror(errno));
} else {
PlIOError(PERMISSION_ERROR_OPEN_SOURCE_SINK, tin, "%s: %s", fname,
strerror(errno));
}
}
return -1;
} }
Yap_initStream(sno, st->file, fname, io_mode, user_name, LOCAL_encoding, Yap_initStream(sno, st->file, fname, io_mode, user_name, LOCAL_encoding,
flags, vfsp); flags, vfsp);

View File

@ -69,6 +69,7 @@ static void *py_open(VFS_t *me, const char *name, const char *io_mode,
} }
st->u.private_data = pystream; st->u.private_data = pystream;
st->vfs = me; st->vfs = me;
st->file = NULL;
python_release_GIL(ctk); python_release_GIL(ctk);
return st; return st;
} }

View File

@ -30,15 +30,15 @@ class Engine( YAPEngine ):
args.setYapPLDIR(yap_lib_path) args.setYapPLDIR(yap_lib_path)
args.setSavedState(join(yap_lib_path, "startup.yss")) args.setSavedState(join(yap_lib_path, "startup.yss"))
YAPEngine.__init__(self, args) YAPEngine.__init__(self, args)
self.goal(set_prolog_flag('verbose', 'silent'), recover=True) self.goal(set_prolog_flag('verbose', 'silent'),True)
self.goal(compile(library('yapi')), recover=True) self.goal(compile(library('yapi')), True)
self.goal(set_prolog_flag('verbose', 'normal'), release=True) self.goal(set_prolog_flag('verbose', 'normal'), True)
def run(self, g, m=None, release=False): def run(self, g, m=None, release=False):
if m: if m:
self.mgoal(g, m, release=release) self.mgoal(g, m, release)
else: else:
self.goal(release=release) self.goal(release)
class EngineArgs( YAPEngineArgs ): class EngineArgs( YAPEngineArgs ):
@ -56,6 +56,7 @@ class Predicate( YAPPredicate ):
class Query: class Query:
"""Goal is a predicate instantiated under a specific environment """ """Goal is a predicate instantiated under a specific environment """
def __init__(self, engine, g): def __init__(self, engine, g):
engine.reSet();
self.q = engine.query(g) self.q = engine.query(g)
if self.q: if self.q:
self.port = "call" self.port = "call"
@ -79,6 +80,8 @@ class Query:
raise StopIteration() raise StopIteration()
def close( self ): def close( self ):
engine.reSet()
if self.q:
self.q.close() self.q.close()
self.q = None self.q = None
@ -108,7 +111,7 @@ class YAPShell:
def numbervars( self ): def numbervars( self ):
Dict = {} Dict = {}
self.engine.goal(show_answer( self, Dict)) self.engine.goal(show_answer( self, Dict), True)
return Dict return Dict
# rc = self.q.namedVarsVector() # rc = self.q.namedVarsVector()
# self.q.r = self.q.goal().numbervars() # self.q.r = self.q.goal().numbervars()

View File

@ -112,7 +112,7 @@ class YAPInputSplitter(InputSplitter):
if not line: if not line:
line = text.rstrip() line = text.rstrip()
self.errors = [] self.errors = []
engine.mgoal(errors(self, line),"user") engine.mgoal(errors(self, line),"user",True)
return self.errors != [] return self.errors != []
@ -494,7 +494,7 @@ class YAPCompleter(Completer):
ensure that each completion object will only be present once. ensure that each completion object will only be present once.
""" """
self.matches = [] self.matches = []
prolog_res = self.shell.yapeng.mgoal(completions(text, self), "user") prolog_res = self.shell.yapeng.mgoal(completions(text, self), "user",True)
if self.matches: if self.matches:
return text, self.matches return text, self.matches
magic_res = self.magic_matches(text) magic_res = self.magic_matches(text)
@ -511,7 +511,7 @@ class YAPRun:
self.yapeng = Engine() self.yapeng = Engine()
global engine global engine
engine = self.yapeng engine = self.yapeng
self.yapeng.goal(use_module(library("jupyter"))) self.yapeng.goal(use_module(library("jupyter")),True)
self.query = None self.query = None
self.os = None self.os = None
self.it = None self.it = None
@ -527,7 +527,7 @@ class YAPRun:
return self.errors return self.errors
self.errors=[] self.errors=[]
(text,_,_,_) = self.clean_end(text) (text,_,_,_) = self.clean_end(text)
self.yapeng.mgoal(errors(self,text),"user") self.yapeng.mgoal(errors(self,text),"user",True)
return self.errors return self.errors
def jupyter_query(self, s): def jupyter_query(self, s):
@ -724,10 +724,10 @@ class YAPRun:
# run the new command using the given tracer # run the new command using the given tracer
# #
try: try:
self.yapeng.mgoal(streams(True),"user") self.yapeng.mgoal(streams(True),"user", True)
#state = tracer.runfunc(f,self,cell) #state = tracer.runfunc(f,self,cell)
state = self.jupyter_query( cell ) state = self.jupyter_query( cell )
self.yapeng.mgoal(streams(False),"user") self.yapeng.mgoal(streams(False),"user", True)
except Exception as e: except Exception as e:
has_raised = True has_raised = True
self.yapeng.mgoal(streams("off"),"user") self.yapeng.mgoal(streams("off"),"user")