improve the interface a bit more.
git-svn-id: https://yap.svn.sf.net/svnroot/yap/trunk@476 b08c6af1-5177-4d33-ba66-4b1c6b8b522a
This commit is contained in:
parent
17728f58f5
commit
008cd709a1
149
C/c_interface.c
149
C/c_interface.c
@ -106,6 +106,7 @@ X_API int STD_PROTO(YapStreamToFileNo, (Term));
|
|||||||
X_API void STD_PROTO(YapCloseAllOpenStreams,(void));
|
X_API void STD_PROTO(YapCloseAllOpenStreams,(void));
|
||||||
X_API Term STD_PROTO(YapOpenStream,(void *, char *, Term, int));
|
X_API Term STD_PROTO(YapOpenStream,(void *, char *, Term, int));
|
||||||
X_API long STD_PROTO(YapNewSlots,(int));
|
X_API long STD_PROTO(YapNewSlots,(int));
|
||||||
|
X_API long STD_PROTO(YapInitSlot,(Term));
|
||||||
X_API Term STD_PROTO(YapGetFromSlot,(long));
|
X_API Term STD_PROTO(YapGetFromSlot,(long));
|
||||||
X_API Term *STD_PROTO(YapAddressFromSlot,(long));
|
X_API Term *STD_PROTO(YapAddressFromSlot,(long));
|
||||||
X_API void STD_PROTO(YapPutInSlot,(long, Term));
|
X_API void STD_PROTO(YapPutInSlot,(long, Term));
|
||||||
@ -421,15 +422,64 @@ YapUnify(Term t1, Term t2)
|
|||||||
return(out);
|
return(out);
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef Int (*CPredicate1)(Term);
|
X_API long
|
||||||
typedef Int (*CPredicate2)(Term,Term);
|
YapNewSlots(int n)
|
||||||
typedef Int (*CPredicate3)(Term,Term,Term);
|
{
|
||||||
typedef Int (*CPredicate4)(Term,Term,Term,Term);
|
Int old_slots = IntOfTerm(ASP[0]), oldn = n;
|
||||||
typedef Int (*CPredicate5)(Term,Term,Term,Term,Term);
|
while (n > 0) {
|
||||||
typedef Int (*CPredicate6)(Term,Term,Term,Term,Term,Term);
|
RESET_VARIABLE(ASP);
|
||||||
typedef Int (*CPredicate7)(Term,Term,Term,Term,Term,Term,Term);
|
ASP--;
|
||||||
typedef Int (*CPredicate8)(Term,Term,Term,Term,Term,Term,Term,Term);
|
n--;
|
||||||
|
}
|
||||||
|
ASP[0] = MkIntTerm(old_slots+oldn);
|
||||||
|
return((ASP+1)-LCL0);
|
||||||
|
}
|
||||||
|
|
||||||
|
X_API long
|
||||||
|
YapInitSlot(Term t)
|
||||||
|
{
|
||||||
|
Int old_slots = IntOfTerm(ASP[0]);
|
||||||
|
*ASP = t;
|
||||||
|
ASP--;
|
||||||
|
ASP[0] = MkIntTerm(old_slots+1);
|
||||||
|
return((ASP+1)-LCL0);
|
||||||
|
}
|
||||||
|
|
||||||
|
X_API void
|
||||||
|
YapRecoverSlots(int n)
|
||||||
|
{
|
||||||
|
Int old_slots = IntOfTerm(ASP[0]);
|
||||||
|
ASP += n;
|
||||||
|
ASP[0] = MkIntTerm(old_slots-n);
|
||||||
|
}
|
||||||
|
|
||||||
|
X_API Term
|
||||||
|
YapGetFromSlot(long slot)
|
||||||
|
{
|
||||||
|
return(Deref(LCL0[slot]));
|
||||||
|
}
|
||||||
|
|
||||||
|
X_API Term *
|
||||||
|
YapAddressFromSlot(long slot)
|
||||||
|
{
|
||||||
|
return(LCL0+slot);
|
||||||
|
}
|
||||||
|
|
||||||
|
X_API void
|
||||||
|
YapPutInSlot(long slot, Term t)
|
||||||
|
{
|
||||||
|
LCL0[slot] = t;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
typedef Int (*CPredicate1)(long);
|
||||||
|
typedef Int (*CPredicate2)(long,long);
|
||||||
|
typedef Int (*CPredicate3)(long,long,long);
|
||||||
|
typedef Int (*CPredicate4)(long,long,long,long);
|
||||||
|
typedef Int (*CPredicate5)(long,long,long,long,long);
|
||||||
|
typedef Int (*CPredicate6)(long,long,long,long,long,long);
|
||||||
|
typedef Int (*CPredicate7)(long,long,long,long,long,long,long);
|
||||||
|
typedef Int (*CPredicate8)(long,long,long,long,long,long,long,long);
|
||||||
|
|
||||||
Int
|
Int
|
||||||
YapExecute(PredEntry *pe)
|
YapExecute(PredEntry *pe)
|
||||||
@ -445,42 +495,69 @@ YapExecute(PredEntry *pe)
|
|||||||
case 1:
|
case 1:
|
||||||
{
|
{
|
||||||
CPredicate1 code1 = (CPredicate1)code;
|
CPredicate1 code1 = (CPredicate1)code;
|
||||||
return ((code1)(Deref(ARG1)));
|
return ((code1)(YapInitSlot(Deref(ARG1))));
|
||||||
}
|
}
|
||||||
case 2:
|
case 2:
|
||||||
{
|
{
|
||||||
CPredicate2 code2 = (CPredicate2)code;
|
CPredicate2 code2 = (CPredicate2)code;
|
||||||
return ((code2)(Deref(ARG1),Deref(ARG2)));
|
return ((code2)(YapInitSlot(Deref(ARG1)),
|
||||||
|
YapInitSlot(Deref(ARG2))));
|
||||||
}
|
}
|
||||||
case 3:
|
case 3:
|
||||||
{
|
{
|
||||||
CPredicate3 code3 = (CPredicate3)code;
|
CPredicate3 code3 = (CPredicate3)code;
|
||||||
return ((code3)(Deref(ARG1),Deref(ARG2),Deref(ARG3)));
|
return ((code3)(YapInitSlot(Deref(ARG1)),
|
||||||
|
YapInitSlot(Deref(ARG2)),
|
||||||
|
YapInitSlot(Deref(ARG3))));
|
||||||
}
|
}
|
||||||
case 4:
|
case 4:
|
||||||
{
|
{
|
||||||
CPredicate4 code4 = (CPredicate4)code;
|
CPredicate4 code4 = (CPredicate4)code;
|
||||||
return ((code4)(Deref(ARG1),Deref(ARG2),Deref(ARG3),Deref(ARG4)));
|
return ((code4)(YapInitSlot(Deref(ARG1)),
|
||||||
|
YapInitSlot(Deref(ARG2)),
|
||||||
|
YapInitSlot(Deref(ARG3)),
|
||||||
|
YapInitSlot(Deref(ARG4))));
|
||||||
}
|
}
|
||||||
case 5:
|
case 5:
|
||||||
{
|
{
|
||||||
CPredicate5 code5 = (CPredicate5)code;
|
CPredicate5 code5 = (CPredicate5)code;
|
||||||
return ((code5)(Deref(ARG1),Deref(ARG2),Deref(ARG3),Deref(ARG4),Deref(ARG5)));
|
return ((code5)(YapInitSlot(Deref(ARG1)),
|
||||||
|
YapInitSlot(Deref(ARG2)),
|
||||||
|
YapInitSlot(Deref(ARG3)),
|
||||||
|
YapInitSlot(Deref(ARG4)),YapInitSlot(Deref(ARG5))));
|
||||||
}
|
}
|
||||||
case 6:
|
case 6:
|
||||||
{
|
{
|
||||||
CPredicate6 code6 = (CPredicate6)code;
|
CPredicate6 code6 = (CPredicate6)code;
|
||||||
return ((code6)(Deref(ARG1),Deref(ARG2),Deref(ARG3),Deref(ARG4),Deref(ARG5),Deref(ARG6)));
|
return ((code6)(YapInitSlot(Deref(ARG1)),
|
||||||
|
YapInitSlot(Deref(ARG2)),
|
||||||
|
YapInitSlot(Deref(ARG3)),
|
||||||
|
YapInitSlot(Deref(ARG4)),
|
||||||
|
YapInitSlot(Deref(ARG5)),
|
||||||
|
YapInitSlot(Deref(ARG6))));
|
||||||
}
|
}
|
||||||
case 7:
|
case 7:
|
||||||
{
|
{
|
||||||
CPredicate7 code7 = (CPredicate7)code;
|
CPredicate7 code7 = (CPredicate7)code;
|
||||||
return ((code7)(Deref(ARG1),Deref(ARG2),Deref(ARG3),Deref(ARG4),Deref(ARG5),Deref(ARG6),Deref(ARG7)));
|
return ((code7)(YapInitSlot(Deref(ARG1)),
|
||||||
|
YapInitSlot(Deref(ARG2)),
|
||||||
|
YapInitSlot(Deref(ARG3)),
|
||||||
|
YapInitSlot(Deref(ARG4)),
|
||||||
|
YapInitSlot(Deref(ARG5)),
|
||||||
|
YapInitSlot(Deref(ARG6)),
|
||||||
|
YapInitSlot(Deref(ARG7))));
|
||||||
}
|
}
|
||||||
case 8:
|
case 8:
|
||||||
{
|
{
|
||||||
CPredicate8 code8 = (CPredicate8)code;
|
CPredicate8 code8 = (CPredicate8)code;
|
||||||
return ((code8)(Deref(ARG1),Deref(ARG2),Deref(ARG3),Deref(ARG4),Deref(ARG5),Deref(ARG6),Deref(ARG7),Deref(ARG8)));
|
return ((code8)(YapInitSlot(Deref(ARG1)),
|
||||||
|
YapInitSlot(Deref(ARG2)),
|
||||||
|
YapInitSlot(Deref(ARG3)),
|
||||||
|
YapInitSlot(Deref(ARG4)),
|
||||||
|
YapInitSlot(Deref(ARG5)),
|
||||||
|
YapInitSlot(Deref(ARG6)),
|
||||||
|
YapInitSlot(Deref(ARG7)),
|
||||||
|
YapInitSlot(Deref(ARG8))));
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
return(FALSE);
|
return(FALSE);
|
||||||
@ -616,7 +693,6 @@ static void myputc (int ch)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static Term told;
|
static Term told;
|
||||||
static int counter=0;
|
|
||||||
|
|
||||||
X_API int
|
X_API int
|
||||||
YapRunGoal(Term t)
|
YapRunGoal(Term t)
|
||||||
@ -979,45 +1055,6 @@ YapOpenStream(void *fh, char *name, Term nm, int flags)
|
|||||||
return retv;
|
return retv;
|
||||||
}
|
}
|
||||||
|
|
||||||
X_API long
|
|
||||||
YapNewSlots(int n)
|
|
||||||
{
|
|
||||||
Int old_slots = IntOfTerm(ASP[0]), oldn = n;
|
|
||||||
while (n > 0) {
|
|
||||||
RESET_VARIABLE(ASP);
|
|
||||||
ASP--;
|
|
||||||
n--;
|
|
||||||
}
|
|
||||||
ASP[0] = MkIntTerm(old_slots+oldn);
|
|
||||||
return((ASP+1)-LCL0);
|
|
||||||
}
|
|
||||||
|
|
||||||
X_API void
|
|
||||||
YapRecoverSlots(int n)
|
|
||||||
{
|
|
||||||
Int old_slots = IntOfTerm(ASP[0]);
|
|
||||||
ASP += n;
|
|
||||||
ASP[0] = MkIntTerm(old_slots-n);
|
|
||||||
}
|
|
||||||
|
|
||||||
X_API Term
|
|
||||||
YapGetFromSlot(long slot)
|
|
||||||
{
|
|
||||||
return(Deref(LCL0[slot]));
|
|
||||||
}
|
|
||||||
|
|
||||||
X_API Term *
|
|
||||||
YapAddressFromSlot(long slot)
|
|
||||||
{
|
|
||||||
return(LCL0+slot);
|
|
||||||
}
|
|
||||||
|
|
||||||
X_API void
|
|
||||||
YapPutInSlot(long slot, Term t)
|
|
||||||
{
|
|
||||||
LCL0[slot] = t;
|
|
||||||
}
|
|
||||||
|
|
||||||
X_API void
|
X_API void
|
||||||
YapThrow(Term t)
|
YapThrow(Term t)
|
||||||
{
|
{
|
||||||
|
@ -628,6 +628,13 @@ static long (*YapINewSlots)(N) = YapNewSlots;
|
|||||||
#define YapNewSlots(N) (*YapINewSlots)(N)
|
#define YapNewSlots(N) (*YapINewSlots)(N)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* Term *YapInitSlot() */
|
||||||
|
extern X_API long PROTO(YapInitSlot,(Term));
|
||||||
|
#ifdef IndirectCalls
|
||||||
|
static long (*YapIInitSlot)(T) = YapInitSlot;
|
||||||
|
#define YapInitSlot(T) (*YapIInitSlot)(T)
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Term YapGetFromSlots(t) */
|
/* Term YapGetFromSlots(t) */
|
||||||
extern X_API Term PROTO(YapGetFromSlot,(long));
|
extern X_API Term PROTO(YapGetFromSlot,(long));
|
||||||
#ifdef IndirectCalls
|
#ifdef IndirectCalls
|
||||||
|
@ -68,6 +68,7 @@ YapStreamToFileNo
|
|||||||
YapCloseAllOpenStreams
|
YapCloseAllOpenStreams
|
||||||
YapOpenStream
|
YapOpenStream
|
||||||
YapNewSlots
|
YapNewSlots
|
||||||
|
YapInitSlot
|
||||||
YapGetFromSlot
|
YapGetFromSlot
|
||||||
YapAddressFromSlot
|
YapAddressFromSlot
|
||||||
YapPutInSlot
|
YapPutInSlot
|
||||||
|
@ -398,7 +398,7 @@ debugging :-
|
|||||||
'$flags'(G,M,F,F),
|
'$flags'(G,M,F,F),
|
||||||
F /\ 16'2000 =\= 0, !, % dynamic procedure, immediate semantics
|
F /\ 16'2000 =\= 0, !, % dynamic procedure, immediate semantics
|
||||||
repeat,
|
repeat,
|
||||||
'$db_last_age'(M:G,Max),
|
( '$db_last_age'(M:G,Max) -> true ; !, fail ),
|
||||||
'$get_value'(spy_cl,Cl),
|
'$get_value'(spy_cl,Cl),
|
||||||
'$get_value'(spy_gn,L),
|
'$get_value'(spy_gn,L),
|
||||||
Maxx is Max+1,
|
Maxx is Max+1,
|
||||||
|
Reference in New Issue
Block a user