memory
This commit is contained in:
parent
c4a0d5766b
commit
4fe08fd82a
@ -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);
|
||||||
|
2
C/exec.c
2
C/exec.c
@ -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);
|
||||||
}
|
}
|
||||||
|
35
CXX/yapi.cpp
35
CXX/yapi.cpp
@ -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();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
12
H/YapText.h
12
H/YapText.h
@ -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);
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
25
os/iopreds.c
25
os/iopreds.c
@ -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);
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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()
|
||||||
|
@ -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")
|
||||||
|
Reference in New Issue
Block a user