fixes for indexing code.
git-svn-id: https://yap.svn.sf.net/svnroot/yap/trunk@2099 b08c6af1-5177-4d33-ba66-4b1c6b8b522a
This commit is contained in:
parent
6d4edaa609
commit
ca67a28a0c
18
C/index.c
18
C/index.c
@ -11,8 +11,11 @@
|
|||||||
* File: index.c *
|
* File: index.c *
|
||||||
* comments: Indexing a Prolog predicate *
|
* comments: Indexing a Prolog predicate *
|
||||||
* *
|
* *
|
||||||
* Last rev: $Date: 2008-01-30 10:35:43 $,$Author: vsc $ *
|
* Last rev: $Date: 2008-02-14 14:35:13 $,$Author: vsc $ *
|
||||||
* $Log: not supported by cvs2svn $
|
* $Log: not supported by cvs2svn $
|
||||||
|
* Revision 1.196 2008/01/30 10:35:43 vsc
|
||||||
|
* fix indexing in 64 bits (it would split ints from atoms :( ).
|
||||||
|
*
|
||||||
* Revision 1.195 2008/01/24 10:20:42 vsc
|
* Revision 1.195 2008/01/24 10:20:42 vsc
|
||||||
* clause should not try to discover who is fail.
|
* clause should not try to discover who is fail.
|
||||||
*
|
*
|
||||||
@ -3391,6 +3394,9 @@ valid_instructions(yamop *end, yamop *cl)
|
|||||||
case _pop_n:
|
case _pop_n:
|
||||||
cl = NEXTOP(cl,s);
|
cl = NEXTOP(cl,s);
|
||||||
break;
|
break;
|
||||||
|
case _procceed:
|
||||||
|
/* we have reached the end of code for a legal clause */
|
||||||
|
return TRUE;
|
||||||
default:
|
default:
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
@ -3488,12 +3494,15 @@ emit_trust(ClauseDef *cl, struct intermediates *cint, UInt nxtlbl, int clauses)
|
|||||||
|
|
||||||
if (ap->PredFlags & TabledPredFlag)
|
if (ap->PredFlags & TabledPredFlag)
|
||||||
clcode = NEXTOP(clcode, ld);
|
clcode = NEXTOP(clcode, ld);
|
||||||
|
if (!(ap->PredFlags & LogUpdatePredFlag)) {
|
||||||
|
/* this should not be generated for logical update predicates!! */
|
||||||
if (ap->PredFlags & ProfiledPredFlag) {
|
if (ap->PredFlags & ProfiledPredFlag) {
|
||||||
Yap_emit(retry_profiled_op, Unsigned(ap), Zero, cint);
|
Yap_emit(retry_profiled_op, Unsigned(ap), Zero, cint);
|
||||||
}
|
}
|
||||||
if (ap->PredFlags & CountPredFlag) {
|
if (ap->PredFlags & CountPredFlag) {
|
||||||
Yap_emit(count_retry_op, Unsigned(ap), Zero, cint);
|
Yap_emit(count_retry_op, Unsigned(ap), Zero, cint);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if (clauses == 0) {
|
if (clauses == 0) {
|
||||||
Yap_emit(trust_op, (CELL)clcode, has_cut(cl->CurrentCode) , cint);
|
Yap_emit(trust_op, (CELL)clcode, has_cut(cl->CurrentCode) , cint);
|
||||||
} else {
|
} else {
|
||||||
@ -3510,12 +3519,15 @@ emit_retry(ClauseDef *cl, struct intermediates *cint, int clauses)
|
|||||||
|
|
||||||
if (ap->PredFlags & TabledPredFlag)
|
if (ap->PredFlags & TabledPredFlag)
|
||||||
clcode = NEXTOP(clcode, ld);
|
clcode = NEXTOP(clcode, ld);
|
||||||
|
if (!(ap->PredFlags & LogUpdatePredFlag)) {
|
||||||
|
/* this should not be generated for logical update predicates!! */
|
||||||
if (ap->PredFlags & ProfiledPredFlag) {
|
if (ap->PredFlags & ProfiledPredFlag) {
|
||||||
Yap_emit(retry_profiled_op, Unsigned(ap), Zero, cint);
|
Yap_emit(retry_profiled_op, Unsigned(ap), Zero, cint);
|
||||||
}
|
}
|
||||||
if (ap->PredFlags & CountPredFlag) {
|
if (ap->PredFlags & CountPredFlag) {
|
||||||
Yap_emit(count_retry_op, Unsigned(ap), Zero, cint);
|
Yap_emit(count_retry_op, Unsigned(ap), Zero, cint);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
Yap_emit(retry_op, (CELL)clcode, (clauses << 1) | has_cut(cl->CurrentCode), cint);
|
Yap_emit(retry_op, (CELL)clcode, (clauses << 1) | has_cut(cl->CurrentCode), cint);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -6858,9 +6870,9 @@ add_to_index(struct intermediates *cint, int first, path_stack_entry *sp, Clause
|
|||||||
icl = ipc->u.Ill.I;
|
icl = ipc->u.Ill.I;
|
||||||
if (first) {
|
if (first) {
|
||||||
if (ap->PredFlags & CountPredFlag)
|
if (ap->PredFlags & CountPredFlag)
|
||||||
ipc->opc = Yap_opcode(_count_retry_logical);
|
ipc->u.Ill.l1->opc = Yap_opcode(_count_retry_logical);
|
||||||
else if (ap->PredFlags & ProfiledPredFlag)
|
else if (ap->PredFlags & ProfiledPredFlag)
|
||||||
ipc->opc = Yap_opcode(_profiled_retry_logical);
|
ipc->u.Ill.l1->opc = Yap_opcode(_profiled_retry_logical);
|
||||||
else
|
else
|
||||||
ipc->u.Ill.l1->opc = Yap_opcode(_retry_logical);
|
ipc->u.Ill.l1->opc = Yap_opcode(_retry_logical);
|
||||||
ipc->u.Ill.l1 = add_try(ap, cls, ipc->u.Ill.l1, cint);
|
ipc->u.Ill.l1 = add_try(ap, cls, ipc->u.Ill.l1, cint);
|
||||||
|
@ -17,6 +17,10 @@ xb
|
|||||||
|
|
||||||
<h2>Yap-5.1.3:</h2>
|
<h2>Yap-5.1.3:</h2>
|
||||||
<ul>
|
<ul>
|
||||||
|
<li> FIXED: indexing code could not see end of static clause (obs from
|
||||||
|
Lisa Torrey).</li>
|
||||||
|
<li> FIXED: indexing code for dynamic predicates was broken with
|
||||||
|
profiling (obs from Lisa Torrey).</li>
|
||||||
<li> NEW: time_file/2 (SWI-compatibility).</li>
|
<li> NEW: time_file/2 (SWI-compatibility).</li>
|
||||||
<li> NEW: module_transparent declaration (SWI-compatibility).</li>
|
<li> NEW: module_transparent declaration (SWI-compatibility).</li>
|
||||||
<li> NEW: strip_module/3 (SWI-compatibility).</li>
|
<li> NEW: strip_module/3 (SWI-compatibility).</li>
|
||||||
|
Reference in New Issue
Block a user